2 |
RM = rm -f |
RM = rm -f |
3 |
LOC = $(PWD) |
LOC = $(PWD) |
4 |
TAMC = tamc |
TAMC = tamc |
5 |
###TAMC = /data43/ralf/tamc/tamc |
TAF = ~fastopt/bin/taf |
|
TAF = taf |
|
|
###TAF = ~fastopt/bin/taf |
|
6 |
DEST = . |
DEST = . |
7 |
SOURCE_CODE = ../bin |
SOURCE_CODE = ../bin |
8 |
ADJOINT_SCRIPT = ../adjoint |
ADJOINT_SCRIPT = ../adjoint |
9 |
BASE = .. |
BASE = .. |
10 |
PKG = $(BASE)/pkg |
PKG = $(BASE)/pkg |
11 |
# |
ADTAMCFLAGS = -reverse -i4 -r4 -admark ad |
12 |
ADTAMCFLAGS = -reverse -admark ad -i4 -r4 |
ADTAFFLAGS = -reverse -i4 -r4 -admark ad |
13 |
ADTAFFLAGS = -reverse -admark ad -i4 -r4 \ |
TLTAMCFLAGS = -forward -i4 -r4 -ftlmark g_ |
14 |
-flow taf_flow.log -nonew_arg |
TLTAFFLAGS = -forward -i4 -r4 -ftlmark g_ |
|
FTLTAMCFLAGS = -forward -ftlmark g_ -i4 -r4 |
|
|
FTLTAFFLAGS = -forward -ftlmark g_ -i4 -r4 \ |
|
|
-flow taf_flow.log -nonew_arg |
|
|
SVDTAMCFLAGS = -reverse -forward -pure -i4 -r4 |
|
|
SVDTAFFLAGS = -reverse -forward -pure -i4 -r4 \ |
|
|
-flow taf_flow.log -nonew_arg |
|
|
# |
|
15 |
# -warn_step -flow taf_flow.log |
# -warn_step -flow taf_flow.log |
16 |
|
|
17 |
DIFF_FLAGS = -toplevel the_main_loop \ |
DIFF_FLAGS = -toplevel the_main_loop \ |
25 |
xx_sss_dummy \ |
xx_sss_dummy \ |
26 |
xx_sst_dummy \ |
xx_sst_dummy \ |
27 |
xx_diffkr_dummy \ |
xx_diffkr_dummy \ |
28 |
xx_kapgm_dummy \ |
xx_kapgm_dummy' \ |
|
xx_efluxy_dummy \ |
|
|
xx_efluxp_dummy' \ |
|
29 |
-output 'fc' |
-output 'fc' |
|
# |
|
|
# -output 'objf_vector' |
|
|
# -output 'fc' |
|
30 |
|
|
31 |
ADTAMCFLAG = $(ADTAMCFLAGS) $(DIFF_FLAGS) |
ADTAMCFLAG = $(ADTAMCFLAGS) $(DIFF_FLAGS) |
32 |
ADTAFFLAG = $(ADTAFFLAGS) $(DIFF_FLAGS) |
ADTAFFLAG = $(ADTAFFLAGS) $(DIFF_FLAGS) |
33 |
|
|
34 |
FTLTAMCFLAG = $(FTLTAMCFLAGS) $(DIFF_FLAGS) |
TLTAMCFLAG = $(TLTAMCFLAGS) $(DIFF_FLAGS) |
35 |
FTLTAFFLAG = $(FTLTAFFLAGS) $(DIFF_FLAGS) |
TLTAFFLAG = $(TLTAFFLAGS) $(DIFF_FLAGS) |
|
|
|
|
SVDTAMCFLAG = $(SVDTAMCFLAGS) $(DIFF_FLAGS) |
|
|
SVDTAFFLAG = $(SVDTAFFLAGS) $(DIFF_FLAGS) |
|
36 |
|
|
37 |
# Source files for the MITgcmUV |
# Source files for the MITgcmUV |
38 |
SRC_MODEL = \ |
SRC_MODEL = \ |
42 |
$(PKG)/autodiff/diags.flow \ |
$(PKG)/autodiff/diags.flow \ |
43 |
$(PKG)/autodiff/cg2d.flow \ |
$(PKG)/autodiff/cg2d.flow \ |
44 |
$(PKG)/autodiff/debug.flow \ |
$(PKG)/autodiff/debug.flow \ |
|
$(PKG)/autodiff/do_the_model_io.flow \ |
|
45 |
$(PKG)/autodiff/dummy_in_stepping.flow \ |
$(PKG)/autodiff/dummy_in_stepping.flow \ |
46 |
|
$(PKG)/autodiff/external_fields_load.flow \ |
47 |
$(PKG)/autodiff/eesupp.flow \ |
$(PKG)/autodiff/eesupp.flow \ |
48 |
$(PKG)/autodiff/active_file.flow \ |
$(PKG)/autodiff/active_file.flow \ |
49 |
$(PKG)/autodiff/write_state.flow \ |
$(PKG)/autodiff/write_state.flow \ |
82 |
$(SOURCE_CODE)/cycle_tracer.f \ |
$(SOURCE_CODE)/cycle_tracer.f \ |
83 |
$(SOURCE_CODE)/different_multiple.f \ |
$(SOURCE_CODE)/different_multiple.f \ |
84 |
$(SOURCE_CODE)/do_fields_blocking_exchanges.f \ |
$(SOURCE_CODE)/do_fields_blocking_exchanges.f \ |
85 |
|
$(SOURCE_CODE)/do_the_model_io.f \ |
86 |
$(SOURCE_CODE)/dynamics.f \ |
$(SOURCE_CODE)/dynamics.f \ |
|
$(SOURCE_CODE)/external_fields_load.f \ |
|
87 |
$(SOURCE_CODE)/external_forcing.f \ |
$(SOURCE_CODE)/external_forcing.f \ |
88 |
$(SOURCE_CODE)/external_forcing_surf.f \ |
$(SOURCE_CODE)/external_forcing_surf.f \ |
89 |
$(SOURCE_CODE)/find_alpha.f \ |
$(SOURCE_CODE)/find_alpha.f \ |
137 |
$(SOURCE_CODE)/ini_mixing.f \ |
$(SOURCE_CODE)/ini_mixing.f \ |
138 |
$(SOURCE_CODE)/ini_p_ground.f \ |
$(SOURCE_CODE)/ini_p_ground.f \ |
139 |
$(SOURCE_CODE)/ini_pnh.f \ |
$(SOURCE_CODE)/ini_pnh.f \ |
140 |
|
$(SOURCE_CODE)/ini_procs.f \ |
141 |
$(SOURCE_CODE)/ini_psurf.f \ |
$(SOURCE_CODE)/ini_psurf.f \ |
142 |
$(SOURCE_CODE)/ini_salt.f \ |
$(SOURCE_CODE)/ini_salt.f \ |
143 |
$(SOURCE_CODE)/ini_spherical_polar_grid.f \ |
$(SOURCE_CODE)/ini_spherical_polar_grid.f \ |
234 |
$(SOURCE_CODE)/cost_tile.f \ |
$(SOURCE_CODE)/cost_tile.f \ |
235 |
$(SOURCE_CODE)/cost_test.f \ |
$(SOURCE_CODE)/cost_test.f \ |
236 |
$(SOURCE_CODE)/cost_tracer.f \ |
$(SOURCE_CODE)/cost_tracer.f \ |
|
$(SOURCE_CODE)/cost_atlantic_heat.f \ |
|
|
$(SOURCE_CODE)/cost_vector.f \ |
|
237 |
\ |
\ |
238 |
|
$(SOURCE_CODE)/shap_filt_apply.f \ |
239 |
$(SOURCE_CODE)/shap_filt_apply_ts.f \ |
$(SOURCE_CODE)/shap_filt_apply_ts.f \ |
|
$(SOURCE_CODE)/shap_filt_apply_uv.f \ |
|
240 |
$(SOURCE_CODE)/shap_filt_tracer_s1.f \ |
$(SOURCE_CODE)/shap_filt_tracer_s1.f \ |
241 |
$(SOURCE_CODE)/shap_filt_tracer_s2.f \ |
$(SOURCE_CODE)/shap_filt_tracer_s2.f \ |
242 |
$(SOURCE_CODE)/shap_filt_tracer_s2g.f \ |
$(SOURCE_CODE)/shap_filt_tracer_s2g.f \ |
245 |
$(SOURCE_CODE)/shap_filt_uv_s2.f \ |
$(SOURCE_CODE)/shap_filt_uv_s2.f \ |
246 |
$(SOURCE_CODE)/shap_filt_uv_s2g.f \ |
$(SOURCE_CODE)/shap_filt_uv_s2g.f \ |
247 |
$(SOURCE_CODE)/shap_filt_uv_s4.f \ |
$(SOURCE_CODE)/shap_filt_uv_s4.f \ |
248 |
|
\ |
|
# $(SOURCE_CODE)/ini_ep.f \ |
|
|
# $(SOURCE_CODE)/calc_ep_forcing.f \ |
|
|
# $(SOURCE_CODE)/cost_entropy.f \ |
|
|
# $(SOURCE_CODE)/cost_t_misfit.f \ |
|
|
# $(SOURCE_CODE)/cost_eflux_regul.f \ |
|
|
# \ |
|
249 |
|
|
250 |
|
|
251 |
#-------------------------------------------------------- |
#-------------------------------------------------------- |
252 |
# rules |
# rules |
253 |
#-------------------------------------------------------- |
#-------------------------------------------------------- |
254 |
|
|
|
small_f: |
|
|
cd $(SOURCE_CODE); $(MAKE) depend; $(MAKE) small_f |
|
|
|
|
255 |
allcode: |
allcode: |
256 |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code.f |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code_ecco.f |
257 |
|
|
258 |
admodeltamc: |
admodeltamc: |
259 |
cd $(DEST) ; $(TAMC) $(ADTAMCFLAG) tamc_code.f \ |
cd $(DEST) ; $(TAMC) $(ADTAMCFLAG) tamc_code_ecco.f \ |
260 |
>! tamc_code_ad.prot |
>! tamc_code_ecco_ad.prot |
261 |
|
|
262 |
admodeltaf: |
admodeltaf: |
263 |
cd $(DEST) ; $(TAF) $(ADTAFFLAG) tamc_code.f |
cd $(DEST) ; $(TAF) $(ADTAFFLAG) tamc_code_ecco.f |
|
|
|
|
ftlmodeltamc: |
|
|
cd $(DEST) ; $(TAMC) $(FTLTAMCFLAG) tamc_code.f \ |
|
|
>! tamc_code_ftl.prot |
|
264 |
|
|
265 |
ftlmodeltaf: |
tlmodeltamc: |
266 |
cd $(DEST) ; $(TAF) $(FTLTAFFLAG) tamc_code.f |
cd $(DEST) ; $(TAMC) $(TLTAMCFLAG) tamc_code_ecco.f \ |
267 |
|
>! tamc_code_ecco_tl.prot |
268 |
|
|
269 |
svdmodeltaf: |
tlmodeltaf: |
270 |
cd $(DEST) ; $(TAF) $(SVDTAFFLAG) tamc_code.f |
cd $(DEST) ; $(TAF) $(TLTAFFLAG) tamc_code_ecco.f |
271 |
|
|
272 |
adchange: |
adchange: |
273 |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
${ADJOINT_SCRIPT}/adjoint_ecco_sed.com \ |
274 |
$(PKG)/autodiff/adjoint_model.F ; \ |
>! tamc_code_ecco_sed_ad.f ; \ |
|
${ADJOINT_SCRIPT}/adjoint_sed.com \ |
|
|
>! tamc_code_sed_ad.f ; \ |
|
275 |
cp $(PKG)/autodiff/adjoint_model.F \ |
cp $(PKG)/autodiff/adjoint_model.F \ |
276 |
$(PKG)/autodiff/adjoint_model.F_old ; \ |
$(PKG)/autodiff/adjoint_model.F_old ; \ |
277 |
cat tamc_code_sed_ad.f >> $(PKG)/autodiff/adjoint_model.F |
cat tamc_code_ecco_sed_ad.f >> $(PKG)/autodiff/adjoint_model.F |
|
|
|
|
ftlchange: |
|
|
cp $(PKG)/autodiff/tangentlinear_model.F_template \ |
|
|
$(PKG)/autodiff/tangentlinear_model.F ; \ |
|
|
cp $(PKG)/autodiff/tangentlinear_model.F \ |
|
|
$(PKG)/autodiff/tangentlinear_model.F_old ; \ |
|
|
cat tamc_code_ftl.f >> $(PKG)/autodiff/tangentlinear_model.F |
|
|
|
|
278 |
adrestore: |
adrestore: |
279 |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
280 |
$(PKG)/autodiff/adjoint_model.F |
$(PKG)/autodiff/adjoint_model.F |
281 |
|
|
282 |
ftlrestore: |
tltamc: allcode tlmodeltamc |
|
cp $(PKG)/autodiff/tangentlinear_model.F_template \ |
|
|
$(PKG)/autodiff/tangentlinear_model.F |
|
|
|
|
|
adtamc: adrestore ftlrestore small_f allcode admodeltamc |
|
|
|
|
|
adtaf: adrestore ftlrestore small_f allcode admodeltaf |
|
|
|
|
|
ftltamc: adrestore ftlrestore small_f allcode ftlmodeltamc |
|
283 |
|
|
284 |
ftltaf: adrestore ftlrestore small_f allcode ftlmodeltaf |
tltaf: allcode tlmodeltaf |
285 |
|
|
286 |
svdtaf: adrestore ftlrestore allcode svdmodeltaf |
adtamc: adrestore allcode admodeltamc |
287 |
|
|
288 |
|
adtaf: adrestore allcode admodeltaf |