2 |
|
|
3 |
Notes on tags used in MITgcmUV |
Notes on tags used in MITgcmUV |
4 |
============================== |
============================== |
5 |
|
o gmredi: fix few bugs and restore parameter values (e.g., Small_Number=1.D-12) |
6 |
|
and scheme (e.g., Large_SlopeSqr=1.D+48) of checkpoint47f_post |
7 |
|
|
8 |
|
checkpoint48 |
9 |
|
checkpoint47h_post (duplicate tag for PH's c48 tag, in order to move c48) |
10 |
|
This will be a good checkpoint to plug into the ecco-branch. |
11 |
|
o few modif.'s to get latest version adjointed |
12 |
|
(mainly kick out code in ini_linear_phisurf) |
13 |
|
o modif's to run adjoint with exactConserv |
14 |
|
o case GM_BOLUS_ADVEC should be cleaned |
15 |
|
S/R gmredi_slope_psi should be cleaned |
16 |
|
o verification/carbon now has exactConserv=.TRUE. |
17 |
|
|
18 |
|
checkpoint47g_post |
19 |
|
o time-average AIM output: becomes independent from statvars time-average |
20 |
|
(can be used with #undef ALLOW_TIMEAVE) ; add new variables (e.g., RH) |
21 |
|
o After TAF bug fix: |
22 |
|
Tested adjoint of gmredi package. |
23 |
|
Tests were done with checkpoint47 rather than with latest |
24 |
|
checkpoint47f_post since the latter is broken for the adjoint |
25 |
|
verification/carbon/ contains both ADM and TLM gradient checks. |
26 |
|
Here they are, before they get changed/lost/stolen. |
27 |
|
Mostly modif.'s to fix numerical sensitivities. |
28 |
|
Gradient checks OK for |
29 |
|
- GM_taper_scheme: |
30 |
|
* clipping |
31 |
|
* ac02 |
32 |
|
* linear |
33 |
|
* glw91 |
34 |
|
* dm95 |
35 |
|
* ldd97 |
36 |
|
- GMREDI_OPTIONS: |
37 |
|
* GM_VISBECK_VARIABLE_K |
38 |
|
* GM_NON_UNITY_DIAGONAL |
39 |
|
* GM_EXTRA_DIAGONAL |
40 |
|
* GM_BOLUS_ADVEC |
41 |
|
in conjunction with data.gmredi parameters to be checked in |
42 |
|
in a few minutes under verification/carbon/code/ |
43 |
|
|
44 |
|
checkpoint47f_post |
45 |
|
Merging from release1_p10: |
46 |
|
o modifications for using pkg/exf with pkg/seaice |
47 |
|
- pkg/seaice CPP options SEAICE_EXTERNAL_FORCING |
48 |
|
and SEAICE_EXTERNAL_FLUXES |
49 |
|
- pkg/exf CPP options EXF_READ_EVAP and |
50 |
|
EXF_NO_BULK_COMPUTATIONS |
51 |
|
- usage examples are Experiments 8 and 9 in |
52 |
|
verification/lab_sea/README |
53 |
|
- verification/lab_sea default experiment now uses |
54 |
|
pkg/gmredi, pkg/kpp, pkg/seaice, and pkg/exf |
55 |
|
|
56 |
|
checkpoint47e_post |
57 |
|
o created a tag prior to creating a branch |
58 |
|
|
59 |
|
checkpoint47d_post |
60 |
|
o fixed bug in the oceanic pressure coordinates code: vertical viscosity |
61 |
|
at the bottom boundary had an erroneous half slip boundary condition |
62 |
|
o added bottom drag and no slip boundary condition capabilities to |
63 |
|
oceanic pressure coordinates code |
64 |
|
o added new verification experiment global_ocean_pressure, this experiment is |
65 |
|
also described in the tutorial section of the manual |
66 |
|
checkpoint47d_pre |
67 |
|
|
68 |
|
checkpoint47c_post |
69 |
|
o Added a verification experiment for a global cubed-sphere ocean run |
70 |
|
- verification/global_ocean.cubed32x32x30 |
71 |
|
- uses pkg/therm_seaice and pkg/bulk_forcing |
72 |
|
|
73 |
|
o allow to run AIM physics with SPEEDY input files (from Franco Molteni) |
74 |
|
o allow a more accurate definition of Ro_Surf (selectFindRoSurf=1) |
75 |
|
when using P-coordinate; only implemented for atmospheric config. |
76 |
|
o OCEANICP & realFreshWater: include P-E direct effect on wVel ; |
77 |
|
NOTES: requires option NONLIN_FRSURF to be "#define". |
78 |
|
o update advect_xz/results/output.txt (left from checkpoint44g_post) |
79 |
|
|
80 |
|
checkpoint47b_post |
81 |
|
Merging from release1_p9: |
82 |
|
o pkg/seaice |
83 |
|
- removed GOTO's and added taf directives |
84 |
|
- double precision constants to reduce the g77 (Linux) |
85 |
|
to F77 (SGI) differences reported in release1_p8 |
86 |
|
o tools/genmake |
87 |
|
- added SGI options |
88 |
|
o verification/testscript |
89 |
|
- updated to that of checkpoint47a_post |
90 |
|
o verification/global_ocean.90x40x15/input/eedata |
91 |
|
- modified for SGI f77 compatibility |
92 |
|
o verification/lab_sea |
93 |
|
- added description of sea-ice model |
94 |
|
- added missing matlab routines |
95 |
|
- added test of thermodynamics parallelization |
96 |
|
|
97 |
|
checkpoint47a_post |
98 |
|
o new pkg: aim_v23 |
99 |
|
= F. Molteni atmos.physics (SPEEDY, ver23) adapted to MITgcm. |
100 |
|
for now, keep the same surface forcing as before. |
101 |
|
- Part-Cell implemented into AIM; check that Heat & Water are conserved |
102 |
|
- aim.5l_cs: use new aim pkg (run 10yr & get better results than before) |
103 |
|
- aim.5l_LatLon & aim.5l_Equatorial_Channel are still using old aim pkg |
104 |
|
o add diagnostic of surface correction term in monitor output |
105 |
|
|
106 |
|
o bulk_force and therm_seaice |
107 |
|
- Two packages: bulk_force (Bulk forcing) |
108 |
|
and therm_seaice (thermodynamic_seaice) - adopted from LANL CICE.v2.0.2 |
109 |
|
- Earlier integration from Stephaine Dutkiewicz |
110 |
|
and Patrick Heimbach. |
111 |
|
- Two ifdef statements for compile time, |
112 |
|
ALLOW_THERM_SEAICE and ALLOW_BULK_FORCE |
113 |
|
|
114 |
|
checkpoint47 |
115 |
|
differentiable version of checkpoint46n_post |
116 |
|
o bug fix in quasihydrostaticterms |
117 |
|
o * "clean" adjoint code (in terms of extensive recomputations) |
118 |
|
can now be obtained for all GMREDI options (i.e. for |
119 |
|
- GM_VISBECK_VARIABLE_K |
120 |
|
- GM_NON_UNITY_DIAGONAL |
121 |
|
- GM_EXTRA_DIAGONAL |
122 |
|
- GM_BOLUS_ADVEC ) |
123 |
|
* However, wrong gradient check problem remains unsolved. |
124 |
|
* New CPP options have been introduced for different |
125 |
|
tapering schemes |
126 |
|
o external_fields_load now part of differentiation list |
127 |
|
o pressure needs multiple storing; |
128 |
|
would be nice to have store_pressure at beginning or |
129 |
|
end of forward_step, e.g. by having phiHyd global (5-dim.) |
130 |
|
(NB: pressure is needed for certain cases in find_rho, |
131 |
|
which is also invoked through convective_adjustment). |
132 |
|
o recomputations in find_rho for cases |
133 |
|
'JMD95'/'UNESCO' or 'MDJWF' are OK. |
134 |
|
o #define ATMOSPHERIC_LOADING should be differentiable |
135 |
|
o ini_forcing shifted to begining of initialise_varia |
136 |
|
o Incorporating QNVS line search routines into MITgcm |
137 |
|
(this is separate code, and therefore not under pkg) |
138 |
|
lsopt/, optim/ |
139 |
|
o Updated verification/carbon/ |
140 |
|
- #define GM_VISBECK_VARIABLE_K |
141 |
|
- GM_taper_scheme = 'ldd97' |
142 |
|
|
143 |
|
checkpoint46n_post |
144 |
|
Merging from release1_p8: |
145 |
|
o verification/natl_box: |
146 |
|
updating new external_fields_load routine |
147 |
|
o New package: pkg/seaice |
148 |
|
Sea ice model by D. Menemenlis (JPL) and Jinlun Zhang (Seattle). |
149 |
|
The sea-ice code is based on Hibler (1979-1980). |
150 |
|
Two sea-ice dynamic solvers, ADI and LSR, are included. |
151 |
|
In addition to computing prognostic sea-ice variables and diagnosing |
152 |
|
the forcing/external data fields that drive the ocean model, |
153 |
|
SEAICE_MODEL also sets theta to the freezing point under sea-ice. |
154 |
|
The implied surface heat flux is then stored in variable |
155 |
|
surfaceTendencyTice, which is needed by KPP package (kpp_calc.F and |
156 |
|
kpp_transport_t.F) to diagnose surface buoyancy fluxes and for the |
157 |
|
non-local transport term. Because this call precedes model |
158 |
|
thermodynamics, temperature under sea-ice may not be "exactly" at |
159 |
|
the freezing point by the time theta is dumped or time-averaged. |
160 |
|
N.B.: fairly large differences in accuracy occur across |
161 |
|
different platforms/compilers; comparison between |
162 |
|
g77 (Linux) and F77 (SGI Origin 2000/MIPSpro) |
163 |
|
generated output gives: |
164 |
|
T S U V |
165 |
|
C D M c m s m s m s m s |
166 |
|
n p a R g m m e . m m e . m m e . m m e . |
167 |
|
f n k u 2 i a a d i a a d i a a d i a a d |
168 |
|
g d e n d n x n . n x n . n x n . n x n . |
169 |
|
|
170 |
|
Y Y Y Y 5 5 7 7 7 8 10 9 6 6 6 6 7 5 7 5 7 FAIL lab_sea |
171 |
|
o GAD: |
172 |
|
- generated new common blocks to account for call of |
173 |
|
same gad routines with differing traceridentities |
174 |
|
(needed to modify tracerIdentity indices in GAD.h) |
175 |
|
- generated separate common blocks for case useCubedSphereExchange |
176 |
|
(Department of Futurology) |
177 |
|
- parameter lists to gmredi_?transport: added tracerIdentity |
178 |
|
- added new key indices to tamc.h |
179 |
|
o external_fields_load: |
180 |
|
- added this routine to TAF list |
181 |
|
- needed to make some common blocks global and additional storing |
182 |
|
along the same lines as exf package (checkpoint_lev?_directives.h) |
183 |
|
o exf: |
184 |
|
updated external forcing package |
185 |
|
- bug fixes carried over from ecco-branch |
186 |
|
(missing OBCS_OPTIONS.h in two routines) |
187 |
|
- enable easy to use "no forcing". |
188 |
|
- added exf I/O for atmospheric loading |
189 |
|
- added exf I/O for runoff data |
190 |
|
- transfered scaling between exf <-> MITgcm to exf namelist |
191 |
|
o Adding new verification experiment global_with_exf. |
192 |
|
This verification experiment is almost identical to the |
193 |
|
global_ocean.90x40x15 experiment, except that it uses |
194 |
|
the exf (and cal) package instead of the |
195 |
|
external_fields_load routine (cf README file). |
196 |
|
|
197 |
|
checkpoint46m_post |
198 |
|
o modified testscript to return -- when there are no lines of "%MON" output |
199 |
|
o added new flag "quasiHydrostatic" for QH mode |
200 |
|
and new routine quasihydrostaticterms() |
201 |
|
o added 2*Omega*Cos(phi)*W to u equations (non-hydrostatic Coriolis term) |
202 |
|
New routine: mom_u_coriolis_nh() |
203 |
|
o fixed sign of non-hydrostatic metric terms in u and v equations. |
204 |
|
Depend on correct sign of gravitySign. |
205 |
|
o added work.pc* to .cvsignore in aim directories using ifc |
206 |
|
o introduced flag for controllin non-hydrostatic metric terms |
207 |
|
o removed gravitySign from PARM04 |
208 |
|
o switched to g77/ifc from pgf77 in aim experiments |
209 |
|
|
210 |
|
checkpoint46l_post |
211 |
|
o made convective adjustment work with pressure coordinates: |
212 |
|
- changed the direction of k-loop in convective_adjustment.F for the |
213 |
|
case of pressure coordinates (OCEANICP,ATMOSPHERIC buoyancyRelation) |
214 |
|
- adjusted the reference pressure k-index in convective_adjustment.F |
215 |
|
- adjusted the convection condition in convect.F (in analogy to |
216 |
|
calc_ivdc.F) |
217 |
|
- convective_adjustment no longer computes anything on the halos |
218 |
|
- removed the warnings about negative salinity from find_rho.F and |
219 |
|
find_alpha.F; instead the new routine look_for_neg_salinity, called |
220 |
|
at the beginning of find_rho, find_alpha, and find_beta, does a |
221 |
|
check of the entire slice, if CPP-option |
222 |
|
CHECK_SALINITY_FOR_NEGATIVE_VALUES is defined |
223 |
|
checkpoint46l_pre |
224 |
|
|
225 |
|
checkpoint46k_post |
226 |
o fixed the verification/global_ocean.90x40x15 experiment: |
o fixed the verification/global_ocean.90x40x15 experiment: |
227 |
- new bathymetry (the world according to A., JMC, and M.) |
- new bathymetry (the world according to A., JMC, and M.) |
228 |
- new initial fields and forcing fields (*.bin files) |
- new initial fields and forcing fields (*.bin files) |