Project

General

Profile

« Previous | Next » 

Revision 5af6ef96

Added by Jim Regetz over 12 years ago

  • ID 5af6ef9628f571ce45e42856b74c0e94545cae5b

reorganized AML terrain scripts to reduce superficial redundancy

View differences:

terrain/research/oregon/aml/aggregate.aml
1
/* need to ensure that the aggregation boxes are consistent across the whole set of layers
2
/* so might need a setwindow here to enforce the correct location
3

  
4
/* Question about 1km Behrman version - should that be projected from 30" stats, or
5
/* should data be projected to Behrman and aggregated over 1km cell. Far from the equator
6
/* these will give quite different results
7

  
8
/* elevation - derive mean, min, max, std. dev, skew
9
elev_mean = aggregate(srtm_or_smth, 10, mean)
10
elev_min = aggregate(srtm_or_smth, 10, min)
11
elev_max = aggregate(srtm_or_smth, 10, max)
12
elev_range = elev_max - elev_min
13

  
14
/* stupid arc doesn't have a standard deviation function for aggregation
15
elev_sd = sqrt(aggregate(sqr(srtm_or_smth - elev_mean), 10, sum) / 100)
16

  
17

  
18
/* slope - just mean and standard deviation
19
slopedeg_mean = aggregate(slopedeg, 10, mean)
20
slopedeg_sd = sqrt(aggregate(sqr(slopdeg - slopedeg_mean), 10, sum) / 100)
21

  
22
/* wetness index - mean and standard deviation
23
/* twi not done yet
24
twi_fill_mean = aggregate(twi_fill, 10, mean)
25
twi_fill_sd = sqrt(aggregate(sqr(twi_fill - twi_fill_mean), 10, sum) / 100)
terrain/research/oregon/aml/chunkproc.aml
1
/* Invoke another AML on a grid to produce a grid
2
/* Other AML takes arguments: gridname outgridname otherargs
3

  
4
&args targetaml gridname outgridname otherargs:REST
5

  
6

  
7
/* targetaml-limits.aml takes same arguments as target.aml (except for
8
/* output file) and sets maximum number of cells and overlap required
9
&run %targetaml%-limits %gridname% [unquote %otherargs%]
10

  
11
&describe %gridname%
12
&sv gridxmin = %grd$xmin%
13
&sv gridxmax = %grd$xmax%
14
&sv gridymin = %grd$ymin%
15
&sv gridymax = %grd$ymax%
16
&sv gridncols = %grd$ncols%
17
&sv gridnrows = %grd$nrows%
18
&sv cellsize = %grd$dx%
19

  
20
/****** TEMPORARY *******/
21
/* setcell %cellsize%
22
/**** END TEMPORARY *****/
23

  
24
&sv ncells = %grd$ncols% * %grd$nrows%
25
&type %ncells% cells in %gridname%
26

  
27
&if %ncells% <= %.maxcells% &then &do
28
  /* no need to do chunks, just invoke target AML
29
  &type Process as single chunk
30
  &run %targetaml% %gridname% %outgridname% [unquote %otherargs%]
31
  &return
32
&end
33

  
34
/* need to do chunks
35
&type Process in multiple chunks
36
/* &type X: %gridxmin% %gridxmax% (%gridncols%) 
37
/* &type Y: %gridymin% %gridymax% (%gridnrows%) 
38
/* &type %ncells% cells, %.maxcells% max, %.border% border
39

  
40
&sv nchunks = [truncate [calc %ncells% / %.maxcells%]] + 1
41
&type Need at least %nchunks% chunks
42
&sv chunkdim = [sqrt %.maxcells%] + 2 * %.border%
43

  
44
&if %gridncols% < %chunkdim% &then
45
  &do
46
    &sv colchunks = 1
47
    &sv rowchunks = %nchunks%
48
    &sv chunkncols = %gridncols%
49
    &sv chunknrows = [truncate [calc %gridnrows% / %rowchunks%]] + 1
50
  &end
51
&else &if %gridnrows% < %chunkdim% &then
52
  &do
53
    &sv rowchunks = 1
54
    &sv colchunks = %nchunks%
55
    &sv chunkncols = [truncate [calc %gridncols% / %colchunks%]] + 1
56
  &end
57
&else 
58
  &do
59
    &sv rowchunks = [truncate [calc %gridnrows% / %chunkdim%]] + 1
60
    &sv colchunks = [truncate [calc %gridncols% / %chunkdim%]] + 1
61
    &sv chunkncols = [truncate [calc %gridncols% / %colchunks%]] + 1
62
    &sv chunknrows = [truncate [calc %gridnrows% / %rowchunks%]] + 1
63
  &end
64

  
65

  
66
&type %colchunks% colchunks, %rowchunks% rowchunks
67
&type Chunk size %chunkncols% cols by %chunknrows% rows
68

  
69
&sv qtrcell = %cellsize% / 4
70
&sv halfcell = %cellsize% / 2
71
&sv colist
72

  
73
&sv chunki = 1
74
&do &while %chunki% <= %colchunks%
75
  &sv chunkj = 1
76
  &sv colist_col
77
  &do &while %chunkj% <= %rowchunks%
78
    &type Chunk %chunki% %chunkj%
79

  
80
    &sv coxmin = %gridxmin% + ( %chunki% - 1 ) * %chunkncols% * %cellsize% - %qtrcell%
81
    &sv coxmax = %coxmin% + %chunkncols% * %cellsize% + %halfcell%
82
    &sv coymin = %gridymin% + ( %chunkj% - 1 ) * %chunknrows% * %cellsize% - %qtrcell%
83
    &sv coymax = %coymin% + %chunknrows% * %cellsize% + %halfcell%
84

  
85
    /* &type Output X: %coxmin% %coxmax%
86
    /* &type Output Y: %coymin% %coymax%
87

  
88
    &if %chunki% = 1 &then &sv chunkxmin = %coxmin%
89
    &else &sv chunkxmin = %coxmin% - %.border% * %cellsize%
90
    &if %chunki% = %colchunks% &then &sv chunkxmax = %coxmax%
91
    &else &sv chunkxmax = %coxmax% + %.border% * %cellsize%
92

  
93
    &if %chunkj% = 1 &then &sv chunkymin = %coymin%
94
    &else &sv chunkymin = %coymin% - %.border% * %cellsize%
95
    &if %chunkj% = %rowchunks% &then &sv chunkymax = %coymax%
96
    &else &sv chunkymax = %coymax% + %.border% * %cellsize%
97

  
98
    /* &type Chunk X: %chunkxmin% %chunkxmax%
99
    /* &type Chunk Y: %chunkymin% %chunkymax%
100

  
101
    /* clip input file to chunk (with borders)
102
    setwindow %chunkxmin% %chunkymin% %chunkxmax% %chunkymax% %gridname%
103
    &if [exists chunk -grid] &then kill chunk
104
    chunk = %gridname%  
105
    &if [exists co_tmp -grid] &then kill co_tmp
106
    &run %targetaml% chunk co_tmp [unquote %otherargs%]
107
    kill chunk
108

  
109
    /* clip output file to chunk (without borders)
110
    setwindow %coxmin% %coymin% %coxmax% %coymax% %gridname%
111
    &if [exists co_%chunki%_%chunkj% -grid] &then kill co_%chunki%_%chunkj%
112
    co_%chunki%_%chunkj% = co_tmp
113
    kill co_tmp
114

  
115
    &if %chunkj% = 1 &then &sv colist_col = co_%chunki%_%chunkj%
116
    &else &sv colist_col = %colist_col%, co_%chunki%_%chunkj%
117

  
118
    &sv chunkj = %chunkj% + 1
119
  &end
120
  setwindow maxof
121
  &if [exists co_%chunki% -grid] &then kill co_%chunki%
122
  co_%chunki% = merge(%colist_col%)
123
  kill (!%colist_col%!)
124
  &if %chunki% = 1 &then &sv colist = co_%chunki%
125
  &else &sv colist = %colist%, co_%chunki%
126
  &sv chunki = %chunki% + 1
127
&end
128

  
129
setwindow maxof
130
&if [exists %outgridname% -grid] &then kill %outgridname%
131
%outgridname% = merge(%colist%)
132
kill (!%colist%!)
terrain/research/oregon/aml/gauss3
1
11 11
2
0.017 0.046 0.100 0.174 0.242 0.271 0.242 0.174 0.100 0.046 0.017 
3
0.046 0.124 0.271 0.472 0.659 0.736 0.659 0.472 0.271 0.124 0.046 
4
0.100 0.271 0.590 1.028 1.434 1.603 1.434 1.028 0.590 0.271 0.100 
5
0.174 0.472 1.028 1.791 2.500 2.793 2.500 1.791 1.028 0.472 0.174 
6
0.242 0.659 1.434 2.500 3.488 3.898 3.488 2.500 1.434 0.659 0.242 
7
0.271 0.736 1.603 2.793 3.898 4.356 3.898 2.793 1.603 0.736 0.271 
8
0.242 0.659 1.434 2.500 3.488 3.898 3.488 2.500 1.434 0.659 0.242 
9
0.174 0.472 1.028 1.791 2.500 2.793 2.500 1.791 1.028 0.472 0.174 
10
0.100 0.271 0.590 1.028 1.434 1.603 1.434 1.028 0.590 0.271 0.100 
11
0.046 0.124 0.271 0.472 0.659 0.736 0.659 0.472 0.271 0.124 0.046 
12
0.017 0.046 0.100 0.174 0.242 0.271 0.242 0.174 0.100 0.046 0.017 
terrain/research/oregon/aml/layers.aml
1
/* using srtmv41 3x3 degree patch smoothed to srtmv41_smth
2
/* need to run GRID
3

  
4
&describe srtm_or_smth
5
&sv cellsize %grd$dx% * 111000
6
dzdx = (srtm_or_smth(1,0) - srtm_or_smth(-1,0)) / (2 * %cellsize% * cos($$ymap / deg))
7
dzdy = (srtm_or_smth(0,-1) - srtm_or_smth(0,1)) / (2 * %cellsize%)
8
slope = sqrt(sqr(dzdx) + sqr(dzdy))
9
slopedeg = atan(slope) * deg
10
/* use scaling factor that is average of x and y scaling factors, 0.707 and 1 ~= 0.85
11
/* and 0.85 / 111000 ~ 0.0000107
12
arcslope = slope(srtm_or_smth, 0.0000107, degree)
13
hillshade = hillshade(srtm_or_smth, 300, 30, shade, 0.00001)
14

  
15
aspect1 = atan2(0 - dzdy, 0 - dzdx) * deg
16
aspect = con(aspect1 > 90, 450 - aspect1, 90 - aspect1)
17
kill aspect1
18

  
19
/*use elevation 
20
flowdir = flowdirection(srtm_or_smth)
21

  
22
/*cell area to account for latitudinal area effects, smallest area near pole
23
setwindow srtm_or_smth
24
setcell srtm_or_smth 
25
cellarea = sqr(%cellsize%) * cos($$ymap / deg)
26
flowacc = flowaccumulation(flowdir, cellarea)
27

  
28
/*account for sinks
29
/*change # defaulto z limit
30
/*caution fill is a command not function
31
/*fill srtm_or_smth srtm_or_fill sink # flowdir_fill
32

  
33
flowacc_fill = flowaccumulation(flowdir_fill, cellarea)
34

  
35
/*scatch_fill is specific catchment area in m
36
/*wrong filling? flowdir_fill produces artefacts
37
scatch_fill = flowacc_fill / sqrt(cellarea) + sqrt(cellarea) / 2
38
/*setting the min slope to 0.1
39
adjslope = tan(max(slopedeg, 0.1) / deg)
40

  
41
twi_fill = ln(scatch_fill / adjslope)
terrain/research/oregon/aml/mrvbf6g-a3.aml
1
/*   WRR paper is based on vd5r.aml. Prior history in vd5r.aml
2
/*
3
/*   mrvbf6a - vd5r modified to incorporate min (fuzzy and) instead of 
4
/*	multiplication when combining flatness and lowness. The transformation
5
/*	following combination of flatness and lowness is no longer used, so
6
/*	tvf and rvf layers are not computed, vf and rf are used directly.
7
/*
8
/*   mrvbf6b - mrvbf6a modified to use hard thresholds when recombining
9
/*	resolutions, rather than the smooth approach that resulted in
10
/*	values bleeding into lower resolution classes
11
/*	
12
/*	-2 changed threshold for converting pctl to low from 0.4 to 0.5
13
/*
14
/*   mrvbf6c - tried using standard deviation - not continued
15
/*
16
/*   mrvbf6d - another attempt to remove small hilltops from inclusion in
17
/*	valley bottom classes by including a fraction of the low indicator
18
/*	from the previous scale
19
/*
20
/*	-2 changed weighting of previous low/high from 0.3 to 0.5
21
/*
22
/*   mrvbf6f - (ignoring the 6e experiment)
23
/*	-1 Following results from Linda Gregory's transcription of the
24
/*	   method to Python in ArcGIS, removed the use of nibble to
25
/*	   extend the DEM beyond its original borders. Seems to be 
26
/*	   unnecessary.
27
/*	   Included extension of grids by one pixel at each step
28
/*
29
/*   mrvbf6g - all of 6f, plus std dev
30
/*         Use sd thresholds with _3 applying to level 3, _9 to level 4 etc 
31
/*	-2 Reduce standard deviation threshold by a factor of 2, so first
32
/*	   threshold is 4 instead of 8. This follows analysis of -1 that
33
/*	   shows that ridge tops are still being left in that should be
34
/*	   eliminated.
35
/*	-3 Reduce pctl radius from 6 cells to 3 at all steps. Radius is the
36
/*	   same for first two steps.
37
/*	-7 As for -3, but change carrying forward of low indicator to use 
38
/*	   raw pctl from previous scale, not low weight. This means that the
39
/*	   information only comes from one scale finer, not all finer scales.
40
/*	   This is to attempt to remedy the defects introduced by the -3 version
41
/*	   while retaining its ability to remove some problems.
42
/*	-10 As for -8, but pctl radius at 6 cells from step 2 onwards.
43
/*
44
/*	-a2 Added code to automatically detect geographic coords
45
/*	    Calculates sdthres from resolution, same as slopethres
46
/*	-a3 Incorporate mssd calculations directly in the AML, using 
47
/*	    correct methods developed in SRTM project; changed name of 
48
/*	    sd layers to match slope naming
49

  
50

  
51
&args dem
52
/* dem: name of dem to work from
53

  
54
&sv keep 1
55
/* higher keep values result in more intermediate results being kept
56

  
57
&describe %dem%
58
&sv mindim = [min %grd$ncols% %grd$nrows%]
59
&sv maxresmult = 1
60
&sv nsteps = 2
61
&do &while [calc %mindim% / %maxresmult%] > [calc 5 * 3]
62
  &sv maxresmult = [calc %maxresmult% * 3]
63
  &sv nsteps = [calc %nsteps% + 1]
64
&end
65
&type Minimum DEM dimension = %mindim%, max resolution = %maxresmult%
66
&type %nsteps% steps
67

  
68

  
69

  
70
&if [null %prj$units%] &then
71
  &return &error No horizontal units defined for DEM %dem%
72

  
73

  
74
&select %prj$units%
75
  &when METERS
76
    &do
77
      &type DEM horizontal units is metres, good
78
      &sv geographic = .false.
79
    &end
80

  
81
  &when DD
82
    &do
83
      &type DEM horizontal units is decimal degrees, scale
84
      &sv geographic = .true.
85
    &end
86

  
87
  &otherwise
88
      &return &error Unrecognised horizontal units for DEM %dem%: %prj$units%
89

  
90
&end
91

  
92
/* set up scaling factors for geographic data
93
&if %geographic% &then &do
94
  &type Calculating geographic scaling factors
95
  &sv xyfactor [calc 110000 * [cos [calc ( %grd$ymin% + %grd$ymax% ) / 2 / 57.2958] ]  ]
96
  &sv zfactor [calc 1 / %xyfactor% ]
97
  &end
98
&else &do
99
  &sv xyfactor 1
100
  &sv zfactor 1
101
&end
102

  
103
&sv baseres = %grd$dx%
104
&sv resmetres = [calc %baseres% * %xyfactor%]
105

  
106
&type DEM resolution = %resmetres% metres
107

  
108
&sv minvbf = 1
109
&sv vbfres = 4  /* maximum resolution for first vbf = 1
110
&sv slopethres = 64  /* 64% = 33 degrees, about steepest for any deposit
111
&sv sdthres = 0.375  /* developed with 1.5 at 25 m
112
&sv pctlradius = [calc %vbfres% * 3]
113
&do &while %vbfres% < %resmetres%
114
  &sv minvbf = [calc %minvbf% + 1]
115
  &sv vbfres = [calc %vbfres% * 3]
116
  &sv slopethres = [calc %slopethres% / 2]
117
  &sv sdthres = [calc %sdthres% * 2]
118
  &sv pctlradius = [calc %pctlradius% * 3]
119
&end
120
&type CHOICE setting pctlradius = 3 * dem resolution
121
&sv pctlradius = [calc %resmetres% * 3.02]
122
/* Modified 18/10/2006 to overcome numerical issues in pctl's cell inclusion calcs
123

  
124
&type TEMPORARY setting minvbf = 1
125
&sv minvbf = 1
126

  
127
&type VBF for base resolution = %minvbf%
128
&type Slope threshold = %slopethres%, percentile radius = %pctlradius%
129

  
130
setwindow %dem%
131
setcell minof
132

  
133
/* set weighting for pctl value from previous step
134
&sv prevpctlwt = 0.5
135

  
136

  
137
&sv l = 0
138
&sv v = %minvbf%
139

  
140
&sv l = 0
141
&sv l1 = 0
142
&sv res = %baseres%
143

  
144
&do &while %l% < %nsteps%
145
  &if %l% = 0 &then &sv l = 1
146
    &else &sv l = [calc %l% + 1]
147
  &type === Step %l% ====
148
  &if %l% > 2 &then &do
149
    &sv res = [calc %res% * 3]
150
    &sv resmetres = [calc %res% * %xyfactor%]
151
  &end
152
  &type Resolution = %res% (%resmetres% metres)
153
  &type Slope threshold = %slopethres%, pctl radius = %pctlradius%
154
  &type Std dev threshold = %sdthres%
155

  
156
  &type Checkpoint 1
157

  
158
  &if %l% > 2 &then &do
159
    &type Checkpoint 1.1
160
    /* create a smoothed version of the DEM from the previous resolution
161
    &if [exists dem_%l%_%l1% -grid] &then kill dem_%l%_%l1%
162
    &describe %dem%
163
    setwindow [calc %grd$xmin% - %res%] [calc %grd$ymin% - %res%] [calc %grd$xmax% + %res%] [calc %grd$ymax% + %res%]
164
    &if %l% = 3 &then &do
165
      dem_%l%_%l1% = focalsum(%dem%, weight, gauss3, data) / focalsum(con(%dem% > -999, 1, 0), weight, gauss3, data)
166
    &end
167
    &else &do
168
      dem_%l%_%l1% = focalsum(dem_%l1%_%l1%, weight, gauss3, data) / focalsum(con(dem_%l1%_%l1% > -999, 1, 0), weight, gauss3, data)
169
    &end
170

  
171
    &type Checkpoint 1.2
172
    /* calculate standard deviation
173
    &if [exists sd_%l% -grid] &then kill sd_%l%
174
    &if %l% = 3 &then &do
175
      sd_%l% = resample(blockstd(%dem%, rectangle, 3, 3), %res%, nearest)
176
    &end
177
    &else &do
178
      &if [exists sswg_%l% -grid] &then kill sswg_%l%
179
      &if [exists ssbg_%l% -grid] &then kill ssbg_%l%
180
      sswg_%l% = aggregate(pow(sd_%l1%, 2), 3, sum)
181
      ssbg_%l% = 9 * pow(resample(blockstd(dem_%l1%_%l1%, rectangle, 3, 3), %res%, nearest), 2)
182
      sd_%l% = sqrt((sswg_%l% + ssbg_%l%) / 9)
183
      &if %keep% <= 4 &then &do
184
        kill ssbg_%l%
185
        kill sswg_%l%
186
      &end
187
    &end
188

  
189
    &type Checkpoint 1.3
190
    &if %keep% <= 2 &then &do
191
      /* get rid of DEM from previous step
192
      &if %l1% > 2 &then kill dem_%l1%_%l1%
193
      &if %l1% > 2 &then kill sd_%l1%
194
    &end
195
  &end
196

  
197
  &type Checkpoint 2
198

  
199
  &if [exists s_%l%_1 -grid] &then kill s_%l%_1
200
  &if %l% = 1 &then &do
201
    /* first step, compute slope from base resolution
202
    &type Compute slope from DEM
203
    s_1_1 = slope(%dem%, %zfactor%, percentrise)
204
  &end 
205
  &else &if %l% = 2 &then &do
206
    /* second step, slope is same as from first step
207
    &if %keep% <= 4 &then rename s_1_1 s_2_1
208
    &else copy s_1_1 s_2_1
209
  &end
210
  &else &do
211
    /* compute slope from smoothed DEM
212
    &if [exists s_%l%_%l1% -grid] &then kill s_%l%_%l1%
213
    s_%l%_%l1% = slope(dem_%l%_%l1%, %zfactor%, percentrise)
214
    &if %l% > 2 &then &do
215
      /* resample back to base resolution
216
      s_%l%_1 = resample(s_%l%_%l1%, %baseres%, bilinear)
217
    &end
218
    &if %keep% <= 5 &then kill s_%l%_%l1%
219

  
220
    &if [exists dem_%l%_%l% -grid] &then kill dem_%l%_%l%
221
    dem_%l%_%l% = resample(dem_%l%_%l1%, %res%)
222
    &if %keep% <= 5 &then kill dem_%l%_%l1%
223
  &end
224
  &if [exists f_%l% -grid] &then kill f_%l%
225
  f_%l% = 1 / (1 + pow(s_%l%_1 / %slopethres%, 4))
226
  &if %keep% <= 4 &then &do
227
    /* get rid of s_%l%_1, except when l = 1 and we need it for s_2_1
228
    &if %l% ^= 1 &then kill s_%l%_1
229
  &end
230

  
231
  &type Checkpoint 3
232

  
233
  &if [exists pctl_%l%_1 -grid] &then kill pctl_%l%_1
234
  &if [exists cpctl_%l%_1 -grid] &then kill cpctl_%l%_1
235
  &if [exists cf_%l% -grid] &then kill cf_%l%
236
  &if [exists low_%l% -grid] &then kill low_%l%
237
  &if [exists vf_%l% -grid] &then kill vf_%l%
238
  &if [exists high_%l% -grid] &then kill high_%l%
239
  &if [exists rf_%l% -grid] &then kill rf_%l%
240
  &if %l% <= 2 &then &do
241
    &r chunkproc pctl %dem% pctl_%l%_1 %pctlradius% %geographic%
242
    &if %l% = 1 &then &do
243
      low_%l% = 1 / (1 + pow(pctl_%l%_1 / 0.5, 3))
244
    &end
245
    &else &do
246
      cpctl_%l%_1 = [calc 1 - %prevpctlwt%] * pctl_%l%_1 + %prevpctlwt% * pctl_%l1%_1
247
      low_%l% = 1 / (1 + pow(cpctl_%l%_1 / 0.5, 3))
248
    &end
249
    vf_%l% = min(f_%l%, low_%l%)
250
    &if %l% = 1 &then &do
251
      high_%l% = 1 / (1 + pow((1 - pctl_%l%_1) / 0.5, 3))
252
    &end
253
    &else &do
254
      high_%l% = 1 / (1 + pow((1 - cpctl_%l%_1) / 0.5, 3))
255
    &end
256
    rf_%l% = min(f_%l%, high_%l%)
257
    &if %l% = 2 &then &do
258
      cf_2 = f_2 * f_1
259
      &if %keep% <= 3 &then kill f_1
260
    &end
261
  &end
262
  &else &do
263
    &if [exists pctl_%l%_%l% -grid] &then kill pctl_%l%_%l%
264
    &r chunkproc pctl dem_%l%_%l% pctl_%l%_%l% %pctlradius% %geographic%
265
    pctl_%l%_1 = resample(pctl_%l%_%l%, %baseres%, bilinear)
266
    cpctl_%l%_1 = [calc 1 - %prevpctlwt%] * pctl_%l%_1 + %prevpctlwt% * pctl_%l1%_1
267
    &if %keep% <= 5 &then kill pctl_%l%_%l%
268
    cf_%l% = f_%l% * cf_%l1%
269
    &if %keep% <= 3 &then kill cf_%l1%
270
    low_%l% = 1 / (1 + pow(cpctl_%l%_1 / 0.5, 3))
271
    &if [exists lowrelief_%l% -grid] &then kill lowrelief_%l%
272
    lowrelief_%l% = 1 / (1 + pow(sd_%l% / %sdthres%, 4))
273

  
274
    vf_%l% = min(cf_%l%, low_%l%, lowrelief_%l%)
275
    high_%l% = 1 / (1 + pow((1 - cpctl_%l%_1) / 0.5, 3))
276
    rf_%l% = min(cf_%l%, high_%l%, lowrelief_%l%)
277
    &if %keep% <= 3 &then kill lowrelief_%l%
278
  &end
279

  
280
  &type Checkpoint 4
281

  
282
  &if %l% > 1 &then &do
283
    &if %keep% <= 4 &then kill pctl_%l1%_1
284
    &if %keep% <= 4 &then kill cpctl_%l%_1
285
    &if %keep% <= 3 &then kill f_%l%
286
  &end
287
  &if [exists mrvbf_%l% -grid] &then kill mrvbf_%l%
288
  &if [exists mrrtf_%l% -grid] &then kill mrrtf_%l%
289
  &if %l% = 2 &then &do
290
    mrvbf_%l% = con(vf_2 >= 0.5, vf_2 + %v% - 1, vf_1)
291
    mrrtf_%l% = con(rf_2 >= 0.5, rf_2 + %v% - 1, rf_1)
292
    &if %keep% <= 3 &then kill vf_1
293
    &if %keep% <= 3 &then kill rf_1
294
  &end
295
  &else &if %l% > 2 &then &do
296
      mrvbf_%l% = con(vf_%l% >= 0.5, vf_%l% + %v% - 1, mrvbf_%l1%)
297
      mrrtf_%l% = con(rf_%l% >= 0.5, rf_%l% + %v% - 1, mrrtf_%l1%)
298
     &if %keep% <= 3 &then kill mrvbf_%l1%
299
     &if %keep% <= 3 &then kill mrrtf_%l1%
300
  &end
301
  &if %l% >= 2 &then &do
302
    &if %keep% <= 3 &then kill vf_%l%
303
    &if %keep% <= 3 &then kill rf_%l%
304
  &end
305

  
306
  &type Checkpoint 5
307

  
308
  &sv v = [calc %v% + 1]
309

  
310
  &sv l1 = %l%
311
  &sv slopethres = [calc %slopethres% / 2]
312
  &if %l% > 2 &then &do
313
    &sv sdthres = [calc %sdthres% * 2]
314
  &end
315
  &if %l% = 1 &then &sv pctlradius = [calc %pctlradius% * 2]
316
  &else &sv pctlradius = [calc %pctlradius% * 3]
317

  
318
  &type Checkpoint 6
319
&end
320

  
321
&if %keep% <= 4 &then kill cf_%l%
322
&if %keep% <= 4 &then kill pctl_%l%_1
323
&if %keep% <= 2 &then kill dem_%l%_%l%
324

  
325
&if [exists mrvbf6g-a -grid] &then kill mrvbf6g-a
326
&if [exists mrrtf6g-a -grid] &then kill mrrtf6g-a
327
mrvbf6g-a = con(%dem% > -999, con(mrvbf_%l% > [calc %minvbf% - 0.5], mrvbf_%l%, 0))
328
mrrtf6g-a = con(%dem% > -999, con(mrrtf_%l% > [calc %minvbf% - 0.5], mrrtf_%l%, 0))
329
&if %keep% <= 2 &then kill mrvbf_%l%
330
&if %keep% <= 2 &then kill mrrtf_%l%
331

  
terrain/research/oregon/aml/multiscalesmooth9a_clean.aml
1
/* run in GRID, not ARC
2
/* &run .aml ingrid sd prob bbox
3
/* sd 0.0001 prob 0.05 
4

  
5
&args ingrid sd prob bbox:rest
6

  
7
/* 9a - limit to 4 steps, see if that has any significant deterioration of smoothing performance. Should fix
8
/* the problem with islands and headlands - turns out also need to remove water except
9
/* for one cell adjacent to land, and give that a higher uncertainty. See cluster_multiscalesmooth9a_clean_216
10

  
11
/* Version 9:
12
/* Focus on implementing identical algorithm to directsmooth2 using multiscale method i.e. aggregating by factor of 3 
13
/* from already aggregated data, rather than from original resolution each time.
14

  
15
/* Version 8:
16
/* WARNING: have not yet checked that the additional weighting of the gaussian smoothing is not messing with
17
/* the calculations of variance etc.
18
/* Replaced simple 3x3 aggregation with gaussian smoothing
19
/* Kernel is chosen to give appropriate level of smoothing and produce a fairly accurate approximation of the smoothed
20
/* surface by interpolation of the coarser scale smoothed values
21
/* Details in gaussian.xls on john's laptop
22

  
23
/* Version 7:
24
/* Further reworking of how the final values are selected - a mean is a candidate if its associated variance
25
/* is less than the mean sample uncertainty, and the mean with the lowest variance among the candidates is the chosen one.
26
/* Implement that in the nested sense by taking the lowest group variance divided by the chi^2 value, and its associated mean variance,
27
/* and if that is lower than the data point variance the 
28

  
29
/* approximate critical value of chi^2/N with N degrees of freedom at 5% level as 1 + 2.45/sqrt(N) + 0.55/N
30
/* for 1% level use 1 + 3.4/sqrt(N) + 2.4/N
31

  
32
/* Version 6:
33
/* Done from scratch after careful working through of theory.
34
/* ingrid is the (potentially sparse) grid of data to be smoothed and
35
/* interpolated, which can be of different extent to the output
36
/* (resolution is assumed to be the same, could adapt this to relax that)
37
/*
38
/* var can be a constant or a grid
39
/*
40
/* bbox can be either a grid name or the 'xmin ymin xmax ymax' parameters
41
/* for setwindow
42

  
43
&type NB - using standard deviation as noise specification now, not variance!
44

  
45

  
46
/* set up chisq parameters
47
&sv chisqa = [calc 2.807 - 0.6422 * [log10 %prob% ] - 3.410 * %prob% ** 0.3411 ]
48
&sv chisqb = [calc -5.871 - 3.675 * [log10 %prob% ] + 4.690 * %prob% ** 0.3377 ]
49
&type chisq parameters %chisqa% %chisqb%
50

  
51

  
52
setcell %ingrid%
53

  
54
/* work out maximum of ingrid and bbox extents
55
setwindow [unquote %bbox%] %ingrid%
56
bboxgrid = 1
57
setwindow maxof
58
workgrid = %ingrid% + bboxgrid
59
setwindow workgrid
60
kill workgrid
61

  
62
/* naming:
63
/*  h - the value being smoothed/interpolated
64
/*  vg - total variance of group of data, or of individual measurement
65
/*  v_bg - variance between groups
66
/*  v_wg - variance within groups
67
/*  wa - weighting for aggregation, based on total variance
68
/*  vm - variance of the calculated mean
69
/*  mv - mean of finer scale variances
70
/*  n - effective number of measurements
71

  
72

  
73
/* NB - only calculating sample variances here, not variances of estimated means.
74
/* Also note that v0_bg is an uncertainty, not a sample variance
75
/* and v1_bg is total variances, but both are labelled as "between-group" to simplify the smoothing
76

  
77
h0 = %ingrid%
78
v0 = con(^ isnull(h0), sqr(%sd%))
79
vg0 = v0
80
w0 = con(isnull(v0), 0, 1.0 / v0)
81
wsq0 = sqr(w0)
82
n0 = con(^ isnull(h0), 1, 0)
83

  
84
&describe v0
85
&sv bigvar %grd$zmax%
86

  
87
setcell minof
88

  
89
/* aggregate to broader scales
90
&sv i 1
91
&sv done .false.
92
&describe h0
93

  
94
&do &until %done%
95
  &sv j [calc %i% - 1]
96

  
97
  &type Aggregate from %j% to %i%
98

  
99
  &describe h%j%
100
  &sv cell3 [calc %grd$dx% * 3]
101
  &describe h0
102
  &sv nx0 [round [calc %grd$xmin% / %cell3% - 0.5]]
103
  &sv ny0 [round [calc %grd$ymin% / %cell3% - 0.5]]
104
  &sv nx1 [round [calc %grd$xmax% / %cell3% + 0.5]]
105
  &sv ny1 [round [calc %grd$ymax% / %cell3% + 0.5]]
106
  &sv x0 [calc ( %nx0% - 0.5 ) * %cell3%]
107
  &sv y0 [calc ( %ny0% - 0.5 ) * %cell3%]
108
  &sv x1 [calc ( %nx1% + 0.5 ) * %cell3%]
109
  &sv y1 [calc ( %ny1% + 0.5 ) * %cell3%]
110
  setwindow %x0% %y0% %x1% %y1%
111

  
112
  w%i% = aggregate(w%j%, 3, sum)
113
  wsq%i% = aggregate(wsq%j%, 3, sum)
114
  n%i% = aggregate(n%j%, 3, sum)
115
  neff%i% = w%i% * w%i% / wsq%i%
116
  h%i% = aggregate(w%j% * h%j%, 3, sum) / w%i%
117
  vbg%i% = aggregate(w%j% * sqr(h%j% - h%i%), 3, sum) / w%i%
118
  &if %i% eq 1 &then vwg%i% = n%i% - n%i% /* zero, but with window and cell size set for us
119
  &else vwg%i% = aggregate(w%j% * vg%j%, 3, sum) / w%i%
120
  vg%i% = vbg%i% + vwg%i%
121
  vm%i% = 1.0 / w%i%
122
  mv%i% = n%i% / w%i%
123

  
124
  chisq%i% = 1 + %chisqa% / sqrt(neff%i% - 1) + %chisqb% / (neff%i% - 1)
125
  v%i% = con(vg%i% / chisq%i% < mv%i%, vm%i%, vg%i%)
126

  
127
  /* remove everything except h%i% and v%i%
128
  kill w%j%
129
  kill wsq%j%
130
  kill n%j%
131
  kill neff%i%
132
  kill vbg%i%
133
  kill vwg%i%
134
  kill vg%j%
135
  kill vm%i%
136
  kill mv%i%
137
  kill chisq%i%
138

  
139
  &sv done %i% eq 4
140

  
141
  &sv i [calc %i% + 1]
142
&end
143

  
144

  
145
&sv maxstep [calc %i% - 1]
146
&sv bigvar [calc %bigvar% * 10]
147

  
148
kill w%maxstep%
149
kill wsq%maxstep%
150
kill n%maxstep%
151
kill vg%maxstep%
152

  
153
/* smooth, refine and combine each layer in turn
154

  
155

  
156
copy h%maxstep% hs%maxstep%
157
copy v%maxstep% vs%maxstep%
158
kill h%maxstep%
159
kill v%maxstep%
160
setcell hs%maxstep%
161
setwindow hs%maxstep%
162

  
163
&do j := %maxstep% &to 1 &by -1
164
  &sv i [calc %j% - 1]
165

  
166
  &type Refine from %j% to %i%
167

  
168
  /* for the first stage where the coarser grid is refined and smoothed, set window to the coarse grid
169
  setcell h%i%
170
  setwindow maxof
171

  
172
  /* create smoothed higher resolution versions of h and v_bg, hopefully with no nulls!
173
  hs%j%_%i% = focalmean(hs%j%, circle, 2)
174
  vs%j%_%i% = focalmean(vs%j%, circle, 2)
175

  
176
  setcell h%i%
177
  &describe h%i%
178
  &sv cellsize %grd$dx%
179
  &describe bboxgrid
180
  setwindow [calc %grd$xmin% - 4 * %cellsize%] [calc %grd$ymin% - 4 * %cellsize%] [calc %grd$xmax% + 4 * %cellsize%] [calc %grd$ymax% + 4 * %cellsize%] h%i%
181

  
182
  /* create no-null version of finer h and v
183
  h%i%_c = con(isnull(h%i%), 0, h%i%)
184
  v%i%_c = con(isnull(v%i%), %bigvar%, v%i%)
185

  
186
  /* combine two values using least variance
187
  hs%i% = (h%i%_c / v%i%_c + hs%j%_%i% / vs%j%_%i% ) / (1.0 / v%i%_c + 1.0 / vs%j%_%i%)
188
  vs%i% = 1 / (1.0 / v%i%_c + 1.0 / vs%j%_%i%)
189

  
190
  kill v%i%_c  
191
  kill h%i%_c
192
  kill v%i%
193
  kill h%i%
194
  kill vs%j%_%i%
195
  kill hs%j%_%i%
196
  kill hs%j%
197
  kill vs%j%
198
&end
199

  
200
/* result is hs0, with variance vs0
201

  
202
kill bboxgrid
terrain/research/oregon/aml/pctl-limits.aml
1
&args gridname radius geographic
2

  
3
&describe %gridname%
4

  
5
&if %geographic% &then &sv xyfactor [calc 110000 * [cos [calc ( %grd$ymin% + %grd$ymax% ) / 2 / 57.2958] ]  ]
6
&else &sv xyfactor 1
7

  
8

  
9
&sv radiuscells = [calc %radius% / ( %grd$dx% * %xyfactor% )]
10

  
11
&type radius = %radiuscells% cells
12

  
13
&sv .maxcells 50000000
14
/* &sv .maxcells 500000 /* Testing on Kyeamba 
15
&sv .border [calc %radiuscells% + 1]
terrain/research/oregon/aml/pctl.aml
1
&args dem pctlname radius geographic
2

  
3
&type Running pctl %dem% %pctlname% %radius% %geographic%
4

  
5
&if [exists demtmp.flt -file] &then [delete demtmp.flt -file]
6
demtmp.flt = gridfloat(%dem%)
7
&if %geographic% &then &sys pctl -ud %radius% demtmp.flt pctl.flt
8
&else &sys pctl %radius% demtmp.flt pctl.flt
9
&if [delete demtmp.flt -file] ^= 0 &then &type ERROR deleting demtmp.flt
10
&if [delete demtmp.hdr -file] ^= 0 &then &type ERROR deleting demtmp.hdr
11
&if [delete demtmp.prj -file] ^= 0 &then &type ERROR deleting demtmp.prj
12
&if [exists %pctlname% -grid] &then kill %pctlname%
13
%pctlname% = floatgrid(pctl.flt)
14
&if [delete pctl.flt -file] ^= 0 &then &type ERROR deleting pctl.flt
15
&if [delete pctl.hdr -file] ^= 0 &then &type ERROR deleting pctl.hdr
terrain/research/oregon/aml/tilemerge_oregon1.aml
1
/* merge x tiles in Oregon around Portland for testing methods
2

  
3

  
4
&if %:program%_ eq ARC_ &then grid
5
&if %:program%_ ne GRID_ &then
6
&return This program must be run from ARC or GRID.
7

  
8
/*note the directory path
9
&sv tiledir I:\NCEAS\topo\tiles
10
&sv outdir I:\NCEAS\topo\experimental
11
&sv name srtmv41
12
&sv vernum 1
13

  
14
/* This can be extended to larger areas (beyond 3x3 used here) but at some stage the
15
/* tilelist variable is going to get too long - AML has a limited line length
16
/* At this point, it would be better to tile by longitude band i.e. do a merge for
17
/* each value of w, then merge the resulting strips as a separate step
18

  
19
/* can be more elegant, loop across lat band then merge
20

  
21
&sv tilelist
22
&do w = 115 &to 117
23
  &do n = 42 &to 46
24
    &sv tilelist %tilelist%, %tiledir%\w%w%\n%n%\%vernum%\%name%\w%w%n%n%
25
  &end
26
&end
27

  
28
%outdir%\srtmv41_OR1 = merge(%tilelist%)
29

  
30
&sv tilelist
31
&do w = 117 &to 119
32
  &do n = 42 &to 46
33
    &sv tilelist %tilelist%, %tiledir%\w%w%\n%n%\%vernum%\%name%\w%w%n%n%
34
  &end
35
&end
36

  
37
%outdir%\srtmv41_OR2 = merge(%tilelist%)
38

  
39
&sv tilelist
40
&do w = 119 &to 121
41
  &do n = 42 &to 46
42
    &sv tilelist %tilelist%, %tiledir%\w%w%\n%n%\%vernum%\%name%\w%w%n%n%
43
  &end
44
&end
45

  
46
%outdir%\srtmv41_OR3 = merge(%tilelist%)
47

  
48
&sv tilelist
49
&do w = 121 &to 123
50
  &do n = 42 &to 46
51
    &sv tilelist %tilelist%, %tiledir%\w%w%\n%n%\%vernum%\%name%\w%w%n%n%
52
  &end
53
&end
54

  
55
%outdir%\srtmv41_OR4 = merge(%tilelist%)
56

  
57
&sv tilelist
58
&do w = 123 &to 125
59
  &do n = 42 &to 46
60
    &sv tilelist %tilelist%, %tiledir%\w%w%\n%n%\%vernum%\%name%\w%w%n%n%
61
  &end
62
&end
63

  
64
%outdir%\srtmv41_OR5 = merge(%tilelist%)
65

  
66
%outdir%\srtmv41_OR = merge(srtmv41_OR1, srtmv41_OR2, srtmv41_OR3, srtmv41_OR4, srtmv41_OR5)
67

  
terrain/research/oregon/aml/unpacktiles.aml
1
/* look for all .asc files in input dir
2
/* load them and split into 1 degree tiles
3

  
4
&if %:program%_ eq ARC_ &then grid
5
&if %:program%_ ne GRID_ &then
6
&return This program must be run from ARC or GRID.
7

  
8
/*note the directory path
9
&sv indir I:\NCEAS\topo\incoming\srtmv41
10
&sv tiledir I:\NCEAS\topo\tiles
11
&sv name srtmv41
12
&sv vernum 1
13

  
14

  
15
&do x = 1 &to 72
16
  &if %x% > 9 &then &sv xn %x%; &else &sv xn 0%x%
17
  &do y = 1 &to 36
18
    &if %y% > 9 &then &sv yn %y%; &else &sv yn 0%y%
19
    &sv ascfile %indir%\srtm_%xn%_%yn%.asc
20
    &if [exists %ascfile% -file] &then
21
    &do
22
      &type Got %ascfile%
23
      
24
      /* import the ASCII file 
25
      &sv tmpgrd [scratchname -dir -full]
26
      /* &sv tmpgrd c:\workspace\xx00000 - was using for testing
27
      /* &type Using %tmpgrd% as temporary grid
28
      %tmpgrd% = asciigrid(%ascfile%)
29
      
30
      /* determine x (long) and y (lat) range
31
      &describe %tmpgrd%
32
      &sv xmin %grd$xmin%
33
      &sv ymin %grd$ymin%
34
      &sv xmax %xmin% + 5
35
      &sv ymax %ymin% + 5
36
      &sv cell %grd$dx%
37
      
38
      &type %xmin% %ymin% %xmax% %ymax%
39
      
40
      &do x = %xmin% &to %xmax%
41
        &if %x% < 0 &then &sv xtile w[round [abs %x%]]; &else &sv xtile e[round %x%]
42
        &sv x1 %x% + 1
43
        &do y = %ymin% &to %ymax%
44
          &if %y% < 0 &then &sv ytile s[round [abs %y%]]; &else &sv ytile n[round %y%]
45
          &sv y1 %y% + 1
46
          setwindow %x% %y% %x1% %y1%
47
          &type Tile %x% %y%
48
          show setwindow
49
          &sv tmptile [scratchname -dir -full]
50
          &type Create tile %xtile%%ytile%
51
          %tmptile% = %tmpgrd%
52
          &describe %tmptile%
53
          &if %grd$stdv% > 0 &then &do
54
            /* grid is not all nodata
55
            &sv dirname %tiledir%\%xtile%
56
            &if ^ [exists %dirname% -directory] &then &sys mkdir %dirname%
57
            &sv dirname %tiledir%\%xtile%\%ytile%
58
            &if ^ [exists %dirname% -directory] &then &sys mkdir %dirname%
59
            &sv dirname %tiledir%\%xtile%\%ytile%\%vernum%
60
            &if ^ [exists %dirname% -directory] &then &sys mkdir %dirname%
61
            &sv dirname %tiledir%\%xtile%\%ytile%\%vernum%\%name%
62
            &if ^ [exists %dirname% -directory] &then &sys mkdir %dirname%
63
            &sv gridname %dirname%\%xtile%%ytile%
64
            &if [exists %gridname% -grid] &then &do
65
              &type WARNING: did not expect to find %gridname%!
66
            &end
67
            &else &do
68
              copy %tmptile% %dirname%\%xtile%%ytile%
69
            &end
70
          &end
71
          kill %tmptile%
72
        &end
73
      &end
74
    
75
      kill %tmpgrd%
76
      
77
    &end
78
  &end 
79
&end
terrain/research/oregon/aml/unziptiles.py
1
import os, fnmatch, zipfile, datetime
2

  
3
outpath = '//I/NCEAS/topo/incoming/srtmv41'
4
inpath = '//I/NCEAS/SRTM_90m_ASCII_v4.1'
5
logname = outpath + '/unzip.log'
6
logfile = open(logname, 'a')
7
logfile.write('Start unziptiles.py at ' + str(datetime.datetime.today()) + '\n')
8

  
9
nprocessed = 0
10
nerrors = 0
11

  
12
try:
13
    
14
    for filename in os.listdir(inpath):
15
        fullname = inpath + '/' + filename
16
        if fnmatch.fnmatch(fullname, '*.zip'):
17
            print fullname
18
            try:
19
                zip = zipfile.ZipFile(fullname, 'r')
20
                for zipi in zip.infolist():
21
                    name = zipi.filename
22
                    if name != 'readme.txt':
23
                        outfilename = outpath + '/' + name
24
                        print outfilename
25
                        if os.path.exists(outfilename):
26
                            print 'done'
27
                        else:
28
                            print 'Process', outfilename
29
                            outfile = open(outfilename, 'w')
30
                            outfile.write(zip.read(name))
31
                            outfile.close()
32
                            nprocessed = nprocessed + 1
33
                zip.close()
34
            except Exception, e:
35
                print str(e)
36
                logfile.write(str(e) + '\n')
37
                nerrors = nerrors + 1
38
except Exception, e:
39
    print "Exception:", e.str()
40
    logfile.write(str(e) + '\n')
41

  
42
logfile.write('Processed ' + str(nprocessed) + '\n')
43
logfile.write('Errors: ' + str(nerrors) + '\n')
44
logfile.write('End unziptiles.py at ' + str(datetime.datetime.today()) + '\n')
45
logfile.close()
terrain/research/oregon/arcgis/v1/aggregate.aml
1
/* need to ensure that the aggregation boxes are consistent across the whole set of layers
2
/* so might need a setwindow here to enforce the correct location
3

  
4
/* Question about 1km Behrman version - should that be projected from 30" stats, or
5
/* should data be projected to Behrman and aggregated over 1km cell. Far from the equator
6
/* these will give quite different results
7

  
8
/* elevation - derive mean, min, max, std. dev, skew
9
elev_mean = aggregate(srtmv41_smth, 10, mean)
10
elev_min = aggregate(srtmv41_smth, 10, min)
11
elev_max = aggregate(srtmv41_smth, 10, max)
12
elev_range = elev_max - elev_min
13
/* stupid arc doesn't have a standard deviation function for aggregation
14
elev_sd = sqrt(aggregate(sqr(srtmv41_smth - elev_mean), 10, sum) / 100)
15

  
16

  
17
/* slope - just mean and standard deviation
18
slopedeg_mean = aggregate(slopedeg, 10, mean)
19
slopedeg_sd = sqrt(aggregate(sqr(slopdeg - slopedeg_mean), 10, sum) / 100)
20

  
21
/* wetness index - mean and standard deviation
22
/* twi not done yet
terrain/research/oregon/arcgis/v1/chunkproc.aml
1
/* Invoke another AML on a grid to produce a grid
2
/* Other AML takes arguments: gridname outgridname otherargs
3

  
4
&args targetaml gridname outgridname otherargs:REST
5

  
6

  
7
/* targetaml-limits.aml takes same arguments as target.aml (except for
8
/* output file) and sets maximum number of cells and overlap required
9
&run %targetaml%-limits %gridname% [unquote %otherargs%]
10

  
11
&describe %gridname%
12
&sv gridxmin = %grd$xmin%
13
&sv gridxmax = %grd$xmax%
14
&sv gridymin = %grd$ymin%
15
&sv gridymax = %grd$ymax%
16
&sv gridncols = %grd$ncols%
17
&sv gridnrows = %grd$nrows%
18
&sv cellsize = %grd$dx%
19

  
20
/****** TEMPORARY *******/
21
/* setcell %cellsize%
22
/**** END TEMPORARY *****/
23

  
24
&sv ncells = %grd$ncols% * %grd$nrows%
25
&type %ncells% cells in %gridname%
26

  
27
&if %ncells% <= %.maxcells% &then &do
28
  /* no need to do chunks, just invoke target AML
29
  &type Process as single chunk
30
  &run %targetaml% %gridname% %outgridname% [unquote %otherargs%]
31
  &return
32
&end
33

  
34
/* need to do chunks
35
&type Process in multiple chunks
36
/* &type X: %gridxmin% %gridxmax% (%gridncols%) 
37
/* &type Y: %gridymin% %gridymax% (%gridnrows%) 
38
/* &type %ncells% cells, %.maxcells% max, %.border% border
39

  
40
&sv nchunks = [truncate [calc %ncells% / %.maxcells%]] + 1
41
&type Need at least %nchunks% chunks
42
&sv chunkdim = [sqrt %.maxcells%] + 2 * %.border%
43

  
44
&if %gridncols% < %chunkdim% &then
45
  &do
46
    &sv colchunks = 1
47
    &sv rowchunks = %nchunks%
48
    &sv chunkncols = %gridncols%
49
    &sv chunknrows = [truncate [calc %gridnrows% / %rowchunks%]] + 1
50
  &end
51
&else &if %gridnrows% < %chunkdim% &then
52
  &do
53
    &sv rowchunks = 1
54
    &sv colchunks = %nchunks%
55
    &sv chunkncols = [truncate [calc %gridncols% / %colchunks%]] + 1
56
  &end
57
&else 
58
  &do
59
    &sv rowchunks = [truncate [calc %gridnrows% / %chunkdim%]] + 1
60
    &sv colchunks = [truncate [calc %gridncols% / %chunkdim%]] + 1
61
    &sv chunkncols = [truncate [calc %gridncols% / %colchunks%]] + 1
62
    &sv chunknrows = [truncate [calc %gridnrows% / %rowchunks%]] + 1
63
  &end
64

  
65

  
66
&type %colchunks% colchunks, %rowchunks% rowchunks
67
&type Chunk size %chunkncols% cols by %chunknrows% rows
68

  
69
&sv qtrcell = %cellsize% / 4
70
&sv halfcell = %cellsize% / 2
71
&sv colist
72

  
73
&sv chunki = 1
74
&do &while %chunki% <= %colchunks%
75
  &sv chunkj = 1
76
  &sv colist_col
77
  &do &while %chunkj% <= %rowchunks%
78
    &type Chunk %chunki% %chunkj%
79

  
80
    &sv coxmin = %gridxmin% + ( %chunki% - 1 ) * %chunkncols% * %cellsize% - %qtrcell%
81
    &sv coxmax = %coxmin% + %chunkncols% * %cellsize% + %halfcell%
82
    &sv coymin = %gridymin% + ( %chunkj% - 1 ) * %chunknrows% * %cellsize% - %qtrcell%
83
    &sv coymax = %coymin% + %chunknrows% * %cellsize% + %halfcell%
84

  
85
    /* &type Output X: %coxmin% %coxmax%
86
    /* &type Output Y: %coymin% %coymax%
87

  
88
    &if %chunki% = 1 &then &sv chunkxmin = %coxmin%
89
    &else &sv chunkxmin = %coxmin% - %.border% * %cellsize%
90
    &if %chunki% = %colchunks% &then &sv chunkxmax = %coxmax%
91
    &else &sv chunkxmax = %coxmax% + %.border% * %cellsize%
92

  
93
    &if %chunkj% = 1 &then &sv chunkymin = %coymin%
94
    &else &sv chunkymin = %coymin% - %.border% * %cellsize%
95
    &if %chunkj% = %rowchunks% &then &sv chunkymax = %coymax%
96
    &else &sv chunkymax = %coymax% + %.border% * %cellsize%
97

  
98
    /* &type Chunk X: %chunkxmin% %chunkxmax%
99
    /* &type Chunk Y: %chunkymin% %chunkymax%
100

  
101
    /* clip input file to chunk (with borders)
102
    setwindow %chunkxmin% %chunkymin% %chunkxmax% %chunkymax% %gridname%
103
    &if [exists chunk -grid] &then kill chunk
104
    chunk = %gridname%  
105
    &if [exists co_tmp -grid] &then kill co_tmp
106
    &run %targetaml% chunk co_tmp [unquote %otherargs%]
107
    kill chunk
108

  
109
    /* clip output file to chunk (without borders)
110
    setwindow %coxmin% %coymin% %coxmax% %coymax% %gridname%
111
    &if [exists co_%chunki%_%chunkj% -grid] &then kill co_%chunki%_%chunkj%
112
    co_%chunki%_%chunkj% = co_tmp
113
    kill co_tmp
114

  
115
    &if %chunkj% = 1 &then &sv colist_col = co_%chunki%_%chunkj%
116
    &else &sv colist_col = %colist_col%, co_%chunki%_%chunkj%
117

  
118
    &sv chunkj = %chunkj% + 1
119
  &end
120
  setwindow maxof
121
  &if [exists co_%chunki% -grid] &then kill co_%chunki%
122
  co_%chunki% = merge(%colist_col%)
123
  kill (!%colist_col%!)
124
  &if %chunki% = 1 &then &sv colist = co_%chunki%
125
  &else &sv colist = %colist%, co_%chunki%
126
  &sv chunki = %chunki% + 1
127
&end
128

  
129
setwindow maxof
130
&if [exists %outgridname% -grid] &then kill %outgridname%
131
%outgridname% = merge(%colist%)
132
kill (!%colist%!)
terrain/research/oregon/arcgis/v1/gauss3
1
11 11
2
0.017 0.046 0.100 0.174 0.242 0.271 0.242 0.174 0.100 0.046 0.017 
3
0.046 0.124 0.271 0.472 0.659 0.736 0.659 0.472 0.271 0.124 0.046 
4
0.100 0.271 0.590 1.028 1.434 1.603 1.434 1.028 0.590 0.271 0.100 
5
0.174 0.472 1.028 1.791 2.500 2.793 2.500 1.791 1.028 0.472 0.174 
6
0.242 0.659 1.434 2.500 3.488 3.898 3.488 2.500 1.434 0.659 0.242 
7
0.271 0.736 1.603 2.793 3.898 4.356 3.898 2.793 1.603 0.736 0.271 
8
0.242 0.659 1.434 2.500 3.488 3.898 3.488 2.500 1.434 0.659 0.242 
9
0.174 0.472 1.028 1.791 2.500 2.793 2.500 1.791 1.028 0.472 0.174 
10
0.100 0.271 0.590 1.028 1.434 1.603 1.434 1.028 0.590 0.271 0.100 
11
0.046 0.124 0.271 0.472 0.659 0.736 0.659 0.472 0.271 0.124 0.046 
12
0.017 0.046 0.100 0.174 0.242 0.271 0.242 0.174 0.100 0.046 0.017 
terrain/research/oregon/arcgis/v1/layers.aml
1
/* using srtmv41 3x3 degree patch smoothed to srtmv41_smth
2

  
3
&describe srtmv41_smth
4
&sv cellsize %grd$dx% * 111000
5
dzdx = (srtmv41_smth(1,0) - srtmv41_smth(-1,0)) / (2 * %cellsize% * cos($$ymap / deg))
6
dzdy = (srtmv41_smth(0,-1) - srtmv41_smth(0,1)) / (2 * %cellsize%)
7
slope = sqrt(sqr(dzdx) + sqr(dzdy))
8
slopedeg = atan(slope) * deg
9
/* use scaling factor that is average of x and y scaling factors, 0.707 and 1 ~= 0.85
10
/* and 0.85 / 111000 ~ 0.0000107
11
arcslope = slope(srtmv41_smth, 0.0000107, degree)
12
hillshade = hillshade(srtmv41_smth, 300, 30, shade, 0.00001)
13

  
14
aspect1 = atan2(0 - dzdy, 0 - dzdx) * deg
15
aspect = con(aspect1 > 90, 450 - aspect1, 90 - aspect1)
16
kill aspect1
17

  
18
/*use elevation 
19
flowdir = flowdirection(srtmv41_smth)
20

  
21
/*cell area to account for latitudinal area effects, smallest area near pole
22
setwindow srtmv41_smth
23
setcell srtmv41_smth 
24
cellarea = sqr(%cellsize%) * cos($$ymap / deg)
25
flowacc = flowaccumulation(flowdir, cellarea)
26

  
27
/*account for sinks
28
/*change # defaulto z limit
29
/*caution fill is a command not function
30
/*fill srtmv41_smth srtmv41_fill sink # flowdir_fill
31

  
32
flowacc_fill = flowaccumulation(flowdir_fill, cellarea)
33

  
34
/*scatch_fill is specific catchment area in m 
35
scatch_fill = flowacc_fill / sqrt(cellarea) + sqrt(cellarea) / 2
36
/*setting the min slope to 0.1
37
adjslope = tan(max(slopedeg, 0.1) / deg)
38

  
39
twi_fill = ln(scatch_fill / adjslope)
terrain/research/oregon/arcgis/v1/mrvbf6g-a3.aml
1
/*   WRR paper is based on vd5r.aml. Prior history in vd5r.aml
2
/*
3
/*   mrvbf6a - vd5r modified to incorporate min (fuzzy and) instead of 
4
/*	multiplication when combining flatness and lowness. The transformation
5
/*	following combination of flatness and lowness is no longer used, so
6
/*	tvf and rvf layers are not computed, vf and rf are used directly.
7
/*
8
/*   mrvbf6b - mrvbf6a modified to use hard thresholds when recombining
9
/*	resolutions, rather than the smooth approach that resulted in
10
/*	values bleeding into lower resolution classes
11
/*	
12
/*	-2 changed threshold for converting pctl to low from 0.4 to 0.5
13
/*
14
/*   mrvbf6c - tried using standard deviation - not continued
15
/*
16
/*   mrvbf6d - another attempt to remove small hilltops from inclusion in
17
/*	valley bottom classes by including a fraction of the low indicator
18
/*	from the previous scale
19
/*
20
/*	-2 changed weighting of previous low/high from 0.3 to 0.5
21
/*
22
/*   mrvbf6f - (ignoring the 6e experiment)
23
/*	-1 Following results from Linda Gregory's transcription of the
24
/*	   method to Python in ArcGIS, removed the use of nibble to
25
/*	   extend the DEM beyond its original borders. Seems to be 
26
/*	   unnecessary.
27
/*	   Included extension of grids by one pixel at each step
28
/*
29
/*   mrvbf6g - all of 6f, plus std dev
30
/*         Use sd thresholds with _3 applying to level 3, _9 to level 4 etc 
31
/*	-2 Reduce standard deviation threshold by a factor of 2, so first
32
/*	   threshold is 4 instead of 8. This follows analysis of -1 that
33
/*	   shows that ridge tops are still being left in that should be
34
/*	   eliminated.
35
/*	-3 Reduce pctl radius from 6 cells to 3 at all steps. Radius is the
36
/*	   same for first two steps.
37
/*	-7 As for -3, but change carrying forward of low indicator to use 
38
/*	   raw pctl from previous scale, not low weight. This means that the
39
/*	   information only comes from one scale finer, not all finer scales.
40
/*	   This is to attempt to remedy the defects introduced by the -3 version
41
/*	   while retaining its ability to remove some problems.
42
/*	-10 As for -8, but pctl radius at 6 cells from step 2 onwards.
43
/*
44
/*	-a2 Added code to automatically detect geographic coords
45
/*	    Calculates sdthres from resolution, same as slopethres
46
/*	-a3 Incorporate mssd calculations directly in the AML, using 
47
/*	    correct methods developed in SRTM project; changed name of 
48
/*	    sd layers to match slope naming
49

  
50

  
51
&args dem
52
/* dem: name of dem to work from
53

  
54
&sv keep 1
55
/* higher keep values result in more intermediate results being kept
56

  
57
&describe %dem%
58
&sv mindim = [min %grd$ncols% %grd$nrows%]
59
&sv maxresmult = 1
60
&sv nsteps = 2
61
&do &while [calc %mindim% / %maxresmult%] > [calc 5 * 3]
62
  &sv maxresmult = [calc %maxresmult% * 3]
63
  &sv nsteps = [calc %nsteps% + 1]
64
&end
65
&type Minimum DEM dimension = %mindim%, max resolution = %maxresmult%
66
&type %nsteps% steps
67

  
68

  
69

  
70
&if [null %prj$units%] &then
71
  &return &error No horizontal units defined for DEM %dem%
72

  
73

  
74
&select %prj$units%
75
  &when METERS
76
    &do
77
      &type DEM horizontal units is metres, good
78
      &sv geographic = .false.
79
    &end
80

  
81
  &when DD
82
    &do
83
      &type DEM horizontal units is decimal degrees, scale
84
      &sv geographic = .true.
85
    &end
86

  
87
  &otherwise
88
      &return &error Unrecognised horizontal units for DEM %dem%: %prj$units%
89

  
90
&end
91

  
92
/* set up scaling factors for geographic data
93
&if %geographic% &then &do
94
  &type Calculating geographic scaling factors
95
  &sv xyfactor [calc 110000 * [cos [calc ( %grd$ymin% + %grd$ymax% ) / 2 / 57.2958] ]  ]
96
  &sv zfactor [calc 1 / %xyfactor% ]
97
  &end
98
&else &do
99
  &sv xyfactor 1
100
  &sv zfactor 1
101
&end
102

  
103
&sv baseres = %grd$dx%
104
&sv resmetres = [calc %baseres% * %xyfactor%]
105

  
106
&type DEM resolution = %resmetres% metres
107

  
108
&sv minvbf = 1
109
&sv vbfres = 4  /* maximum resolution for first vbf = 1
110
&sv slopethres = 64  /* 64% = 33 degrees, about steepest for any deposit
111
&sv sdthres = 0.375  /* developed with 1.5 at 25 m
112
&sv pctlradius = [calc %vbfres% * 3]
113
&do &while %vbfres% < %resmetres%
114
  &sv minvbf = [calc %minvbf% + 1]
115
  &sv vbfres = [calc %vbfres% * 3]
116
  &sv slopethres = [calc %slopethres% / 2]
117
  &sv sdthres = [calc %sdthres% * 2]
118
  &sv pctlradius = [calc %pctlradius% * 3]
119
&end
120
&type CHOICE setting pctlradius = 3 * dem resolution
121
&sv pctlradius = [calc %resmetres% * 3.02]
122
/* Modified 18/10/2006 to overcome numerical issues in pctl's cell inclusion calcs
123

  
124
&type TEMPORARY setting minvbf = 1
125
&sv minvbf = 1
126

  
127
&type VBF for base resolution = %minvbf%
128
&type Slope threshold = %slopethres%, percentile radius = %pctlradius%
129

  
130
setwindow %dem%
131
setcell minof
132

  
133
/* set weighting for pctl value from previous step
134
&sv prevpctlwt = 0.5
135

  
136

  
137
&sv l = 0
138
&sv v = %minvbf%
139

  
140
&sv l = 0
141
&sv l1 = 0
142
&sv res = %baseres%
143

  
144
&do &while %l% < %nsteps%
145
  &if %l% = 0 &then &sv l = 1
146
    &else &sv l = [calc %l% + 1]
147
  &type === Step %l% ====
148
  &if %l% > 2 &then &do
149
    &sv res = [calc %res% * 3]
150
    &sv resmetres = [calc %res% * %xyfactor%]
151
  &end
152
  &type Resolution = %res% (%resmetres% metres)
153
  &type Slope threshold = %slopethres%, pctl radius = %pctlradius%
154
  &type Std dev threshold = %sdthres%
155

  
156
  &type Checkpoint 1
157

  
158
  &if %l% > 2 &then &do
159
    &type Checkpoint 1.1
160
    /* create a smoothed version of the DEM from the previous resolution
161
    &if [exists dem_%l%_%l1% -grid] &then kill dem_%l%_%l1%
162
    &describe %dem%
163
    setwindow [calc %grd$xmin% - %res%] [calc %grd$ymin% - %res%] [calc %grd$xmax% + %res%] [calc %grd$ymax% + %res%]
164
    &if %l% = 3 &then &do
165
      dem_%l%_%l1% = focalsum(%dem%, weight, gauss3, data) / focalsum(con(%dem% > -999, 1, 0), weight, gauss3, data)
166
    &end
167
    &else &do
168
      dem_%l%_%l1% = focalsum(dem_%l1%_%l1%, weight, gauss3, data) / focalsum(con(dem_%l1%_%l1% > -999, 1, 0), weight, gauss3, data)
169
    &end
170

  
171
    &type Checkpoint 1.2
172
    /* calculate standard deviation
173
    &if [exists sd_%l% -grid] &then kill sd_%l%
174
    &if %l% = 3 &then &do
175
      sd_%l% = resample(blockstd(%dem%, rectangle, 3, 3), %res%, nearest)
176
    &end
177
    &else &do
178
      &if [exists sswg_%l% -grid] &then kill sswg_%l%
179
      &if [exists ssbg_%l% -grid] &then kill ssbg_%l%
180
      sswg_%l% = aggregate(pow(sd_%l1%, 2), 3, sum)
181
      ssbg_%l% = 9 * pow(resample(blockstd(dem_%l1%_%l1%, rectangle, 3, 3), %res%, nearest), 2)
182
      sd_%l% = sqrt((sswg_%l% + ssbg_%l%) / 9)
183
      &if %keep% <= 4 &then &do
184
        kill ssbg_%l%
185
        kill sswg_%l%
186
      &end
187
    &end
188

  
189
    &type Checkpoint 1.3
190
    &if %keep% <= 2 &then &do
191
      /* get rid of DEM from previous step
192
      &if %l1% > 2 &then kill dem_%l1%_%l1%
193
      &if %l1% > 2 &then kill sd_%l1%
194
    &end
195
  &end
196

  
197
  &type Checkpoint 2
198

  
199
  &if [exists s_%l%_1 -grid] &then kill s_%l%_1
200
  &if %l% = 1 &then &do
201
    /* first step, compute slope from base resolution
202
    &type Compute slope from DEM
203
    s_1_1 = slope(%dem%, %zfactor%, percentrise)
204
  &end 
205
  &else &if %l% = 2 &then &do
206
    /* second step, slope is same as from first step
207
    &if %keep% <= 4 &then rename s_1_1 s_2_1
208
    &else copy s_1_1 s_2_1
209
  &end
210
  &else &do
211
    /* compute slope from smoothed DEM
212
    &if [exists s_%l%_%l1% -grid] &then kill s_%l%_%l1%
213
    s_%l%_%l1% = slope(dem_%l%_%l1%, %zfactor%, percentrise)
214
    &if %l% > 2 &then &do
215
      /* resample back to base resolution
216
      s_%l%_1 = resample(s_%l%_%l1%, %baseres%, bilinear)
217
    &end
218
    &if %keep% <= 5 &then kill s_%l%_%l1%
219

  
220
    &if [exists dem_%l%_%l% -grid] &then kill dem_%l%_%l%
221
    dem_%l%_%l% = resample(dem_%l%_%l1%, %res%)
222
    &if %keep% <= 5 &then kill dem_%l%_%l1%
223
  &end
224
  &if [exists f_%l% -grid] &then kill f_%l%
225
  f_%l% = 1 / (1 + pow(s_%l%_1 / %slopethres%, 4))
226
  &if %keep% <= 4 &then &do
227
    /* get rid of s_%l%_1, except when l = 1 and we need it for s_2_1
... This diff was truncated because it exceeds the maximum size that can be displayed.

Also available in: Unified diff