7 |
SOURCE_CODE = ../bin |
SOURCE_CODE = ../bin |
8 |
ADJOINT_SCRIPT = ../adjoint |
ADJOINT_SCRIPT = ../adjoint |
9 |
BASE = .. |
BASE = .. |
10 |
TAMCFLAGS = -reverse -i4 -r4 |
ADTAMCFLAGS = -reverse -i4 -r4 -admark ad |
11 |
TAFFLAGS = -reverse -i4 -r4 |
ADTAFFLAGS = -reverse -i4 -r4 -admark ad -warn_step -flow taf_flow.log |
12 |
|
TLTAMCFLAGS = -forward -i4 -r4 -ftlmark g_ |
13 |
|
TLTAFFLAGS = -forward -i4 -r4 -ftlmark g_ -warn_step -flow taf_flow.log |
14 |
PKG = $(BASE)/pkg |
PKG = $(BASE)/pkg |
15 |
|
|
16 |
DIFF_FLAGS = -toplevel the_main_loop \ |
DIFF_FLAGS = -toplevel the_main_loop \ |
27 |
xx_kapgm_dummy' \ |
xx_kapgm_dummy' \ |
28 |
-output 'fc' |
-output 'fc' |
29 |
|
|
30 |
TAMCFLAG = $(TAMCFLAGS) $(DIFF_FLAGS) -admark ad |
ADTAMCFLAG = $(ADTAMCFLAGS) $(DIFF_FLAGS) |
31 |
|
ADTAFFLAG = $(ADTAFFLAGS) $(DIFF_FLAGS) |
|
TAFFLAG = $(TAFFLAGS) $(DIFF_FLAGS) -admark ad |
|
32 |
|
|
33 |
|
TLTAMCFLAG = $(TLTAMCFLAGS) $(DIFF_FLAGS) |
34 |
|
TLTAFFLAG = $(TLTAFFLAGS) $(DIFF_FLAGS) |
35 |
|
|
36 |
# Source files for the MITgcmUV |
# Source files for the MITgcmUV |
37 |
SRC_MODEL = \ |
SRC_MODEL = \ |
60 |
$(PKG)/autodiff/open_copy_data_file.flow\ |
$(PKG)/autodiff/open_copy_data_file.flow\ |
61 |
$(PKG)/autodiff/timeave.flow \ |
$(PKG)/autodiff/timeave.flow \ |
62 |
\ |
\ |
63 |
|
$(SOURCE_CODE)/adams_bashforth2.f \ |
64 |
$(SOURCE_CODE)/calc_buoyancy.f \ |
$(SOURCE_CODE)/calc_buoyancy.f \ |
65 |
$(SOURCE_CODE)/calc_common_factors.f \ |
$(SOURCE_CODE)/calc_common_factors.f \ |
66 |
$(SOURCE_CODE)/calc_diffusivity.f \ |
$(SOURCE_CODE)/calc_diffusivity.f \ |
70 |
$(SOURCE_CODE)/calc_gt.f \ |
$(SOURCE_CODE)/calc_gt.f \ |
71 |
$(SOURCE_CODE)/calc_gtr1.f \ |
$(SOURCE_CODE)/calc_gtr1.f \ |
72 |
$(SOURCE_CODE)/calc_ivdc.f \ |
$(SOURCE_CODE)/calc_ivdc.f \ |
|
$(SOURCE_CODE)/calc_mom_rhs.f \ |
|
73 |
$(SOURCE_CODE)/calc_phi_hyd.f \ |
$(SOURCE_CODE)/calc_phi_hyd.f \ |
74 |
$(SOURCE_CODE)/calc_viscosity.f \ |
$(SOURCE_CODE)/calc_viscosity.f \ |
75 |
$(SOURCE_CODE)/comm_stats.f \ |
$(SOURCE_CODE)/comm_stats.f \ |
88 |
$(SOURCE_CODE)/find_rho.f \ |
$(SOURCE_CODE)/find_rho.f \ |
89 |
$(SOURCE_CODE)/forward_step.f \ |
$(SOURCE_CODE)/forward_step.f \ |
90 |
$(SOURCE_CODE)/freeze.f \ |
$(SOURCE_CODE)/freeze.f \ |
91 |
$(SOURCE_CODE)/get_offline_fields.f \ |
$(SOURCE_CODE)/gad_advection.f \ |
92 |
$(SOURCE_CODE)/gad_biharm_x.f \ |
$(SOURCE_CODE)/gad_biharm_x.f \ |
93 |
$(SOURCE_CODE)/gad_biharm_y.f \ |
$(SOURCE_CODE)/gad_biharm_y.f \ |
94 |
$(SOURCE_CODE)/gad_c2_adv_r.f \ |
$(SOURCE_CODE)/gad_c2_adv_r.f \ |
102 |
$(SOURCE_CODE)/gad_diff_r.f \ |
$(SOURCE_CODE)/gad_diff_r.f \ |
103 |
$(SOURCE_CODE)/gad_diff_x.f \ |
$(SOURCE_CODE)/gad_diff_x.f \ |
104 |
$(SOURCE_CODE)/gad_diff_y.f \ |
$(SOURCE_CODE)/gad_diff_y.f \ |
105 |
|
$(SOURCE_CODE)/gad_dst3_adv_x.f \ |
106 |
|
$(SOURCE_CODE)/gad_dst3_adv_y.f \ |
107 |
|
$(SOURCE_CODE)/gad_dst3_adv_r.f \ |
108 |
|
$(SOURCE_CODE)/gad_dst3fl_adv_x.f \ |
109 |
|
$(SOURCE_CODE)/gad_dst3fl_adv_y.f \ |
110 |
|
$(SOURCE_CODE)/gad_dst3fl_adv_r.f \ |
111 |
$(SOURCE_CODE)/gad_fluxlimit_adv_r.f \ |
$(SOURCE_CODE)/gad_fluxlimit_adv_r.f \ |
112 |
$(SOURCE_CODE)/gad_fluxlimit_adv_x.f \ |
$(SOURCE_CODE)/gad_fluxlimit_adv_x.f \ |
113 |
$(SOURCE_CODE)/gad_fluxlimit_adv_y.f \ |
$(SOURCE_CODE)/gad_fluxlimit_adv_y.f \ |
144 |
$(SOURCE_CODE)/initialise_varia.f \ |
$(SOURCE_CODE)/initialise_varia.f \ |
145 |
$(SOURCE_CODE)/integrate_for_w.f \ |
$(SOURCE_CODE)/integrate_for_w.f \ |
146 |
$(SOURCE_CODE)/modeldata_example.f \ |
$(SOURCE_CODE)/modeldata_example.f \ |
147 |
|
$(SOURCE_CODE)/mom_fluxform.f \ |
148 |
|
$(SOURCE_CODE)/mom_hdissip.f \ |
149 |
|
$(SOURCE_CODE)/mom_vecinv.f \ |
150 |
$(SOURCE_CODE)/mom_calc_hfacz.f \ |
$(SOURCE_CODE)/mom_calc_hfacz.f \ |
151 |
$(SOURCE_CODE)/mom_calc_ke.f \ |
$(SOURCE_CODE)/mom_calc_ke.f \ |
152 |
|
$(SOURCE_CODE)/mom_calc_strain.f \ |
153 |
|
$(SOURCE_CODE)/mom_calc_tension.f \ |
154 |
$(SOURCE_CODE)/mom_cdscheme.f \ |
$(SOURCE_CODE)/mom_cdscheme.f \ |
155 |
$(SOURCE_CODE)/mom_u_adv_uu.f \ |
$(SOURCE_CODE)/mom_u_adv_uu.f \ |
156 |
$(SOURCE_CODE)/mom_u_adv_vu.f \ |
$(SOURCE_CODE)/mom_u_adv_vu.f \ |
174 |
$(SOURCE_CODE)/mom_v_sidedrag.f \ |
$(SOURCE_CODE)/mom_v_sidedrag.f \ |
175 |
$(SOURCE_CODE)/mom_v_xviscflux.f \ |
$(SOURCE_CODE)/mom_v_xviscflux.f \ |
176 |
$(SOURCE_CODE)/mom_v_yviscflux.f \ |
$(SOURCE_CODE)/mom_v_yviscflux.f \ |
177 |
|
$(SOURCE_CODE)/mom_vi_calc_absvort3.f \ |
178 |
|
$(SOURCE_CODE)/mom_vi_calc_hdiv.f \ |
179 |
|
$(SOURCE_CODE)/mom_vi_calc_ke.f \ |
180 |
|
$(SOURCE_CODE)/mom_vi_calc_relvort3.f \ |
181 |
|
$(SOURCE_CODE)/mom_vi_coriolis.f \ |
182 |
|
$(SOURCE_CODE)/mom_vi_del2uv.f \ |
183 |
|
$(SOURCE_CODE)/mom_vi_hdissip.f \ |
184 |
|
$(SOURCE_CODE)/mom_vi_u_coriolis.f \ |
185 |
|
$(SOURCE_CODE)/mom_vi_u_grad_ke.f \ |
186 |
|
$(SOURCE_CODE)/mom_vi_u_vertshear.f \ |
187 |
|
$(SOURCE_CODE)/mom_vi_v_coriolis.f \ |
188 |
|
$(SOURCE_CODE)/mom_vi_v_grad_ke.f \ |
189 |
|
$(SOURCE_CODE)/mom_vi_v_vertshear.f \ |
190 |
$(SOURCE_CODE)/packages_init_variables.f \ |
$(SOURCE_CODE)/packages_init_variables.f \ |
191 |
$(SOURCE_CODE)/plot_field.f \ |
$(SOURCE_CODE)/plot_field.f \ |
192 |
$(SOURCE_CODE)/solve_for_pressure.f \ |
$(SOURCE_CODE)/solve_for_pressure.f \ |
232 |
# rules |
# rules |
233 |
#-------------------------------------------------------- |
#-------------------------------------------------------- |
234 |
|
|
235 |
adcode: |
allcode: |
236 |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code_ecco.f |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code_ecco.f |
237 |
|
|
238 |
admodeltamc: |
admodeltamc: |
239 |
cd $(DEST) ; $(TAMC) $(TAMCFLAG) tamc_code_ecco.f \ |
cd $(DEST) ; $(TAMC) $(ADTAMCFLAG) tamc_code_ecco.f \ |
240 |
>! tamc_code_ecco_ad.prot |
>! tamc_code_ecco_ad.prot |
241 |
|
|
242 |
admodeltaf: |
admodeltaf: |
243 |
cd $(DEST) ; $(TAF) $(TAFFLAG) tamc_code_ecco.f |
cd $(DEST) ; $(TAF) $(ADTAFFLAG) tamc_code_ecco.f |
244 |
|
|
245 |
|
tlmodeltamc: |
246 |
|
cd $(DEST) ; $(TAMC) $(TLTAMCFLAG) tamc_code_ecco.f \ |
247 |
|
>! tamc_code_ecco_tl.prot |
248 |
|
|
249 |
|
tlmodeltaf: |
250 |
|
cd $(DEST) ; $(TAF) $(TLTAFFLAG) tamc_code_ecco.f |
251 |
|
|
252 |
adchange: |
adchange: |
253 |
${ADJOINT_SCRIPT}/adjoint_ecco_sed.com \ |
${ADJOINT_SCRIPT}/adjoint_ecco_sed.com \ |
259 |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
260 |
$(PKG)/autodiff/adjoint_model.F |
$(PKG)/autodiff/adjoint_model.F |
261 |
|
|
262 |
adtamc: adcode admodeltamc |
tltamc: allcode tlmodeltamc |
263 |
|
|
264 |
|
tltaf: allcode tlmodeltaf |
265 |
|
|
266 |
|
adtamc: adrestore allcode admodeltamc |
267 |
|
|
268 |
adtaf: adcode admodeltaf |
adtaf: adrestore allcode admodeltaf |