-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcoreg_dsm2glas.sh
executable file
·97 lines (75 loc) · 3.11 KB
/
coreg_dsm2glas.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
#!/bin/bash
#
# Co-register a single HRSI DSM to ICESat-GLAS
#
# 3 steps
# - Masking input DEM to get control surfaces (dem_control.py)
# - Filtering GLAS over the control surfaces
# - PC aligning input DEM with filtered GLAS
source ~/anaconda3/bin/activate sibbork_pyproj #py2 #For Paul
#source ~/miniconda2/bin/activate py2 #My code
hostN=`/bin/hostname -s`
script_name=$(basename ${0})
pairname=${1}
main_dir=${2:-''}
dem_file=${3:-'out-DEM_1m.tif'}
glas=${4:-'/att/gpfsfs/briskfs01/ppl/pmontesa/userfs02/data/glas/circ_boreal/gla01-boreal50up-data.csv'}
ref_dem='/att/gpfsfs/briskfs01/ppl/pmontesa/userfs02/data/tandemx/TDM90/mos/TDM1_90m_circ_DEM.vrt'
elev_range="-15 15"
test_dir='/att/gpfsfs/briskfs01/ppl/pmontesa/tmp/test2'
HRSI_DSM_DIR='/att/gpfsfs/atrepo01/hrsi_dsm/v2'
if [ -z $main_dir ] ; then
main_dir=$test_dir
fi
workdir=$main_dir/$pairname
mkdir -p $workdir
dem=$workdir/${dem_file}
#Pubrepo files needed: out-DEM_*.tif, *.xml; Need to needed files to NOBACKUP
xml_fn_list=$(ls ${HRSI_DSM_DIR}/$pairname/*.xml)
ln -sf $xml_fn_list $test_dir/$pairname
for f in `ls ${HRSI_DSM_DIR}/$pairname/*{out-DEM_,ortho}*` ; do
ln -svf $f $test_dir/$pairname
ln -svf $f $main_dir/$pairname
done
mkdir -p $main_dir/logs_coreg2glas
logfile=$main_dir/logs_coreg2glas/${script_name%.*}_${hostN}_${pairname}.log
echo; echo "Script call:" | tee $logfile
echo '---------'
echo "${script_name} ${1} ${2} ${3}"| tee -a $logfile
echo "Main dir: $main_dir" | tee -a $logfile
dem_4control=${dem%1*}4m.tif
echo $dem_4control
echo; echo "Get static control DEM: masks input using TOA (dark & smooth) & DEM (roughness & slope) masked out of the 4m version of each DEM" ; echo | tee -a $logfile
cmd="dem_control.py $dem_4control -filt_param $ref_dem $elev_range"
echo $cmd ; echo | tee -a $logfile
eval $cmd | tee -a $logfile
echo; echo "Filter ICESat-GLAS (GLA14) using the *control.tif: this provides a set of GLAS over control surfaces only."
#using dem_4control, which expects a corresponding *_control.tif from dem_control.py
cmd="filter_glas_control.py $glas $dem_4control"
echo $cmd ; echo | tee -a $logfile
eval $cmd | tee -a $logfile
glas_file=$(basename $glas)
ref_glas_asp=${dem_4control%.*}_${glas_file%.*}_ref_asp.csv
echo; echo $ref_glas_asp
if [ -e "$ref_glas_asp" ] ; then
echo; echo "Run DEM co-registration to filtered ICESat-GLAS ..." ; echo
cmd="pc_align_wrapper_3dsi.sh ${ref_glas_asp} $dem"
echo $cmd ; echo | tee -a $logfile
eval $cmd | tee -a $logfile
else
echo; echo "No reference ICESat-GLAS points for co-reg. Exiting." ; echo
echo; date ; echo
exit 1
fi
align_glas_dsm=${dem%.*}_align_glas.tif
if [ -e "$workdir/${dem_file%.*}_align/${dem_file%.*}-trans_reference-DEM.tif" ] ; then
echo; echo "DEM co-reg to ICESat-GLAS successful" ; echo | tee -a $logfile
ln -sf $workdir/*align/*trans_reference-DEM.tif $align_glas_dsm
if [ $main_dir = $test_dir ] ; then
echo; echo "Hillshade the co-reg'd DEM" ; echo
hs_dem.sh $test_dir/$pairname/*align_glas.tif
fi
else
echo; echo "Failed to co-register DEM to ICESat-GLAS" ; echo | tee -a $logfile
fi
echo; date ; echo