-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinterp_prepared_ebm
executable file
·74 lines (60 loc) · 3.04 KB
/
interp_prepared_ebm
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
#!/bin/bash
set -evx
input=$1
usurf=$2
isg=$3
atmgrid=$4
outfile=$5
startyear=1000
endyear=1049
pow=2
# isg='/work/bm0948/m300467/EBData/TOPO/ice5g_0k_5min.nc'
# isg='/work/bm0948/m300019/PISM/SPINUP/GL0049/pism_init_yx.nc'
toponame=usurf
workpath=$(pwd)
cdo='cdo -s -P 24 '
# INTERPOLATE
# split into vars, do 2d interpolation, split into years, do vert interpolation, combine all years, # (REMOVED) only take areas with non-neg surface elev in topo file,
# get target topograhpy > 0
if [ ! -f ${usurf/.nc/_usurf_yx.nc} ] ; then
offset=$(cdo -s -info -fldmin -ifthen -eqc,4 -selvar,mask ${usurf} -selvar,usurf ${usurf} |tail -n 1 |awk -F: '{print $5}' |sed 's/\s//g')
echo $offset
ncap2 -Ovs "usurf=usurf-(${offset})" ${usurf} ${usurf/.nc/_usurf.nc}
ncpdq -Oa time,y,x ${usurf/.nc/_usurf.nc} ${usurf/.nc/_usurf_yx.nc}
fi
usurf=${usurf/.nc/_usurf_yx.nc}
${cdo} -f ext -b 64L mul -selname,${toponame} ${usurf} -gec,0 -selname,${toponame} ${usurf} ${workpath}/fort.51
# root for interpolation
wrz=$(echo "1/${pow}" | bc -l)
${cdo} splitcode $input ${workpath}/var
# rm ${workpath}/Output_Zall.ext
for var in 600 601 602; do
#CDO zieht keine dritten Wurzeln aus negativen Zahlen daher spalte auf
${cdo} -gec,0 ${workpath}/var${var}.ext ${workpath}/mask
${cdo} -pow,${wrz} -mul ${workpath}/mask ${workpath}/var${var}.ext ${workpath}/oneINT
${cdo} -pow,${wrz} -mul -subc,1 ${workpath}/mask ${workpath}/var${var}.ext ${workpath}/twoINT
rm ${workpath}/mask
${cdo} -f ext -b 64L -add -pow,${pow} -remapbil,${isg} -setgrid,${atmgrid} ${workpath}/oneINT -mulc,-1 -pow,${pow} -remapbil,${isg} -setgrid,${atmgrid} ${workpath}/twoINT ${workpath}/INT
rm ${workpath}/oneINT ${workpath}/twoINT
for year in $(seq ${startyear} ${endyear}); do
${cdo} -selyear,$year ${workpath}/INT ${workpath}/fort.50
cd ${workpath}
/home/zmaw/m300467/vertint.x
cd -
${cdo} -f nc -setgrid,${isg} ${workpath}/fort.60 ${workpath}/${var}_${year}_Pow.nc
rm ${workpath}/fort.50 ${workpath}/fort.60
done
${cdo} -mergetime ${workpath}/${var}_????_Pow.nc ${workpath}/${var}all.nc
rm ${workpath}/${var}_????_Pow.nc ${workpath}/var${var}.ext ${workpath}/INT
# ${cdo} mul ${workpath}/${var}all.nc -gec,0 -selname,${toponame} ${isg} ${workpath}/${var}all.nc1
done
# merge vars
${cdo} -merge ${workpath}/601all.nc ${workpath}/602all.nc ${workpath}/600all.nc ${workpath}/Output_Int_flo.nc
rm ${workpath}/60?all.nc # ${workpath}/60?all.nc1
# time mean and correct output vars.
${cdo} timmean ${workpath}/Output_Int_flo.nc ${workpath}/Output_Int_mean_flo.nc
if [ -f ${outfile} ] ; then
mv ${outfile} ${outfile}.bak
fi
${cdo} -f nc -r -merge -setunit,'kg m-2 yr-1' -setmisstoc,-5000 -setname,climatic_mass_balance -mulc,365 -mulc,86400 -mulc,1000 -sub -selcode,601 ${workpath}/Output_Int_mean_flo.nc -selcode,602 ${workpath}/Output_Int_mean_flo.nc -setunit,'Kelvin' -setmisstoc,260 -setname,ice_surface_temp -selcode,600 ${workpath}/Output_Int_mean_flo.nc ${workpath}/${outfile}
exit 0