forked from christophersanborn/Radiative3D
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdot-mltw.sh
executable file
·652 lines (595 loc) · 26 KB
/
dot-mltw.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
#!/bin/bash
##
## "DO-TEMPLATE"-script for a Radiative3D batch run:
##
## Creates a BATCH of derivative do-scripts in a top-level output
## directory. Individual resultant do-scripts will create their own
## subdirectories. Facilitates rapid scanning of parameter spaces.
##
## The executable part of this file ends at the 'exit' at around line 100
## (approx). After that are the "payloads," which include the template
## for the do-scripts and possibly some additional scripts to be
## transcribed to the output directory.
##
source scripts/do-fundamentals.sh
##
##
## One-liner description: (Keep this BRIEF.)
##
INTENT="Example halfspace simulation and test of MLTW method."
CAMPAIGN="" ## (e.g. "For AGU Poster Dec 2018" or some such.)
PopDefaults "template" ## Defined in do-fundamentals.sh
CheckBuildStatus ## ''
CreateBatchDirectory $@ ## ''
echo "Created batch output directory $outdir"
# Keys and values. If we use SpiralIndex (see do-fundamentals.sh) below then
# we construct do-scripts over the parameter space in a spiral outwards from a
# defined centerpoint. KeyXmid, min, and max must be defined to establish the
# initial center and included region of the spiral. Indices outside of the
# min-max ranges are skipped - (this allows non-square grids to be defined if
# desired; spiral will still work and output scripts will still be
# sequentially named). Aux values allow a second variable to be varied with
# the main key.
key1='%%QSINT%%' # Intrinsic Shear Q
values1=(62.5 88.4 125 176.8 250 500 1000 2000 4000 8000 16000 32000 64000)
key1mid=7; key1min=1; key1max=10;
key2='%%EPS%%' # Scat eps (Proxy for Scattering Q)
aux2='%%NUMPH%%' # Phonons per run (need more for low-scat to reach later
# time windows)
values2=(0.08 0.0565685 0.04 0.0282843 0.02 0.0141421 0.01 0.0070711 0.005)
auxval2=(300 300 400 400 400 400 500 600 600)
key2mid=5; key2min=1; key2max=9;
DOSH_PATTERN='do-$RUNID-$DIDX.sh'
DIDX=101 # Starting do-script index
limit=169 # How many to make (but may be further limited by min,max bounds)
# Make the individual do-files following spiral pattern from center:
idx=0; count=0;
echo "Generating do-scripts over keys $key1 and $key2..."
echo "(If you see grep output it means keys were missed.)"
while [ "$idx" -lt "$limit" ]; do
idxIJ=$(SpiralIndex "$idx" "$key1mid" "$key2mid")
idxI=$(echo "$idxIJ" | awk '{print $1}')
idxJ=$(echo "$idxIJ" | awk '{print $2}')
if [ "$idxI" -lt "$key1min" ] || [ "$idxI" -gt "$key1max" ] || \
[ "$idxJ" -lt "$key2min" ] || [ "$idxJ" -gt "$key2max" ]; then
((idx+=1))
continue # then skip to next index pair
fi
var1="${values1[idxI-1]}"
var2="${values2[idxJ-1]}"
auxvar2="${auxval2[idxJ-1]}"
out_do_sh="$doshdir"/$(eval echo ${DOSH_PATTERN})
cat "$TMPL_SRC" | sed "s/${key1}/${var1}/g" | \
sed "s/${key2}/${var2}/g" | \
sed "s/${aux2}/${auxvar2}/g" | \
sed "s/%%DIDX%%/${DIDX}/g" > "$out_do_sh"
chmod u+x "$out_do_sh"
grep -EHnT "%%[[:alnum:]]*%%" "$out_do_sh" # Reveal any missed vars
((DIDX+=1))
((count+=1))
((idx+=1))
done
((limit=count))
echo "...done. Generated $limit scripts."
# FUNCTION: make-do-sequential start=$1 skip=$2 max=$3
# 'skip' should be the number of cores to parallelize over.
# 'max' should be the max index to allow.
function make-do-sequential {
local SER_SH="$outdir/do-sequential-$1.sh"
local doshbase="$(basename $doshdir)"
local DIDX="$1"
local skip="$2"
echo '#!/bin/bash' > "$SER_SH"
echo '## Usage: do-sequential [min_index [max_index]]' >> "$SER_SH"
echo -n 'function inrange { ' >> "$SER_SH"
echo '[[ ( -z "$2" || "$1" -ge "$2" ) && ( -z "$3" || "$1" -le "$3" ) ]]; }' \
>> "$SER_SH"
while [ "$DIDX" -le "$3" ]; do
echo "inrange $DIDX "'$@'" && ./$doshbase/$(eval echo ${DOSH_PATTERN})" \
>> "$SER_SH"
((DIDX+=skip))
done
chmod u+x "$SER_SH"
}
# Make the do-sequential files:
ncores=7; ((DIDXmax=101+limit-1))
echo "Making do-sequential scripts for $ncores cores..."
make-do-sequential 101 $ncores $DIDXmax
make-do-sequential 102 $ncores $DIDXmax
make-do-sequential 103 $ncores $DIDXmax
make-do-sequential 104 $ncores $DIDXmax
make-do-sequential 105 $ncores $DIDXmax
make-do-sequential 106 $ncores $DIDXmax
make-do-sequential 107 $ncores $DIDXmax
cp scripts/do-parallel.sh "$outdir/"
echo "Done. Batch is ready to run."
exit
## (Do not edit/remove this comment block.)
#!/bin/bash
## ___TEMPLATE_START___
## "DO"-script for a Radiative3D run:
##
## Copy and edit this file to easily specify (and remember)
## parameters used for a particular run.
##
## If $1 is set, it is used as an extra identifier token in the
## output directory name.
##
## (Note: Do not edit line 3. It is used by subsequent scripts to
## identify this file as a "do script". (See wikify.sh.))
##
#source scripts/do-fundamentals.sh
source revision-files/do-fundamentals.sh
##
## This DO-SCRIPT sets up a run based on a HALFSPACE model with up to
## ONE interface layer.
##
## This do-script is part of a batch run and was AUTO GENERATED.
## The following lines help coordinate the individual runs
DIDX=%%DIDX%% # do-script index; used to generate output dir
##
SIMTARGET="waveform" # Choice: 'waveform' or 'video'. Affects
# defaults not otherwise specified.
MODIDX=40 # HALFSPACE # Model Index: Selects from custom coded models.
# 1: Lop Nor (base or moho depends on COMPARGS),
# 5: North Sea Crust Pinch model,
# 8: Crust Upthrust model
# 40: Halfspace model
event=eq # 'eq' or 'expl' - See case statement below for choices
EQISOFRAC=0.0 # Iso fraction for EQ event (choose from range [-1.0, 1.0])
# (Or choose as Iso Angle in range [-90, -1), (1, 90].)
##
## Epicenter and Station Locations
##
EPIXYZ=0,0,0 #
STAXYZ=183.85,183.85,0 # Station 'A', 260 km to the NE; Pg azimuth
STBXYZ=260,0,0 # Station 'B', 260 km to the East; Lg azimuth
STCXYZ=240.21,-99.5,0 # Station 'C', 260 km to the ESE; mixed Pg/Lg
FREQ=2.0 # Phonon frequency to model
NUMPHONS=%%NUMPH%% # Number of phonons to spray (Recommend: 140M)
RECTIME=200 # Recording duration of seismometers (seconds).
BINSIZE=0.50 # Seismometer time-bin size in seconds
GATHER=0.105,10.0 # Initial,Terminal gather radius, in kilometers.
R0=2.737 # Range of first receiver in array
NSEIS=48 # Number of receivers per linear array
CYLRAD=900 # Total (cylindrical) radius of model.
# (Phonons exceeding this radius from XY
# = (0,0), or this travel time from t=0,
# are abandoned.)
SCAT1=0.8,%%EPS%%,0.61,0.5,%%QSINT%% # Scat Args (nu,eps,a,kappa) and Q in top layer
SCAT2=0.8,%%EPS%%,0.61,0.5,%%QSINT%% # Scat Args (nu,eps,a,kappa) and Q in bot layer
VPVS1=6.40,3.63,2.83,-60 # Seismic attrs (Vp, Vs, rho, z-bottom) top layer
VPVS2=6.40,3.63,2.83,-400 # Seismic attrs (Vp, Vs, rho, z-bottom) bot layer
# (Note: Q's specified are Q_s values.
# Q_p is computed from assumption that
# Q_kappa is infinite.)
COMPARGS=$SCAT1,$SCAT2,$VPVS1,$VPVS2
#FLATTEN="--flatten" # If set to "--flatten", apply Earth-flattening
FLATTEN="" # transformation to depths and velocities.
# (Set to "" to disable.)
ADDITIONAL="" # Additional params. (Such as --ocsraw,
# or --earthrad=xxxx) Radii: Earth: 6371 km,
# Mars: 3389, Mercury: 2440, Earth's
# moon: 1737
#
# Event Parameters:
#
case "$event" in
expl) # Generic explosion
SOURCELOC=0,0,-5 # Origin, 5km deep
SOURCETYP=EXPL #
;;
eq) # Generic earthquake
SOURCELOC=0,0,-5 # Origin, 5km deep
SOURCETYP=SDR,0,90,0,$EQISOFRAC # Basic Strike-Slip
;;
*)
echo Event code not recognized.
exit
;;
esac
SEISORIG1=$EPIXYZ # Array locations:
SEISORIG2=$EPIXYZ #
SEISORIG3=$EPIXYZ #
SEISDEST1=$STAXYZ #
SEISDEST2=$STBXYZ #
SEISDEST3=$STCXYZ #
SEIS1=--seis-p2p=$SEISORIG1,$SEISDEST1,$R0,$GATHER,$NSEIS
SEIS2=--seis-p2p=$SEISORIG2,$SEISDEST2,$R0,$GATHER,$NSEIS
SEIS3=--seis-p2p=$SEISORIG3,$SEISDEST3,$R0,$GATHER,$NSEIS
## RUN THE SIMULATION:
##
## Set up output directory and run the sim:
##
PopDefaults $SIMTARGET ## Defined in do-fundamentals.sh
#CheckBuildStatus ## ''
CreateBatchSubDirectory $@ ## ''
RunSimulation ## ''
echo Begin Figure Generation: >> "$LOGFILE"
rwd=`pwd` # Switch to output directory - the rest of our work
cd "$outdir" # will be done there.
## (Do not edit/remove this comment block.)
#!/bin/bash
## ___FIG_GEN_START___
##
## # Note: this part of the do-script will
## GENERATE FIGURES AND GRAPHICS: # be carved off into 'do-figsonly.sh'
## # to facilitate re-running and/or
# customizing figure output after the
# initial run.
# Organize seisfiles
mkdir -p seisfiles # Stash seis files in a subdirectory (aesthetics)
mv seis_???.octv seisfiles/ 2> /dev/null || : # (suppress error msg and code)
# Text values for Wiki script:
cat > wikify.incl <<EOF
STA="PGX"
STB="LGX"
STC="PLG"
MODELCODE="HLF"
EOF
# Determine RunID from name of do-script: (for labeling figs)
SHFILE=RUNID
for file in *.sh; do
if grep -qx '## "DO"-script for a Radiative3D run:' "$file"
then # Catch ONLY file with R3D do marker
SHFILE="$file" # Also catches no more than one do- file
fi #
done
RUNID=${SHFILE%.sh}
RUNID=${RUNID#do-}
echo "Found RunID: $RUNID"
# Some octave/gnuplot set-up and platform-independence stuff:
alias octave="octave --no-window-system" # Prevents trouble on some systems.
export GNUTERM="dumb" # Ascii, but we don't disply so is OK.
shopt -s expand_aliases # Aliases in scripts... needs enabled.
reverser="tac" # Linux has tac (backwords cat)
[ "`uname`" == "Darwin" ] && reverser="tail -r" # But OS X has 'tail -r',...
revtail() { $reverser | tail $@ | $reverser; } # 'head' with neg line count
# does not work on OS X, so
# use revtail in its place.
if [ -x "`which pdfcrop 2> /dev/null`" ]; then # Check whether pdfcrop is
pdfcroptobb() { # $1=tmp-file $2=ouputfile # installed. If yes, then
pdfcrop --margins 0 "$1" "$2" >/dev/null # define pdfcroptobb (PDF-Crop-
rm "$1" # to-Bounding-Box), otherwise
} else # define a dummy function.
pdfcroptobb() { #
echo "pdfcrop not installed.";
mv "$1" "$2"; }
fi
# Make seismometer and model maps:
echo "Plotting model maps and cross-sections."
cat stdout.txt | \
grep -A 10000 "# R3D_GRID:" | \
grep -B 10000 "# END R3D_GRID" | \
revtail -n +2 | \
tail -n +9 | \
sed 's/\*\*\*/000/g' > griddump.txt
octave -qf <<"EOF"
## Seismometer Map:
seismap("seisfiles/seis_???.octv","out_mparams.octv",
[-50 274 -47 196], [45 95 118], {"PGX","LGX","PLG"});
legend("hide"); # (We're not using separate P and S gather anymore)
print("seismap.png","-r200"); # PNG version for wiki
print("tmp-seismap.pdf"); # PDF version for publication
## LOP to MAK:
modelplot("griddump.txt", [1 2], {"SRC","PGX"},
"out_mparams.octv",
"seisfiles/seis_%03d.octv",
[0,1:2:47]);
print("profile-LOP-MAK.png","-r200"); # PNG version for wiki
#delete(findall("tag","sourcemark")); # Remove source marker for publication
#delete(findall("tag","seismometer"));# Remove seismometer marks if desired
print("tmp-profile-LOP-MAK.pdf"); # PDF version for publication
## LOP to WUS:
modelplot("griddump.txt", [1 3], {"SRC","LGX"},
"out_mparams.octv",
"seisfiles/seis_%03d.octv",
[48,49:2:95]);
print("profile-LOP-WUS.png","-r200");
## WUS to MAK:
modelplot("griddump.txt", [3 2], {"LGX","PGX"},
"out_mparams.octv",
"",
[]);
print("profile-WUS-MAK.png","-r200");
EOF
pdfcroptobb "tmp-seismap.pdf" "seismap.pdf" # Crop to bb
pdfcroptobb "tmp-profile-LOP-MAK.pdf" "profile-LOP-MAK.pdf"
# Seismograms:
if [ "$1" != "noseis" ]; then
echo "Plotting envelopes..."
#for file in seisfiles/seis_{000,009,027,047,048,057,075,095,096,105,123,143}.octv ; do
for file in seisfiles/seis_{009,027,057,075,105,123}.octv ; do
ofile=`basename "${file%.octv}.png"` # PNG's for wiki
echo $ofile
octave -qf << EOF
seisplot("$file");
papertext(0.01, 0.00, "$RUNID", ## Plot RunID in lowerleft corner
"verticalalignment", "bottom", "horizontalalignment", "left",
"fontsize", 5, "fontweight", "demi", "color", [0 0 0]);
print("$ofile","-r200");
EOF
done
fi
for file in seisfiles/seis_{009,027,057,075,105,123}.octv ; do
ofile=`basename "${file%.octv}.pdf"` # PDF for publication
echo $ofile
octave -qf << EOF
seisplot("$file");
hRID = papertext(0.01, 0.00, "$RUNID", ## Plot RunID in lowerleft corner
"verticalalignment", "bottom", "horizontalalignment", "left",
"fontsize", 5, "fontweight", "demi", "color", [0 0 0]);
#set(hRID, "color", [1 1 1]); # Invisible but selectable in pdf version
#title(""); # Kill title, and Kill 1/4-inch extra margin it claims:
#set(gcf(),"paperposition", get(gcf(),"paperposition")-[0 0 0 0.25])
print("tmp-$ofile");
EOF
pdfcroptobb "tmp-$ofile" "$ofile" # Crop to bb
done
# Traveltime Curves (Template Function):
produce_ttcurves() { # $1: station code
# $2, $3: seis indices
# $4: caxis limit
# $5: caxis limit for 2nd plot (optional)
# Create links to reference curves. User manually must define directory links
# "other..." to activate. Enables energy comparisons to a baseline run. (Link
# "other" to the baseline, "other2" and "other3" to other test-case runs.)
ncbase="traveltime-$1-xyz-normcurve"
[ -d other ] && ln -sf "other/${ncbase}_smooth.octv" "${ncbase}_common.octv"
[ -d other ] && ln -sf "other/${ncbase}.octv" "${ncbase}_other.octv"
[ -d other2 ] && ln -sf "other2/${ncbase}.octv" "${ncbase}_other2.octv"
[ -d other3 ] && ln -sf "other3/${ncbase}.octv" "${ncbase}_other3.octv"
octave -qf <<EOF
AR = array("seisfiles/seis_%03d.octv",$2,$3);
NORMCURVE = arrayimage(AR, [1 1 1], 2.0, [0 200]);
save("traveltime-$1-xyz-normcurve.octv", "NORMCURVE");
NC2 = NORMCURVE;
NORMCURVE = normcurve_fitpowerlaw(NORMCURVE,4,48);
save("traveltime-$1-xyz-normcurve_smooth.octv", "NORMCURVE");
if (exist("traveltime-$1-xyz-normcurve_common.octv","file")==2)
NORMCURVE = load("traveltime-$1-xyz-normcurve_common.octv").NORMCURVE;
if (exist("traveltime-$1-xyz-normcurve_other.octv","file")==2)
NC1 = load("traveltime-$1-xyz-normcurve_other.octv").NORMCURVE;
normcurve_compare(NC1, NC2, NORMCURVE);
print("traveltime-$1-xyz-etracecompare.png", "-r160");
end
end # Loads a common curve if one has been created (requires
# user intervention). If _othercurve also exists,
# then plot a comparisson.
## VARIANT 1: Make one with norm relative to best-fit NORMCURVE:
arrayimage(AR, [1 1 1], 2.0, [0 200], NORMCURVE, $4);
annotate_array([6.40,3.63],{"Pg","Lg"},230); # (mark phase velocities)
hRID = papertext(0.03, 0.00, "$RUNID", ## Plot RunID in lowerleft corner
"verticalalignment", "bottom", "horizontalalignment", "left",
"fontsize", 5, "fontweight", "demi");
print("traveltime-$1-xyz-g2.0.png", "-r200");
## VARIANT 2: And make one where norm relative to local peak and average:
arrayimage(AR, [1 1 1], 2.0, [0 200], 0.5, ${5:-0});
annotate_array([6.40,3.63],{"Pg","Lg"},230); # (mark phase velocities)
hRID = papertext(0.03, 0.00, "$RUNID", ## Plot RunID in lowerleft corner
"verticalalignment", "bottom", "horizontalalignment", "left",
"fontsize", 5, "fontweight", "demi");
set(findobj("tag", "colorbar"), "yticklabel", []); # kill colorbar labels
set(findobj("tag", "colorbar"), "ytick", []); # kill clrbar ticks too
# (Some versions octave broken and need to kill ticks too to kill labels.)
print("traveltime-$1-xyz-g2.0-nr.png", "-r200"); # PNG version
#set(hRID, "color", [1 1 1]); # Invisible but selectable in pdf version
#set(findobj("tag", "OLCapt3"), "color", [1 1 1]); # Same for NR label
newstr=get(findobj("tag", "OLCapt2"), "string");
newstr=sprintf("%s\n%s","Channel: Ex+Ey+Ez",newstr); # Add to OL2 label
set(findobj("tag", "OLCapt2"), "string", newstr);
#title(""); # Kill title
print("tmp-traveltime-$1-xyz-g2.0-nr.pdf"); # PDF version
EOF
pdfcroptobb "tmp-traveltime-$1-xyz-g2.0-nr.pdf" \
"traveltime-$1-xyz-g2.0-nr.pdf" # Crop to bb
}
# TT Curves:
produce_ttcurves PGX 0 47 8 0 # Station LGX
produce_ttcurves LGX 48 95 8 0 # Station PGX
produce_ttcurves PLG 96 143 8 0 # Station PLG
# Lapse Time Curves (Template Function):
produce_lapsecurves() { # $1: filename tag (eg station code if relevant)
# $2, $3: seis indices
# $4, $5: lapse times (default 0, 30)
phaseedge="[3.63, 0]"
axesxyz="[1,1,1]"
axestxt="xyz"
geospread=2
LT1="${4:-0}"
LT2="${5:-30}"
QIntS="$(grep -A 10 '# R3D_GRID:' stdout.txt | grep '^ 0 0 0' | awk '{ print $11 }')"
QScatS="$(grep -A 6 '# BEGIN SCATTERER DUMP:' stdout.txt | grep -m 1 '^ ' | awk '{ print $5 * $9 }')"
echo "$QScatS $QIntS" > QScatIntS.txt
octave -qf <<EOF
AR1 = array("seisfiles/seis_%03d.octv",$2,$3);
ARs = {AR1}; nAR = 1;
QScatInt = {load("QScatIntS.txt")};
otherdirs = {"other"};
for (i=1:25); otherdirs{end+1} = sprintf("other%d",i); end
for (i=1:length(otherdirs))
if (exist(otherdirs{i},"dir")==7)
filepattern = sprintf("%s%s",otherdirs{i},"/seisfiles/seis_%03d.octv");
AR = array(filepattern,$2,$3);
ARs{end+1} = AR; nAR += 1;
QScatInt{end+1} = load(sprintf("%s/QScatIntS.txt",otherdirs{i}));
end
end
LineWidths = {7,6,5,4,3,2,1};
LineStyles = {"-", "-.", ":"};
LgEdge = $phaseedge; # [v, t0]
LWindow1 = $LT1 + [0 15];
LWindow2 = $LT2 + [0 70];
lapsetimebaseplot();
global linestyle;
R1R2data = [];
for i=1:nAR
linestyle.style = LineStyles{mod(i-1,length(LineStyles))+1};
linestyle.width = LineWidths{mod(i-1,length(LineWidths))+1};
data = lapsetimecurve(ARs{i}, QScatInt{i}, $axesxyz,
$geospread, LgEdge, LWindow1, LWindow2);
R1R2data = [R1R2data; data];
end
R1R2data
axis([0 250, 0.0001 10]);
titletxt = sprintf(
"Blue: Early window (%d to %d s); Green: Late window (%d to %d s)",
LWindow1(1), LWindow1(2), LWindow2(1), LWindow2(2)
);
title(titletxt, "fontweight", "bold");
hlgnd = findobj(gcf(),"type","axes","Tag","legend");
set(hlgnd, "fontweight", "bold", "FontSize", 8);
print("tmp-LapseTime-$1-$axestxt.pdf");
print("LapseTime-$1-$axestxt.png","-r200");
# Now plot the R1 R2 data:
fehlerR1R2plot(R1R2data);
print("tmp-FehlerR1R2-$1-$axestxt.pdf");
EOF
pdfcroptobb "tmp-LapseTime-$1-$axestxt.pdf" \
"LapseTime-$1-$axestxt.pdf" # Crop to bb
pdfcroptobb "tmp-FehlerR1R2-$1-$axestxt.pdf" \
"FehlerR1R2-$1-$axestxt.pdf" # Crop to bb
}
# Lapse Time curves:
produce_lapsecurves LGX 48 95 0 30 # Lg Lapse Time curve at LGX
## (Do not edit/remove this comment block.)
## ___FIG_GEN_END___
##
cd "$rwd"
echo End Figure Generation: `date +"%Y.%m.%d-%H:%M:%S"` >> "$LOGFILE"
echo '///'
echo "Figure generation complete. To re-run figures, run 'do-figsonly.sh' in"
echo "the output directory, which may be modified to customize figure output."
echo "Output has been placed in $outdir."
echo "Logfile contents:"
cat "$outdir"/logfile
ln -sr "$outdir" "$combodir/$DIDX-R3D"
[ -f "$outdir.inprogress" ] && rm "$outdir.inprogress"
## END
##
## ___TEMPLATE_END___
## (Do not edit/remove this comment block)
##
exit
## (Do not edit/remove this comment block.)
#!/bin/bash
## ___SUMMARY_FIGS_START___
## # Note: this part of the dot-script is carved
## GENERATE SUMMARY FIGURES: # off into 'do-summaryfigs.sh' to facili-
## # tate re-running and/or customizing figure
# output after the initial run. This one is
# for summary figs of batch runs.
# Determine RunID from name of do-script: (for labeling figs)
SHFILE=RUNID ## TODO: adapt for summary figs
for file in *.sh; do
if grep -qx '## "DO"-script for a Radiative3D run:' "$file"
then # Catch ONLY file with R3D do marker
SHFILE="$file" # Also catches no more than one do- file
fi #
done
RUNID=${SHFILE%.sh}
RUNID=${RUNID#do-}
echo "Found RunID: $RUNID"
# Some octave/gnuplot set-up and platform-independence stuff:
alias octave="octave --no-window-system" # Prevents trouble on some systems.
export GNUTERM="dumb" # Ascii, but we don't disply so is OK.
shopt -s expand_aliases # Aliases in scripts... needs enabled.
reverser="tac" # Linux has tac (backwords cat)
[ "`uname`" == "Darwin" ] && reverser="tail -r" # But OS X has 'tail -r',...
revtail() { $reverser | tail $@ | $reverser; } # 'head' with neg line count
# does not work on OS X, so
# use revtail in its place.
if [ -x "`which pdfcrop 2> /dev/null`" ]; then # Check whether pdfcrop is
pdfcroptobb() { # $1=tmp-file $2=ouputfile # installed. If yes, then
pdfcrop --margins 0 "$1" "$2" >/dev/null # define pdfcroptobb (PDF-Crop-
rm "$1" # to-Bounding-Box), otherwise
} else # define a dummy function.
pdfcroptobb() { #
echo "pdfcrop not installed.";
mv "$1" "$2"; }
fi
# Lapse Time Curves (Template Function):
produce_lapsecurves() { # $1: filename tag (eg station code if relevant)
# $2, $3: seis indices
# $4, $5: lapse times (default 0, 30)
phaseedge="[3.63, 0]"
axesxyz="[1,1,1]"
axestxt="xyz"
geospread=2
LT1="${4:-0}"
LT2="${5:-30}"
octave -qf <<EOF
ARs = {}; nAR = 0;
QScatInt = [];
B0 = [];
otherdirs = {};
for (i=101:221); otherdirs{end+1} = sprintf("datasrc/%03d-R3D",i); end
for (i=1:length(otherdirs))
if (exist(otherdirs{i},"dir")==7)
filepattern = sprintf("%s%s",otherdirs{i},"/seisfiles/seis_%03d.octv");
AR = array(filepattern,$2,$3);
ARs{end+1} = AR; nAR += 1;
QScatInt(end+1,:) = load(sprintf("%s/QScatIntS.txt",otherdirs{i}));
B0(end+1) = QScatInt(end,1)^-1 / (QScatInt(end,1)^-1 + QScatInt(end,2)^-1);
end
end
[dummy, srtB0] = sort(B0, "descend"); srtB0 = 1:length(B0);
ARs = ARs(srtB0);
QScatInt = QScatInt(srtB0,:);
LineWidths = {7,6,5,4,3,2,1};
LineWidths = num2cell(linspace(7,2,nAR));
LineStyles = {"-", "-.", ":"};
LgEdge = $phaseedge; # [v, t0]
LWindow1 = $LT1 + [0 15];
LWindow2 = $LT2 + [0 70];
lapsetimebaseplot();
global linestyle;
R1R2data = [];
for i=1:nAR
linestyle.style = LineStyles{mod(i-1,length(LineStyles))+1};
linestyle.width = LineWidths{mod(i-1,length(LineWidths))+1};
data = lapsetimecurve(ARs{i}, QScatInt(i,:), $axesxyz,
$geospread, LgEdge, LWindow1, LWindow2);
R1R2data = [R1R2data; data];
end
R1R2data
axis([0 250, 0.0001 60]);
titletxt = sprintf(
"Blue: Early window (%d to %d s); Green: Late window (%d to %d s)",
LWindow1(1), LWindow1(2), LWindow2(1), LWindow2(2)
);
title(titletxt, "fontweight", "bold");
hlgnd = findobj(gcf(),"type","axes","Tag","legend");
set(hlgnd, "fontweight", "bold", "FontSize", 8);
legend("off");
print("tmp-LapseTime-$1-$axestxt.pdf");
print("LapseTime-$1-$axestxt.png","-r200");
# Now plot the R1 R2 data:
fehlerR1R2plot(R1R2data, [7 4.5], true);
#axis([-1.5 4 -0.5 2.5]);
set(get(gca(),"title"),"string","R_2 vs. R_1 in XXXXX Model");
print("tmp-FehlerR1R2-$1-$axestxt.pdf");
# Now plot QsQi for reference: (Trick the R1R2 plot into plotting
# log Q values intead of R1R2)
QsQiData = [R1R2data(:,1:3), log10(R1R2data(:,2)), -log10(R1R2data(:,3))];
fehlerR1R2plot(QsQiData);
axis([0 4.5 -4 -1.5]);
set(get(gca(),"xlabel"),"string","log10[Q_{Scat}]");
set(get(gca(),"ylabel"),"string","log10[Q_{Int}^{-1}]");
set(get(gca(),"title"),"string","Intrinsic Attenuation vs. Q_{Scat}");
print("tmp-FehlerQsQi-$1-$axestxt.pdf");
EOF
pdfcroptobb "tmp-LapseTime-$1-$axestxt.pdf" \
"LapseTime-$1-$axestxt.pdf" # Crop to bb
pdfcroptobb "tmp-FehlerR1R2-$1-$axestxt.pdf" \
"FehlerR1R2-$1-$axestxt.pdf" # Crop to bb
pdfcroptobb "tmp-FehlerQsQi-$1-$axestxt.pdf" \
"FehlerQsQi-$1-$axestxt.pdf" # Crop to bb
}
# Lapse Time curves:
produce_lapsecurves LGX 48 95 0 30 # Lg Lapse Time curve at LGX
## END
##
## ___SUMMARY_FIGS_END___
## (Do not edit/remove this comment block)
##