forked from icenet-ai/icenet-pipeline
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun_daily.sh
executable file
·113 lines (88 loc) · 3.5 KB
/
run_daily.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
#!/usr/bin/env bash
set -o pipefail
set -eu
. ENVS
# FIXME: We're doing a daily run but uploading only the most recent?
# FIXME: the parameters for this script are a bit silly
DATASET="HEMI_10"
DAYS_BEHIND=0
END_DATE="yesterday"
FORECAST_NAME="_daily_forecast"
LOADER=""
RUN_SUFFIX="hemi"
UPLOAD=0
while getopts ":b:d:e:f:l:n:o:r:ux" opt; do
case "$opt" in
b) DAYS_BEHIND=$OPTARG ;;
d) DATASET="$OPTARG" ;;
e) END_DATE="$OPTARG" ;;
f) FILTER_FACTOR=$OPTARG ;;
l) LAG=$OPTARG ;;
n) FORECAST_NAME="_${OPTARG}" ;;
o) LOADER="${OPTARG}" ;;
r) RUN_SUFFIX="$OPTARG" ;;
u) UPLOAD=1 ;;
x) DO_NOT_EXECUTE=1 ;;
esac
done
shift $((OPTIND-1))
[[ "${1:-}" = "--" ]] && shift
COPY="${1:-}"
echo "Leftovers from getopt: $@"
if [[ "$END_DATE" != "yesterday" ]] \
&& ! [[ "$END_DATE" =~ ^[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}$ ]]; then
echo "$END_DATE if specified, needs to be in the form yyyy-mm-dd"
exit 1
else
echo "Using end date $END_DATE"
fi
ICENET_START=$( date --date="$END_DATE - `expr $LAG \+ $DAYS_BEHIND` days" +%F )
ICENET_END=`date --date="$END_DATE" +%F`
LOGDIR="logs/`date +%Y%m%d.%H%M`"
echo "Processing dates $ICENET_START to $ICENET_END"
for HEMI in south north; do
PROC_NAME="${HEMI}${FORECAST_NAME}"
DATASET_NAME="${DATASET/HEMI/$HEMI}"
LOADER="${LOADER:-$DATASET}"
LOADER_NAME="${LOADER/HEMI/$HEMI}"
mkdir $LOGDIR
echo "Removing previous daily predictions"
[ -d results/predict/$PROC_NAME ] && rm -rv results/predict/$PROC_NAME
[ -f results/predict/${PROC_NAME}.nc ] && rm -v results/predict/${PROC_NAME}.nc
echo "Removing previous ensemble"
[ -d ensemble/$PROC_NAME ] && rm -rv ensemble/$PROC_NAME
icenet_data_hres -v $HEMI $ICENET_START $ICENET_END \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.data.hres.log
icenet_process_metadata -v ${PROC_NAME} $HEMI \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.proc.meta.log
icenet_process_hres -v ${PROC_NAME} $HEMI \
-ts $ICENET_START -te $ICENET_END -l $LAG \
-r processed/${LOADER_NAME}/era5/${HEMI} \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.proc.hres.log
# NOTE THE -c - we only produce configuration here...
icenet_dataset_create -c -l $LAG -ob 1 -w 4 $PROC_NAME $HEMI \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.dataset.log
./loader_test_dates.sh $PROC_NAME | tail -n `expr $DAYS_BEHIND + 1` >predict.${PROC_NAME}.csv
echo rm -rv ensemble/${PROC_NAME}/
# NOTE THE -l - we use the loader directly
# FIXME: we assume the network name here is suffixed with 22 for BAS runs
# due to the reliance on node022 for GPU runs
./run_predict_ensemble.sh \
-b 1 -f ${FILTER_FACTOR} -p $PREP_SCRIPT -l -i ${DATASET_NAME}.22 \
${HEMI}_${RUN_SUFFIX} $PROC_NAME $PROC_NAME predict.${PROC_NAME}.csv \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.ensemble.predict.log
if [[ $UPLOAD == 1 ]]; then
icenet_upload_azure -o -v \
results/predict/${PROC_NAME}.nc $ICENET_END \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.upload_azure.log
fi
# while read -rs DT; do echo "Processing $DT";
# icenet_upload_local -v results/predict/north_daily_forecast.nc
# /data/twins/common/icenet $DT;
# done <predict.north_daily_forecast.csv
if [[ ! -z "$COPY" ]]; then
icenet_upload_local -v \
results/predict/${PROC_NAME}.nc $COPY $ICENET_END \
2>&1 | tee ${LOGDIR}/${PROC_NAME}.upload_local.log
fi
done