2 |
RM = rm -f |
RM = rm -f |
3 |
LOC = $(PWD) |
LOC = $(PWD) |
4 |
TAMC = tamc |
TAMC = tamc |
5 |
|
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 |
TAMCFLAGS = -adjoint -i4 -r4 |
TAMCFLAGS = -reverse -i4 -r4 |
11 |
|
TAFFLAGS = -reverse -i4 -r4 |
12 |
PKG = $(BASE)/pkg |
PKG = $(BASE)/pkg |
13 |
|
|
14 |
DIFF_FLAGS = -module the_main_loop \ |
DIFF_FLAGS = -toplevel the_main_loop \ |
15 |
-input ' xx_theta_dummy \ |
-input ' xx_theta_dummy \ |
16 |
xx_salt_dummy \ |
xx_salt_dummy \ |
17 |
|
xx_tr1_dummy \ |
18 |
xx_hflux_dummy \ |
xx_hflux_dummy \ |
19 |
xx_sflux_dummy \ |
xx_sflux_dummy \ |
20 |
xx_tauu_dummy \ |
xx_tauu_dummy \ |
23 |
xx_sst_dummy' \ |
xx_sst_dummy' \ |
24 |
-output 'fc' |
-output 'fc' |
25 |
|
|
26 |
TAMCFLAG = $(TAMCFLAGS) $(DIFF_FLAGS) -l list_uv -admark ad |
TAMCFLAG = $(TAMCFLAGS) $(DIFF_FLAGS) -admark ad |
27 |
|
|
28 |
|
TAFFLAG = $(TAFFLAGS) $(DIFF_FLAGS) -l list_uv -admark ad |
29 |
|
|
30 |
|
|
31 |
# Source files for the MITgcmUV |
# Source files for the MITgcmUV |
32 |
SRC_MODEL = $(PKG)/autodiff/read_write.flow \ |
SRC_MODEL = \ |
33 |
|
$(PKG)/autodiff/read_write.flow \ |
34 |
$(PKG)/autodiff/read_write_fld.flow \ |
$(PKG)/autodiff/read_write_fld.flow \ |
35 |
$(PKG)/autodiff/read_write_rec.flow \ |
$(PKG)/autodiff/read_write_rec.flow \ |
|
$(PKG)/autodiff/cg2d.flow \ |
|
|
$(PKG)/autodiff/initialisation.flow \ |
|
36 |
$(PKG)/autodiff/diags.flow \ |
$(PKG)/autodiff/diags.flow \ |
37 |
|
$(PKG)/autodiff/cg2d.flow \ |
38 |
|
$(PKG)/autodiff/debug.flow \ |
39 |
$(PKG)/autodiff/dummy_in_stepping.flow \ |
$(PKG)/autodiff/dummy_in_stepping.flow \ |
40 |
$(PKG)/autodiff/external_fields_load.flow \ |
$(PKG)/autodiff/external_fields_load.flow \ |
41 |
$(PKG)/autodiff/eesupp.flow \ |
$(PKG)/autodiff/eesupp.flow \ |
42 |
$(PKG)/autodiff/active_file.flow \ |
$(PKG)/autodiff/active_file.flow \ |
43 |
$(PKG)/autodiff/write_state.flow \ |
$(PKG)/autodiff/write_state.flow \ |
|
$(PKG)/autodiff/write_time_averages.flow\ |
|
44 |
$(PKG)/autodiff/exch_ad.flow \ |
$(PKG)/autodiff/exch_ad.flow \ |
45 |
|
$(PKG)/autodiff/exch_z_ad.flow \ |
46 |
|
$(PKG)/autodiff/exch_uv_ad.flow \ |
47 |
$(PKG)/autodiff/global_sum_ad.flow \ |
$(PKG)/autodiff/global_sum_ad.flow \ |
48 |
$(PKG)/autodiff/global_max_ad.flow \ |
$(PKG)/autodiff/global_max_ad.flow \ |
49 |
|
$(PKG)/autodiff/initialisation.flow \ |
50 |
$(PKG)/autodiff/mdsio.flow \ |
$(PKG)/autodiff/mdsio.flow \ |
51 |
|
$(PKG)/autodiff/monitor.flow \ |
52 |
$(PKG)/autodiff/checkpoint.flow \ |
$(PKG)/autodiff/checkpoint.flow \ |
53 |
$(PKG)/autodiff/print_message.flow \ |
$(PKG)/autodiff/print_message.flow \ |
54 |
$(PKG)/autodiff/open_copy_data_file.flow\ |
$(PKG)/autodiff/open_copy_data_file.flow\ |
55 |
$(PKG)/autodiff/timeave.flow \ |
$(PKG)/autodiff/timeave.flow \ |
56 |
\ |
\ |
|
$(SOURCE_CODE)/grad_sigma.f \ |
|
57 |
$(SOURCE_CODE)/calc_buoyancy.f \ |
$(SOURCE_CODE)/calc_buoyancy.f \ |
58 |
$(SOURCE_CODE)/calc_common_factors.f \ |
$(SOURCE_CODE)/calc_common_factors.f \ |
59 |
$(SOURCE_CODE)/calc_diffusivity.f \ |
$(SOURCE_CODE)/calc_diffusivity.f \ |
61 |
$(SOURCE_CODE)/calc_grad_phi_surf.f \ |
$(SOURCE_CODE)/calc_grad_phi_surf.f \ |
62 |
$(SOURCE_CODE)/calc_gs.f \ |
$(SOURCE_CODE)/calc_gs.f \ |
63 |
$(SOURCE_CODE)/calc_gt.f \ |
$(SOURCE_CODE)/calc_gt.f \ |
64 |
|
$(SOURCE_CODE)/calc_gtr1.f \ |
65 |
$(SOURCE_CODE)/calc_ivdc.f \ |
$(SOURCE_CODE)/calc_ivdc.f \ |
66 |
$(SOURCE_CODE)/calc_mom_rhs.f \ |
$(SOURCE_CODE)/calc_mom_rhs.f \ |
67 |
$(SOURCE_CODE)/calc_phi_hyd.f \ |
$(SOURCE_CODE)/calc_phi_hyd.f \ |
79 |
$(SOURCE_CODE)/external_forcing_surf.f \ |
$(SOURCE_CODE)/external_forcing_surf.f \ |
80 |
$(SOURCE_CODE)/find_alpha.f \ |
$(SOURCE_CODE)/find_alpha.f \ |
81 |
$(SOURCE_CODE)/find_rho.f \ |
$(SOURCE_CODE)/find_rho.f \ |
82 |
|
$(SOURCE_CODE)/forward_step.f \ |
83 |
$(SOURCE_CODE)/freeze.f \ |
$(SOURCE_CODE)/freeze.f \ |
84 |
$(SOURCE_CODE)/get_offline_fields.f \ |
$(SOURCE_CODE)/get_offline_fields.f \ |
85 |
|
$(SOURCE_CODE)/gad_biharm_x.f \ |
86 |
|
$(SOURCE_CODE)/gad_biharm_y.f \ |
87 |
|
$(SOURCE_CODE)/gad_c2_adv_r.f \ |
88 |
|
$(SOURCE_CODE)/gad_c2_adv_x.f \ |
89 |
|
$(SOURCE_CODE)/gad_c2_adv_y.f \ |
90 |
|
$(SOURCE_CODE)/gad_c4_adv_r.f \ |
91 |
|
$(SOURCE_CODE)/gad_c4_adv_x.f \ |
92 |
|
$(SOURCE_CODE)/gad_c4_adv_y.f \ |
93 |
|
$(SOURCE_CODE)/gad_calc_rhs.f \ |
94 |
|
$(SOURCE_CODE)/gad_del2.f \ |
95 |
|
$(SOURCE_CODE)/gad_diff_r.f \ |
96 |
|
$(SOURCE_CODE)/gad_diff_x.f \ |
97 |
|
$(SOURCE_CODE)/gad_diff_y.f \ |
98 |
|
$(SOURCE_CODE)/gad_fluxlimit_adv_r.f \ |
99 |
|
$(SOURCE_CODE)/gad_fluxlimit_adv_x.f \ |
100 |
|
$(SOURCE_CODE)/gad_fluxlimit_adv_y.f \ |
101 |
|
$(SOURCE_CODE)/gad_grad_x.f \ |
102 |
|
$(SOURCE_CODE)/gad_grad_y.f \ |
103 |
|
$(SOURCE_CODE)/gad_u3_adv_r.f \ |
104 |
|
$(SOURCE_CODE)/gad_u3_adv_x.f \ |
105 |
|
$(SOURCE_CODE)/gad_u3_adv_y.f \ |
106 |
|
$(SOURCE_CODE)/grad_sigma.f \ |
107 |
$(SOURCE_CODE)/impldiff.f \ |
$(SOURCE_CODE)/impldiff.f \ |
108 |
$(SOURCE_CODE)/ini_cartesian_grid.f \ |
$(SOURCE_CODE)/ini_cartesian_grid.f \ |
109 |
$(SOURCE_CODE)/ini_cg2d.f \ |
$(SOURCE_CODE)/ini_cg2d.f \ |
110 |
$(SOURCE_CODE)/ini_communication_patterns.f \ |
$(SOURCE_CODE)/ini_communication_patterns.f \ |
111 |
$(SOURCE_CODE)/ini_cori.f \ |
$(SOURCE_CODE)/ini_cori.f \ |
112 |
|
$(SOURCE_CODE)/ini_curvilinear_grid.f \ |
113 |
$(SOURCE_CODE)/ini_depths.f \ |
$(SOURCE_CODE)/ini_depths.f \ |
114 |
$(SOURCE_CODE)/ini_fields.f \ |
$(SOURCE_CODE)/ini_fields.f \ |
115 |
$(SOURCE_CODE)/ini_forcing.f \ |
$(SOURCE_CODE)/ini_forcing.f \ |
116 |
$(SOURCE_CODE)/ini_grid.f \ |
$(SOURCE_CODE)/ini_grid.f \ |
117 |
$(SOURCE_CODE)/ini_masks_etc.f \ |
$(SOURCE_CODE)/ini_masks_etc.f \ |
118 |
|
$(SOURCE_CODE)/ini_p_ground.f \ |
119 |
|
$(SOURCE_CODE)/ini_pnh.f \ |
120 |
$(SOURCE_CODE)/ini_procs.f \ |
$(SOURCE_CODE)/ini_procs.f \ |
121 |
$(SOURCE_CODE)/ini_psurf.f \ |
$(SOURCE_CODE)/ini_psurf.f \ |
122 |
$(SOURCE_CODE)/ini_salt.f \ |
$(SOURCE_CODE)/ini_salt.f \ |
123 |
$(SOURCE_CODE)/ini_spherical_polar_grid.f \ |
$(SOURCE_CODE)/ini_spherical_polar_grid.f \ |
124 |
$(SOURCE_CODE)/ini_theta.f \ |
$(SOURCE_CODE)/ini_theta.f \ |
125 |
$(SOURCE_CODE)/ini_uvel.f \ |
$(SOURCE_CODE)/ini_tr1.f \ |
126 |
|
$(SOURCE_CODE)/ini_dynvars.f \ |
127 |
|
$(SOURCE_CODE)/ini_vel.f \ |
128 |
$(SOURCE_CODE)/ini_vertical_grid.f \ |
$(SOURCE_CODE)/ini_vertical_grid.f \ |
|
$(SOURCE_CODE)/ini_vvel.f \ |
|
|
$(SOURCE_CODE)/ini_wvel.f \ |
|
129 |
$(SOURCE_CODE)/initialise_varia.f \ |
$(SOURCE_CODE)/initialise_varia.f \ |
130 |
$(SOURCE_CODE)/integrate_for_w.f \ |
$(SOURCE_CODE)/integrate_for_w.f \ |
131 |
$(SOURCE_CODE)/modeldata_example.f \ |
$(SOURCE_CODE)/modeldata_example.f \ |
132 |
$(SOURCE_CODE)/nml_filter.f \ |
$(SOURCE_CODE)/mom_calc_hfacz.f \ |
133 |
|
$(SOURCE_CODE)/mom_calc_ke.f \ |
134 |
|
$(SOURCE_CODE)/mom_cdscheme.f \ |
135 |
|
$(SOURCE_CODE)/mom_u_adv_uu.f \ |
136 |
|
$(SOURCE_CODE)/mom_u_adv_vu.f \ |
137 |
|
$(SOURCE_CODE)/mom_u_adv_wu.f \ |
138 |
|
$(SOURCE_CODE)/mom_u_bottomdrag.f \ |
139 |
|
$(SOURCE_CODE)/mom_u_del2u.f \ |
140 |
|
$(SOURCE_CODE)/mom_u_metric_nh.f \ |
141 |
|
$(SOURCE_CODE)/mom_u_metric_sphere.f \ |
142 |
|
$(SOURCE_CODE)/mom_u_rviscflux.f \ |
143 |
|
$(SOURCE_CODE)/mom_u_sidedrag.f \ |
144 |
|
$(SOURCE_CODE)/mom_u_xviscflux.f \ |
145 |
|
$(SOURCE_CODE)/mom_u_yviscflux.f \ |
146 |
|
$(SOURCE_CODE)/mom_v_adv_uv.f \ |
147 |
|
$(SOURCE_CODE)/mom_v_adv_vv.f \ |
148 |
|
$(SOURCE_CODE)/mom_v_adv_wv.f \ |
149 |
|
$(SOURCE_CODE)/mom_v_bottomdrag.f \ |
150 |
|
$(SOURCE_CODE)/mom_v_del2v.f \ |
151 |
|
$(SOURCE_CODE)/mom_v_metric_nh.f \ |
152 |
|
$(SOURCE_CODE)/mom_v_metric_sphere.f \ |
153 |
|
$(SOURCE_CODE)/mom_v_rviscflux.f \ |
154 |
|
$(SOURCE_CODE)/mom_v_sidedrag.f \ |
155 |
|
$(SOURCE_CODE)/mom_v_xviscflux.f \ |
156 |
|
$(SOURCE_CODE)/mom_v_yviscflux.f \ |
157 |
$(SOURCE_CODE)/packages_init_variables.f \ |
$(SOURCE_CODE)/packages_init_variables.f \ |
158 |
$(SOURCE_CODE)/plot_field.f \ |
$(SOURCE_CODE)/plot_field.f \ |
159 |
$(SOURCE_CODE)/solve_for_pressure.f \ |
$(SOURCE_CODE)/solve_for_pressure.f \ |
187 |
\ |
\ |
188 |
$(SOURCE_CODE)/cost_final.f \ |
$(SOURCE_CODE)/cost_final.f \ |
189 |
$(SOURCE_CODE)/cost_init.f \ |
$(SOURCE_CODE)/cost_init.f \ |
190 |
|
$(SOURCE_CODE)/cost_tile.f \ |
191 |
$(SOURCE_CODE)/cost_test.f \ |
$(SOURCE_CODE)/cost_test.f \ |
192 |
|
$(SOURCE_CODE)/cost_tracer.f \ |
193 |
\ |
\ |
194 |
|
|
195 |
|
|
199 |
|
|
200 |
adcode: |
adcode: |
201 |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code_ecco.f |
cd $(DEST) ; cat $(SRC_MODEL) >! tamc_code_ecco.f |
202 |
admodel: |
admodeltamc: |
203 |
cd $(DEST) ; $(TAMC) $(TAMCFLAG) tamc_code_ecco.f \ |
cd $(DEST) ; $(TAMC) $(TAMCFLAG) tamc_code_ecco.f \ |
204 |
>! tamc_code_ecco_ad.prot |
>! tamc_code_ecco_ad.prot |
205 |
|
|
206 |
|
admodeltaf: |
207 |
|
cd $(DEST) ; $(TAF) $(TAFFLAG) tamc_code_ecco.f |
208 |
|
|
209 |
adchange: |
adchange: |
210 |
${ADJOINT_SCRIPT}/adjoint_ecco_sed.com \ |
${ADJOINT_SCRIPT}/adjoint_ecco_sed.com \ |
211 |
>! tamc_code_ecco_sed_ad.f ; \ |
>! tamc_code_ecco_sed_ad.f ; \ |
215 |
adrestore: |
adrestore: |
216 |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
cp $(PKG)/autodiff/adjoint_model.F_template \ |
217 |
$(PKG)/autodiff/adjoint_model.F |
$(PKG)/autodiff/adjoint_model.F |
218 |
adall: adcode admodel |
|
219 |
|
adtamc: adcode admodeltamc |
220 |
|
|
221 |
|
adtaf: adcode admodeltaf |