/[MITgcm]/MITgcm/doc/tag-index
ViewVC logotype

Diff of /MITgcm/doc/tag-index

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.467 by adcroft, Mon Mar 28 15:48:14 2005 UTC revision 1.718 by jmc, Wed Aug 23 15:26:17 2006 UTC
# Line 1  Line 1 
1  $Header$  $Header$
2    $Name$
3    
4      Notes on tags used in MITgcmUV      Notes on tags used in MITgcmUV
5      ==============================      ==============================
6    
7    o simplify EXCH interface:
8     - change _XYZ_ interface to _3D_ subroutine (with 3rd dim in argument list)
9     - not often used EXCH S/R (exch_z, exch_uv_agrid): keep only the _3D_ version
10    o added the regrid package
11    o shelfice:
12     - add a simple boundary layer scheme to reduce noise
13     - fix the indexing in shelfice_u/v_drag so that there will be actually drag
14    
15    checkpoint58n_post
16    o fix globalArea multi-threaded calculation: need to apply GLOBAL_SUM to
17       local variable (not in common block).
18    o lot of small changes for multi-threaded. Most tests (using OMP & ifort) pass.
19      - still problems with pkgs: mnc, exp2, dic, cal, exf (and probably more);
20      - still BEGIN_MASTER/END_MASTER to remove around READ/WRITE_FLD S/R calls
21        to work with SingleCpuIO.
22    o add "_d 0" to real constant of pkg/cfc subroutines ;
23       update exp. cfc_exemple & tutorial_cfc_offline output files.
24    o multi-threading and IO:
25      - all threads call READ_FLD S/R (needed if using SingleCpuIO):
26        (no BEGIN_MASTER/ END_MASTER around the call, but inside MDSIO S/R.
27      - barrier before and after reading.
28      - stop if other than master is calling MDS_WRITELOCAL (if #undef IO_THREAD_SAFE)
29      - avoid using MDS_WRITELOCAL for LAND pkg output.
30      - new S/R AIM_WRITE_PHYS (replaces AIM_WRITE_LOCAL) to write AIM physics
31        common-block variables ; Allows multi-threading with master-thread IO.
32    o change default MAX_NO_THREADS from 32 to 4 ;
33      and stop cleanly when MAX_NO_THREADS is too small.
34    o add S/R BAR_CHECK to check multi-threaded barrier synchronization
35    
36    checkpoint58m_post
37    o add a Non-Hydroatatic test (with 3-D Coriolis, NHMTerms, biharmonic Visc.
38       and side-drag) on CS-grid : global_ocean.cs32x15.viscA4
39    o make "tutorial_global_oce_latlon" from standard "global_ocean.90x40x15" exp.
40       keep global_ocean.90x40x15 (for AD testing) with former secondary test
41       (".qshyd") as the main test (mv output.qshyd.txt to output.txt)
42    o CVS modules: update MITgcm_verif_basic; remove MITgcm_verif_ocean & _verif_atmos;
43        add MITgcm_tutorials (= code + all the tutorials)
44    o ecco, option to compute cost for total ssh (mean+anom)
45    o consistent with addition of ptracer and ssh in pkg/profiles
46    o profiles: adding ptracer and ssh
47    o testreport: change multi-test output-file name
48      (from output.txt.{name} to output.{name}.txt)
49    o profiles: now ok for mutli-tiles case
50    o seaice: add 4 parameters for different advection schemes for area,
51      (effective) seaice thickness, enthalphy, and snow height. Their default
52      is the standard parameter SEAICEadvScheme
53    o calc_gw:
54     - add cosFacU in zonal viscous flux (harmonic.visc.).
55     - put back side-drag (call new S/R MOM_W_SIDEDRAG) and output.txt.
56       of tutorial_plume_on_slope.
57    o obcs_calc.F : fix index Pb in OBSeta & OBNeta (Thanks to Gianmaria).
58    o calc_gw: true flux-form, account for horizontal grid spacing.
59      update rotating_tank results, but not plume_on_slope (affected at
60      truncation level, 11 digits).
61    
62    checkpoint58l_post
63    o calc_gw:
64     - take bi,bj loops outside calc_gw to fix Pb with local array KappaRU,V
65     - remove side-drag for now (need to fix it); update plume_on_slope results.
66     - fix for partial-cell & non-uniform dz; update plume_on_slope results.
67    o commit code to make SST/SSS weights spatially variable
68      (based on either variable in-situ or variable initial T/S weights)
69    o pkg/ecco:
70      * commit code to relax deviations of xx_theta, xx_salt to 5*sigma,
71        now based on horizontally varying weights wthetaLev, wsaltLev
72      * cost_averagesflags now returns year indices in addition to day, month
73      * sflux balance is performed on annual basis
74        (sflxumm, sfluxmm2, bal_sfluxmm)
75      * for SSH anomaly, separate more cleanly contrib from T/P, ERS, GFO,
76        including separate counting and multipliers
77    o pkg/rbcs
78      * add all necessary infrastructure for pkg/rbcs levN adjoint checkpointing
79    
80    checkpoint58k_post
81    o testreport:
82     - always build in dir. "build" (if not there, mkdir build instead of building
83       & running in input)
84     - run in dir run (if it exists), in build otherwise.
85     - call prepare_run (if input/prepare_run exists)
86     - run multi-threaded test (with new option: "-mth") if file input/eedata.mth exists.
87    o pkg/exf modifications to interpolation and rotation routines for more
88       reasonable treatment of North Pole singularity: for tracers North Pole
89       value is set to northernmost zonal-mean value, for zonal velocity it is
90       set to zero, and for meridional velocity it is set to northernmost value.
91    o pkg/exf/exf_check_range.F
92     - add tile index to diagnostics and move stop statement to the very
93       end of the routine.
94    o pkg/diagnostics: (diagnostics_main_init.F)
95      define title of isomorphic variables according to the current config.
96    o pkg/thsice with pkg/seaice dynamics:
97    - fix domain of computation (interior only, required for exf) and do exchanges
98    - seaice-dynamics forcing: add atmospheric and seaice loading to SSH gradient
99    o towards a standard way of dealing with multi-threading in MONITOR
100      and ${PKG}_MONITOR (all except ptracers_monitor) subroutines.
101    o Pass variable viscosities (vertical and horizontal, e.g., KPP or Leith)
102       to W momentum equation in nonhydrostatic and quasihydrostatic runs.  
103    o make exf_monitor & seaice_monitor independant of the main (dynamics) monitor.
104    o pkg/seaice: fix SEAICEuseEVPpickup parameter (put it in a commom block)
105    o generic_advdiff: DST advection S/R : use local copy of velocity to compute CFL
106       (problems ? with gradient check in bottom_ctrl_5x5 adjoint test)
107    o tracer advection:
108     - clean-up and simplify calc_common_factors.F
109     - make a local copy of velocity and pass it (as u,v,r_Trans) to DST tracer
110       advection subroutine (but still not used within DST advection S/R)
111    o rename pkg aim_ocn_coupler to atm_ocn_coupler (later on, will be used without aim)
112    
113    checkpoint58j_post
114    o new driver S/R: LOAD_FIELDS_DRIVER to load external forcing fields
115      from file (collects calls previously in FORWARD_STEP)
116    o move call to SEAICE_MODEL from FORWARD_STEP to DO_OCEANIC_PHYS
117    o adjoint store dir. adjusted accordingly
118    o genmake2
119      replace target "ad_taf" by $(EXE_AD) ; add $(EXE_AD) to the make CLEAN list.
120    
121    checkpoint58i_post
122    o pkg/seaice: add parameter that allows to scale/turn off effect of seaice
123      on wind stress (SEAICEstressFactor defaults to 1.)
124    o Total number of Timers is finite (<=40): comment out 2 non-essential one
125      in the_main_loop.F to avoid Pb (e.g., when running fizhi test)
126    o vector_invariant: fix highOrderVorticity(=4.th.Order) advection
127      on CS-grid: no longer loosing mass.
128    o exf & curvilinear-grid: no longer modify longitude xC & xG.
129    o pkg/ggl90: fix sloppy output and fix a bug
130    o pkg/seaice: added SEAICEuseEVPpickup parameter
131      - Set to false in order to start EVP solver with
132        non-EVP pickup files when using SEAICEuseEVP
133      - fix sign error in diffusion in seaice_calc_rhs
134    
135    checkpoint58h_post
136    * Modifications for bottom topography control
137      o replace hFacC by _hFacC at various places
138      o replace ALLOW_HFACC_CONTROL by ALLOW_DEPTH_CONTROL
139      o add non-self-adjoint cg2d_nsa
140      o update autodiff support routines
141      o re-initialise hfac after ctrl_depth_ini
142      o works for 5x5 box, doesnt work for global_ocean.90x40x15
143    * Adding verification for 5x5 box (4-layer) bottom topography control
144    
145    checkpoint58g_post
146    o pkg/diagnostics: implement "periodic averaging diagnostics" (e.g.,
147       used for mean seasonal cycle, mean diurnal cycle); add an example
148       in verification/global_ocean.cs32x15/input.thsice/data.diagnostics
149    o pkg/ggl90:
150      - add parameter (minimum surface kinetic energy)
151      - fix bug (avoiding division by zero)
152    o couple pkg/thsice to pkg/seaice:
153      - modify advection in seaice to accomodate new scalar fields to be advected
154      - only muliDimAdection scheme work with seaice/thsice
155      - mapping of thsice-variables to seaice-variables, back and forth
156      - does not break the verification experiments, but does not give the
157        desired results either
158    o pkg/seaice
159      - make (default) second order advection a bit less confusing?
160    
161    checkpoint58f_post
162    o couple pkg/thsice and pkg/exf (as a preparation for coupling pkg/thsice
163      to pkg/seaice):
164      - new routines thsice_map_exf and thsice_get_exf provide the interface
165      - add an additional formal parameter to thsice_solve4temp
166    o pkg/exf:
167      - add new fields wspeed, snowprecip (to be able to couple to thsice)
168      - correct Stefan-Boltzmann constant
169      - new parameter for longwave surface emittance
170      - separate some stuff from exf_bulkformulae into new routines  
171        exf_radiation, exf_wind
172      - add new parameters and constants: longwave emissivity for ocean, ice
173        and snow, evaporation parameters over ice
174      - decouple wind/stress computation from ALLOW_BULKFORMULA: always compute
175        either wind from stress or stress from wind
176    o pkg/thSIce:
177    - split thsice_step_fwd.F in 2 S/R: thsice_step_temp.F & thsice_step_fwd.F
178    - put i,j loops inside S/R: THSICE_ALBEDO, THSICE_SOLVE4TEMP, THSICE_EXTEND
179       and THSICE_CALC_THICKN
180    - for now, call to THSICE_GET_BULKF remains inside i,j loops.
181    - add CPP option: ALLOW_DBUG_THSICE and header file THSICE_DEBUG.h
182      to make debugging easier.
183    - affects results (@ truncation level) of global_ocean.cs32x15.thsice: update output
184    o pkg/bulk_force:
185      - clean-up comments and parameters ;
186      - add new Bulk-Formulae from Large and Yeager, 2004, NCAR/TN-460+STR ;
187    o fix bug in aim+thsice albedo: snow & ice thickness arguments were switched;
188      generate new output for test-experiment: aim.5l_cs.thSI
189    o results_ad : rename "output.txt_adm" to "output_adm.txt" and change
190      testreport accordingly
191    
192    checkpoint58e_post
193    o SEAICE_CGRID adjoint done
194    o R_STAR adjoint implemented.
195      * Seems to just work (based on global_ocean.90x40x15/code_ad_nlfs/ )
196      * need to sort out init. of h0facc, etc.
197    o Make pkg/profile fully independent of ecco,cost, etc. stuff
198      to be able to use it in pure forward.
199    
200    checkpoint58d_post
201    o upgrade simple test-experiment to tutorial example:
202     step.1: duplicate the experiment and (step.2) will remove the old copy.
203      tutorial_barotropic_gyre      <- copy of exp0     (R1:barotropic_gyre_in_a_box)
204      tutorial_baroclinic_gyre      <- copy of exp1     (R1:baroclinic_gyre_on_a_sphere)
205      tutorial_global_oce_latlon    <- empty for now    (R1:global_ocean_circulation)
206      tutorial_global_oce_biogeo    <- copy of dic_example
207      tutorial_deep_convection      <- almost like exp5 (R1:nonhydrostatic_deep_convection)
208      tutorial_plume_on_slope       <- copy of plume_on_slope
209      tutorial_tracer_adjsens       <- copy of carbon   (R1:tracer_adjoint_sensitivity)
210      tutorial_global_oce_optim     <- empty for now (David ?)
211      tutorial_global_oce_in_p      <- copy of global_ocean_pressure
212     some tutorials (R1) were already checked-in under tutorial_examples in release1_branch
213    o correct a sign problem in cost_scat.F
214    o obcs and ptracers: fix boundary conditions for advections schemes
215      with larger stencil
216    o thsice adjoint: start
217    o mom_vecinv: add ISOTROPIC_COS_SCALING flags to mom_vi_hdissip for
218      completeness
219    o mom_fluxform: fixing the mutual use of ISOTROPIC_COS_SCALING
220      and COSINEMETH_III, add comments in default CPP_OPTIONS.h
221    o ptracers adjoint:
222      * avoid extensive recomputatations
223      * fix missing re-init. of gptr (missed by TAF)
224    o obcs: add a flag (OBCSprintDiags, defaults is true) that allows
225      me to turn off the excessive output to STDOUT that this package produces
226    o move NH metric terms & 3.D Coriolis S/R to pkg/mom_common
227      and add those terms in Vector-Invariant formulation.
228    o in ctrl pkg, if ALLOW_CAL, use monthly mean controls
229      if the control period (xx_hfluxperiod etc) is 0
230    o in profiles pkg, clean routines and fix details
231    o in ecco pkg, reading ssh data:
232      fix problem in case the model does not start at iter0=0
233    o fix mnc-pickup/restart for ptracers
234    o new package prifiles:
235      code to compute profile-based cost by Gael Forget
236      (modifs in ecco, ctrl, autodiff)
237    o Benign bug fix in initialization (spotted by M. Mazloff) of
238      ctrl_set_globfld_xz.F ctrl_set_globfld_yz.F
239    
240    checkpoint58c_post
241    o adjoint: finish NLFS adjoint and provide reference output in
242      verification/global_ocean.90x40x15/results_ad_nlfs
243    o seaice: add an EVP solver following Hunke and Dukowicz (1997) and the
244      documentation of CICE. Turn on by defining SEAICE_ALLOW_EVP in
245      SEAICE_OPTIONS.h and SEAICEuseEVP=.true. in data.seaice. Works only
246      with SEAICE_CGRID defined.
247    o move calendarDumps from "data" to "data.cal" and clean-up the code
248      with a simple call to pkg/cal S/R: CAL_TIME2WRITE
249    o add useEXF & useCAL flags (for now, set in hard-coded way)
250    o add S/R to compute NH-metrics terms & Coriolis f' in vertical momentum
251      (were missing in NH mode, and wrong in quasihydrostatic mode).
252      waiting for Chris updated version of calc_gw to add those CALLs.
253    o fix bug in quasihydrostatic S/R ;
254      add a test for this option: global_ocean.90x40x15.qshyd
255    o new S/R "SET_PARMS": set parameters that might depend on the use of some pkgs.
256      (called from INITIALISE_FIXED, after INI_PARMS & PACKAGES_READPARAMS)
257    o add on/off flag useOffLine for package OFFLINE
258    o seaice:
259      - modify advection so that it works also on the C-grid
260      - extend loop ranges in seaice_lsr and seaice_dynsolver; fixes
261        problem in multi-tile runs with C-grid
262      - add flags for clipping ice velocities and/or masking solver forcing
263      - fix drag (ocean on ice) formulation and a bug that caused noise in the
264        C-grid solver
265      - added a few comments to seaice_diffusion.F
266      - separate C-grid and B-grid versions more cleanly (UVM and seaiceMaskU/V
267        are now exclusive)
268      - add a new ocean-ice stress coupling method (Hibler and Bryan, 1987) which
269        required re-ordering the code a little:
270       + make DAIRN global variable (defined in SEAICE)
271       + move computation of the viscosities eta and zeta into a new separate
272         routine (because I need to recompute them in seaice_ocean_stress.F)
273    
274    checkpoint58b_post
275    o AIM+thSIce: fix sign of Short-Wave through the Ice ;
276      update output.txt of exp. aim.5l_cs.thSI
277    o various mnc cleanups and improvements:
278      + shrink lookup tables by factor of ~4
279      + better error reporting when running out of lookup space
280      + able to handle longer path/file names (up to 500 chars)
281    o adjoint:
282      - Another overhaul of store dirs. for NLFS to eliminate  "hidden" recomputations.
283      - TBD: "hidden" mom_vecinv recomp. in dynamics
284    o change forcing_In_AB to affects both T,S forcing and Momentum forcing
285     (allow to differentiate between forcing components using new integer flags:
286      momForcingOutAB=1/0 & tracForcingOutAB=1/0)
287     and add new flag to put Dissipation tendency out of Adams-Bashforth.
288    o ecco
289      - enable trend removal from SSH anomaly obs.
290    o adjoint
291      - a fix for PmEpR when #undef EXACT_CONSERV
292      - fix of "hidden" recomp. in thermodynamics (no TAF warnings)
293      - try to fix "hidden" recomp. in forward_step for NLFS
294        (NLFS seems broken sometimes after I checked it in)
295    o seaice:
296     - add c-grid version of the dynamic solver:
297       + three new routines that are the c-grid substitute lsr, dynsolver
298         and ostres
299       + put a few fields that were local to dynsolver into global common
300         blocks, so that I can move the computation of stresses etc into
301         seaice_lsr (saves coding but may break the adjoint).
302     - replace more hardwired parameters by runtime parameters
303     - add ice masks that mask the rhs of the implicit solvers where there
304       is no ice (commented out in seaice_dynsolver, because i am not sure
305       if this works properly), eventually this should replace the clipping
306       of ice velocities in seaice_dynsolver to +/-40cm/s.
307    o remove the BUILD_INFO.h include from CPP_EEOPTIONS.h and explicitly
308      include it only where its needed
309    o move balancing of fluxes before the call of external_forcing_surf
310    o seaice:
311      - correct units of turning angles (now they are really in degrees)
312      - move computation of GWATX/Y out of main routine into dynsolver
313      - initialize GWATX/Y in seaice_init
314    o Apply mask on Fresh-Water flux (needed for SSH forcing).
315      update output.txt of exp. global_ocean_ebm & cpl_aim+ocn (affects cg2d residual)
316    o seaice: add runtime flags for turning angles (default to zero)
317    o Adding runtime parameter to exf/, ctrl/, to remove on-the-fly global mean
318      and trend from exf forcing and ctrl control adjustments
319    o fix variable aliasing in gad_calc_rhs that cannot be handled by TAF
320      (since checkpoint57x_post)
321    o change the default rotation period to 86164.s = the Earth rotation
322    o 1rst implementation of Implicit IGW using the 3-D solver (use3Dsolver=T)
323      and based on a reference stratification. Tested within hs94.cs-32x32x5.
324    o seaice advection: add code for choosing between the default (2nd order
325      central differences) and multiDim advection schemes provided by
326      pkg/generic_advdiff
327    o seaice:
328      - removed all references to SEAICE_GRID.h fields from
329        dynsolver, advect, diffus, lsr, without changing the results of lab_sea
330        (cubed-sphere configuration will change a little)
331      - grid computations in seaice_init are obsolete now.
332      - cleaned up code a little so that is easier to read (hopefully).
333      - added new (better?) discretizations of default advection and diffusion
334        (turn on with SEAICEuseFluxForm)
335      - replace 1 in 3d global fields by kSurface in growth.F
336      
337    checkpoint58a_post
338    o seaice:
339      - bug fix in advect.F
340    o shelfice:
341      - separate shelfice load anomaly from pload (breaks with time
342        dependent forcing), => introduce constant field shelficeLoadAnomaly.
343        Its default is 0., but it may be computed more cleverly from (unknown)
344        t- and s-profiles (tRef, sRef) and actual EOS. For now this has to be
345        done offline. A good approximation of the pressure load anomaly is
346        necessary to avoid large initial adjustment processes underneath
347        deep-reaching shelfice.
348      - small fix in ISOMIP shelfice_thermodynamics
349      - add more sophisticated thermodynamics of Hellmer (1989), this is
350        now the default
351      - give a few constants more intuitive names
352    o add code to balance EmPmP and Qnet at the end of do_ocean_physics. Useful
353      if bulk formulae are used in long integration (especially EmPmR). Turn
354      on with balanceEmPmR = .true. or balanceQnet = .true. in data, PARM01
355      if balancePrintMean, the imbalance that is substracted is printed to
356      STDOUT.
357    o fix bug (typo) in obcs_apply_eta.F
358    o add a new package shelfice which enables us to model the circulation
359      underneath shelf-ice with draughts of hundreds of meters.
360     - works
361     - to do: + include improved thermodynamics
362              + check whether kSurfC (from model/inc/SURFACE.h) can be used
363                instead of new field kTopC
364              + can we use topoFile, Ro_surf and existing code in ini_depth.F
365                instead of new field R_shelfIce and new code in ini_depth.F
366                and ini_mask_etc.F?
367              + adjust vertical mixing schemes?
368    o seaice pkg:
369     - add a cpp-flag to include a simple formula for a salinity dependent
370       freezing point of sea water at the surface
371     - change the contents of SEAICE_TEST_ICE_STRESS_1 so that zonal and
372       meridional stresses are now different (and hopefully correct)
373    o AIM pkg: change threshold on large-scale condensation to conserve Heat.
374       update results of aim.5l_LatLon test ; fix title & units of AIM diagnostics
375       and  change 3 diagnostics names (OSR,OSRCLR,KM -> TSR,TSRCLR,DRAG)
376    o pkg/diagnostics: add options and parameters for regional-statistics
377       diagnostics ; define regions by reading a region-mask from a file
378       (might add other options later)
379    o pkg/bulk_force:
380     - add option and parameters to use AIM surface-flux formulae.
381     - Change loading part: S/R BULKF_FIELDS_LOAD only take care of bulkf_fields ;
382       others forcing fields (defined in PARM05, parameter file "data") are loaded
383       from S/R EXTERNAL_FIELDS_LOAD, as usually (with useBulkforce = T or F).
384     - initialise all bulkf_fields in bulkf_init.F ; do in-lining of exf_bulkcdn.F
385     - use the right EXCH call for uwind,vwind (to work on CS-grid).
386     - re-arrange header files (move parameters from BULKF.h to BULKF_PARAMS.h)
387       and parameters (note: calcWindStress replaces .NOT.readwindstress).
388     - cleaner interface with pkg/thSIce (new S/R THSICE_GET_PRECIP).
389    
390    checkpoint58
391    o add "--embed-source" option to genmake2 which, when the supporting
392      tools can be compiled (as determined by genmake2) will turn on the
393      embed_files package which then embeds the entire MITgcm source code
394      (*.[fFhc] + Makefile) used for the build within the executable
395      - requested by CNH but off by default
396      - adds a paltry <9MB to the mitgcmuv executable in most cases
397      - only writes the output when useEMBEDSRC in eedata is true
398    o clean up 3-dim. relaxation codes:
399      * Fix I/O inconsistency in pkg/rbcs: replace precFloat32 by readBinaryPrec
400      * Remove 3-dim. relaxation code from pkg/exf (now use only pkg/rbcs)
401      * Thanks to Tom Haine for testing!
402    
403    checkpoint57z_post
404    o make CG3D solver compatible with Free-surface at k > 1 (p-coordinate):
405      affects output (@ truncation level) of exp. plume_on_slope ; updated.
406    o fix the pickup behavior for obcs in combination with ptracers
407    o fix a bug in ptracers_external_fields_load
408    o no AB-2 at the first iteration for Gw (consistent with Gu,Gv,Gt,Gs ...)
409      affects results of NH experiments (but all our NH tests have Gw[it=1]==0 !!)
410    o transfered surface NH pressure to eta field (if exactConserv).
411    o gmredi: fix bugs in slope tapering ldd97 (depthZ had the wrong sign)
412         and update lab_sea output.txt file.
413    o completing 3-dim. relaxation code: additional term
414         1/tau*( theta(i,j,k) - thetaStar(i,j,k) )
415      in S/R EXTERNAL_FORCING_T (file external_forcing.F)
416      * At compile time, in "EXF_OPTIONS.h" set
417          #define  ALLOW_CLIMTEMP_RELAXATION
418          #define  ALLOW_CLIMSALT_RELAXATION
419      * At runtime in "data", under &PARM03 set (e.g., units in seconds)
420          tauThetaClimRelax3Dim = 15552000.0,
421          tauSaltClimRelax3Dim  = 15552000.0,
422      * 3 cases:
423          1) Use a constant-in-time 3-dim. field
424          2) Provide 12 3-dim. fields corresponding to Jan., ... , Dec.
425          3) Real-time relax. to time-evolving prescribed field
426    o Adding Laplacian-type smoothness constraint on
427      initial and boundary (forcing) controls (ic, bc)
428      * enable at compile-time via
429        ALLOW_SMOOTH_IC_COST_CONTRIBUTION, ALLOW_SMOOTH_BC_COST_CONTRIBUTION
430      * enable at run-time via mult_smooth_ic = 1, mult_smooth_bc = 1
431      * Absolute scale somewhat unclear so far
432      * no area weighting was included since no other cost term does so far
433    
434    checkpoint57y_post
435    First step for a NLFS adjoint
436    o initially suppress rStar (new flag DISABLE_RSTAR_CODE)
437    o new init. routines for calc_r_star, calc_surf_dr
438    o still need to deal with ini_masks_etc
439    o testreport seemed happy
440    checkpoint57y_pre
441    
442    o obcs: always reset wVel & eta (to zero or prescribe it) at the OBs.
443    o add new package rbcs (for relaxing ptracers at boundaries/depth/surface etc)
444    o add new offset feature to offline pkg (plus minor cleanup)
445    o cfc fixes for final year of integration
446    o clean up GCHEM_OPTIONS.h/DIC_OPTIONS.h (all options should
447      be in GCHEM_OPTIONS).
448    
449    checkpoint57x_post
450    o fix testreport Pb in multiple test experiment.
451    o cleanup our namelist syntax in verification:
452      - make it more F95 standards compliant (some work still needed)
453      - allows the vast majority of our tests to work with gfortran
454    o Non-Hydrostatic:
455     - put all NH variables (formerly in DYNVARS.h & GW.h) in NH_VARS.h
456     - fix exchange calls for CS-grid using the new EXCH_S3D_RL.
457    o Allow to apply AB on T,S rather than on AB(gT,gS):
458     - implemented within #ifdef ALLOW_ADAMSBASHFORTH_3
459     - use the same arrays (gtNm,gsNm) to hold tracer field at previous
460       time-steps (if AB(T,S)) and tendencies (if AB(gT,gS)).
461     - need a "clever" read_pickup to restart from the other AB formulation
462    o move local commom bloc /GlobalLo/ (used for singleCpuIO) in EESUPPORT.h
463    o remove some unused variables (reduces number of compiler warnings)
464    o adjoint
465      * Disable useVariableViscosity for adjoint for time being
466        (there are a number of extensive recomputations)
467      * Initialize certain variables needed for adjoint
468    
469    checkpoint57w_post
470    o pkg/mdsio: use MAX_LEN_FNAM (instead of hard coded 80) for file-names
471                 fix the singleCpuIO RS version of MDSWRITEFIELD
472       and add a WARNING if using globalFiles=T with multi-processors.
473    o write grid-file(s) in only one format (MDS or MNC): default=MNC (if
474      using MNC); can force MDS output by setting writegrid_mnc=F in data.mnc
475    o tracer advection scheme:
476      add DST-2 (=Lax-Wendroff) & 1rst order upwind schemes (the way to get
477       those 2 schemes before, changing GAD_FLUX_LIMITER.h + to recompile,
478       was not very convenient).
479      add implicit version for DST-3 & DST3_Flux_Limit vertical advection;  
480       (further tests needed for the implicit DST & Flux-Limiter schemes).
481    o PTRACERS: added namelist parameter PTRACERS_ref in analogy to tRef
482      and sRef for convenience, handy, when you want to initialize
483      ptracers in a large domain with a constant non-zero value. Also,
484      untangle ptracers_init.F a little.
485    
486    checkpoint57v_post
487    o change dome exp. to use variable viscosity in side-drag terms.
488    o remove all the files from the cfc_offline test since they are now
489      incorporated into tutorial_cfc_offline which has been producing
490      identical results for a few days of testing
491    o add new parameter: sideDragFactor to enable half-slip-side BC
492      and change side-drag S/R to use viscosity from mom_calc_visc
493      (can switch back by setting sideDragFactor=0.); affects results at
494      truncation level; regenerate output for exp.: global_ocean.cs32x10(x3),
495       global_ocean_ebm, global_ocean_pressure, matrix_example & MLAdjust(x5).
496    o vorticity & strain are now computed without masking, to account for
497      no-slip-side BC in variable viscosity calculation ; mask is applied
498      anyway later on, before computing advection/coriolis terms.
499    o modify exp4 to test new obcs support for reading from external files
500      and for passive tracers
501    o fix behavior of ptracers_monitor when monitor output is written to a
502      netcdf-file; still not independent of monitor.F (writes in the same
503      file).
504    o change default value of tRef (put a uniform, meaningful value for ocean
505      & atmos) and initialize sRef (was missing, as Martin mentioned).
506    o Redefine viscC?Leith*.  Change the coefficients of Leith viscosity
507      to be proportional to enstrophy dissipation length.  Thus,
508       viscC?leith?_new=pi*(viscC?leith?_old)^(1/3)
509      This is now consistent with Smagorinsky and with the manual.
510    
511    checkpoint57u_post
512    o OBCS and PTRACERS: add open boundary support for passive tracers
513      - either use homogenous (pseudo) v.Neumann conditions or prescribe
514        OB-values from file; this is not different from the way theta and salinity
515        are treated
516      - however, Orlanski-radiation conditions are not supported, and the model
517        will stop if you use pTracers and Orlanski at the same time.
518      - beefed up the rountine obcs_external_fields_load: now only those open
519        boundary values are overwritten with values from files for which there
520        are really files, otherwise the OB-fields remain untouched. This makes
521        it possible to use different OBs at different ends of the domain (as
522        with EXF)
523    o reduce number of exch calls in shap_filt (s2).
524    o CS-grid: fix divergence contribution to Leith viscosity. Affects (@
525      truncation level) 4/5 MLAdjust test results (11&12 digits match).
526    
527    checkpoint57t_post
528    o test biharmonic viscosity + no-slip with exp: global_ocean.cs32x15.viscA4
529    o finish adding brackets (coriolis S/R, vecinv) in multi-terms sum to get
530      same truncation, independent of the face number: affects affects several
531      test. exp.: Update global_ocean.cs32x15 (+.thsice) & MLAdjust (all 5).
532    o fix bug in mom_v_sidedrag (biharmonic viscosity was counted 2 times);
533      note that biharmonic viscosity + no-slip was not tested in any experiment.
534    o fix bug in non-linear free-surf side-drag ; generate new output for
535      global_ocean.cs32x15(+.thsice) & global_ocean_pressure.
536    o make mnc honor the writeBinaryPrec flag for most kinds of output
537    o eesupp: split EEPARAMS into EESIZE/EEPARAMS and add a vector global sum
538    o minor change in averaging W (mom_vi_?_vertshear.F) that affects truncation
539      error; update output from global_ocean.cs32x15(+.thsice) & MLAdjust (all 5).
540    o add brackets in multi-terms sum to get same truncation, independent of
541      the face number (manage to get exactly same value of gU,gV at the cs-edge)
542      affects several test. exp. Update global_ocean.cs32x15 (+.thsice).
543    o Clean, new version of mom_calc_visc.  Adds a new feature, viscAhRemax
544      and viscA4Remax, which allow one to limit the minimum viscosity by specifying
545      a maximum grid-scale Reynolds number.  Also, changes all length calculations
546      in the case of grid anisotropy to geometric mean of dx**2 and dy**2.
547      Suggested values of viscosity parameters found in mom_calc_visc.
548      Many new viscosity diagnostics available.
549    
550    checkpoint57s_post
551    o Add clearing-house for viscosity calculations, mom_calc_visc and
552      correct numerous bugs in LeithD and Smagorinsky discretizations.  
553      mom_calc_visc now allows for Smagorinsky, Leith and LeithD to be
554      used simultaneously, and to be used in mom_vecinv and mom_fluxform.
555      Mom_vecinv can be used with standard viscous calculation (mom_vi_hdissip.F)
556      and with Strain-Tension viscous term calculation (mom_hdissip.F).  
557      The Strain-Tension form is now called with useStrainTensonVisc=.true.
558      ViscAhStrain and viscAhTension are now retired.
559    o diagnostics "VISCAHD" & "VISCA4D" replace "VISCAH" & "VISCA4".
560    o In response to JMC's bug report, genmake2 now ignores any soft-links
561      that it finds in the *current* directory when searching for files.
562      Soft-links found in any other source directories will still work as
563      they did before.
564    o add HAVE_SETRLSTK define and useSETRLSTK flag (eedata) which calls
565      a C routine to unlimit the stack size
566    o mnc-ify pkg/aim snapshot vars
567    o mnc-ify pkg/land as requested by Daniel
568    o various changes to mnc including:
569      - all files use the new "BASENAME[[.ITER].{t|f}NUM].nc" format
570      - output can now be grouped so that all files within a group
571          change the ITER portion of their names in lock-step together
572      - can now read ("global") PER-FACE (in addition to PER-TILE) files
573          and works with both EXCH1 and EXCH2 (but needs more testing)
574      - writing works for all verification test cases w/ g77 on Linux
575    
576    checkpoint57r_post
577    o make MNC variable initialization happen earlier
578    o add diagnostics for (almost) each term of the momentum Eq.
579    o remove SST,SSS,UVEL_k2,VVEL_k2 diagnostics.
580    o move pkg timeave out of pkg-groups "oceanic" & "atmospheric" (pkg/pkg_groups)
581    o remove MINIMAL_TAVE_OUTPUT option ;
582      add "dumpInitAndLast" to replace "nodumps" (and MINIMAL_TAVE_OUTPUT).
583    o move some basic S/R (used elsewhere in the code) from pkg/mdsio to eesupp/src
584      allows to compile without pkg/mdsio (& test successfully hs94.1x64x5)
585    o add MNC output for adjoint of EXF (adexf), SEAICE (adseaice)
586    o add time-dependent SST, SSS control
587    o cost terms in ecco/ modularized (new cost_generic.F)
588    o cost_averages routines are modularized (new cost_averagesgeneric.F)
589    o new infrastructure for seaice model vs. obs misfits in seaice/
590      * driver from the_main_loop.F is seaice_cost_driver.F
591      * first term is AREA vs. SMR observation misfit (ALLOW_SEAICE_COST_SMR_AREA)
592      * gradient check in Exp. 6a of natl_box_adjoint/
593    o natl_box_adjoint input_seaice for Lab. Sea now available online via wget
594      (see README file)
595    
596    checkpoint57q_post
597    o fix initialisation Pb in calc_gw (get NANs in exp5 with g77)
598    o fix annoying months-old bug in mnc/mdsio output for seaice pkg
599      - bug was reported by Jean-Michel and Ian Fenty
600    o fix initialization Pb in AIM-Ocean coupled model (aim_sice2aim.F)
601      update exp. cpl_aim+ocn output.
602    o Implement 4-level checkpointing: AUTODIFF_4_LEVEL_CHECKPOINT
603      Needed for high-res. runs with large global files
604      to be able to limit tapelev size
605    o Changed some tests for adjoint:
606      * carbon/ now tests AUTODIFF_2_LEVEL_CHECKPOINT
607      * natl_box_adjoint/code_bulk/ tests AUTODIFF_4_LEVEL_CHECKPOINT
608      * global_ocean.90x40x15/ back to default 3-level checkpointing
609    o Modifications to enable scripted COMMON to MODULE conversion
610      * verification/OpenAD/code/ has necessary scripts and description;
611      * converts, compiles and runs successfully;
612    
613    checkpoint57p_post
614    o reading of delXfile & delYfile moved from ini_parms.F to ini_grid.F
615    o move ${PKG}_MNC_INIT from ${PKG}_READ_PARAMS to ${PKG}_INIT_FIXED
616      (already the case for some pkgs, including recent MNC_init, e.g. thsice)
617    o call CALC_GW from DYNAMICS (instead of from FORWARD_STEP)
618    o Dissipation & phiHyd gradient are always added to gU,gV in timestep.F
619      (was already the case for dissipation with mom_vecinv,
620       and also the case for grad.PhiHyd when staggered-timeStep)
621      This will allow to put dissipation out-off the AB time-stepping.
622     Unfortunately, affects truncation error. Update output of exp. that "fails"
623      (cg2d matching number) and leave the others for later: front_relax(10),
624      global_ocean_pressure(10),ideal_2D_oce(10),internal_wave(9),lab_sea(12),
625      matrix_example(7!),natl_box(12),plume_on_slope(11),vermix(12x3,11x2).
626    
627    checkpoint57o_post
628    o fix MNC/MDSIO flags in PTRACERS so that (1) it works, and
629      (2) its ready to be documented during the 20050801 DocFest
630    o MNC-ify the gmredi package -- tested and works w/ and w/o mnc
631      for ideal_2D_oce and lab_sea on linux_ia32_g77
632    o set to #undef CTRL_SET_OLD_MAXCVARS_30
633      in global1x1_tot/code_seaice_adj to access indices 32, 33
634      (worth another tag)
635    
636    checkpoint57n_post
637    o adding precip control xx_precip 32
638    o adding swflux control xx_swflux 33
639    o Replacing 10 forcing penalty cost routines by 1 generic.
640    o Implementing partitioning in time-mean and variable adjustment
641      for atmos. state.
642    o Time-mean constant error is now read in data.ecco (instead of hard-coded)
643    o in natl_box_adjoint:
644      * updated exp 1 to 10
645        (but does not have time-mean vs. variable split results yet)
646    o updated global1x1/*_seaice_adj/
647      to incorporate latest changes
648    o enable useSingleCpuIO for mdsio vector routines
649      (applies in particular to tapelev I/O)
650    o removed inefficient K-loop in all active_file*control*.F
651    
652    checkpoint57m_post
653    o re-arrange exp. adjustment.cs-32x32x1 (adjust_nlfs.cs-32x32x1 merge into)
654      and advect_cs (use EXCH-2 and standard cs-32 grid files).
655    o pkg/exch2: filling of face-corner halo regions is optional
656      (ifdef W2_FILL_NULL_REGIONS) and is turned off by default.
657    
658    checkpoint57l_post
659     tag before updating tutorials (pre-release-2)
660    o add cos & sin of grid-direction orientation angle (curvilinear grid only,
661       for output and interpolation of input fields onto model grid)
662    o fix radius in mom_v_metric_cylinder.F (wrong by dy/2).
663       Affects results of exp. rotating_tank ; update output.txt.
664    o pkg/diagnostics: 2 new S/R to fill a diagnostics using a scaling factor
665          and taking the square quantity and/or using a fraction-weight field.
666    o fix aim_diagnostics_init.F mate numbers.
667    o add mnc output capability to diagnostics/diagstat and update
668      our cvsignore files for the ACSII output generated
669    
670    checkpoint57k_post
671    o lab_sea now uses diagnostics package and provides a suite of
672      new EXF diagnostics output.
673    
674    checkpoint57j_post
675    o exf
676      * bug fix in exf_bulkformulae for psimh (spotted by Eliyahu Biton):
677        Bracket missing in eqn. for psimh (eqn. 7 of Large & Pond, 1982);
678        terms -2*ATAN(x) + pi/2 were added to both stable and unstable case.
679      * extended diagnostics output
680        - now includes all EXF variables
681        - hs, hl moved to common block
682        - separate S/R for diagnostics, called after ctrl vector is added
683        - name changed for EXFsw -> EXFswnet, EXFlw -> EXFlwnet
684        - EXFqnet contains true Qnet (i.e. includes qsw)
685      * updated verif. lab_sea, global_with_exf
686      * Rearranging hflux (exf_mapfields -> exf_getforcing)
687        to ensure that diagnostics sees a true EXFqnet
688    o add matlab scripts for CS-grid vectors (in utils/cs_grid)
689    o diagnostics pkg: change pointers so that 1 diagnostic can be used
690      several times with different frequencies.
691    o mnc-ify the thsice package as requested by Daniel Enderton
692      - the monitor--MNC output needs work
693      - many attributes need to be added (most are currently blank)
694    o mnc-ify theaim_v23 package as requested by Daniel Enderton
695      - many attributes need to be added (most are currently blank)
696    o remove "groundAtK1" & "rkFac" (replaced by usingPCoords & -rkSign)
697    o add Sadourny like discretization to the 4th.O vorticity advection scheme
698    o fix bug in rStar code (calc_r_star.F) when used with topo/bathy.
699      update output.txt from: aim.5l_cs (& .thSI), cpl_aim+ocn,
700         fizhi-gridalt-hs and global_ocean.cs32x15 (& .thsice).
701    o fix few little things to avoid floating error with -ftrapuv (ifort v9)
702     (ini_spherical_polar_grid.F, calc_r_star.F, monitor/mon_surfcor.F)
703    
704    checkpoint57i_post
705    o Diagnostics package was changed: diagnostic allocation is now deactivated
706      by setting an empty file name in the namelist (used to be by setting 0 frequency)
707    o momentum advection (VI form) options: activate 4th.O vorticity Coriolis ;
708      add 1rst Order upwind vertical Shear.
709    o add a quick fix for A/B checkpointing in OFFLINE mode
710    o add IGNORE_TIME define and -ignore_time option to genmake2 as an
711      end-run around the C/Fortran linking horror in eesup/src/timers.F
712    o added pkg/runclock: allows user to terminate run based on wall clock
713    o added non-hydrostatic scaling parameter: nh_am2
714    o pkg/my82: futile attempt to make results compiler-independent by adding
715      some "_d 0", etc. no effect.
716    o for mnc output, fill the 'T' coordinate var with myTime and create a
717      separate 'iter' variable for iteration count
718    o pkg/diagnostics:
719      add new capability: output of Global/Regional & per-level statistics ;
720      tested against monitor output (including land & thSIce) on various exp.
721    o make seaice-pkg I/O type flags (MNC/MDS) more standard.
722    
723    checkpoint57h_done
724      tag after changing user customized files (DIAGNOSTICS_SIZE.h,
725      data.diagnostics, data.gchem, data.ptracers) is done.
726    
727    o pkg/diagnostics: prepare for Global/Regional statistics.
728      add 2nd namelist in data.diagnostics and update DIAGNOSTICS_SIZE.h
729    o remove "baseTime" (no used) from arg. list of DIFF_BASE_MULTIPLE
730      and rename it: DIFFERENT_MULTIPLE
731    
732    checkpoint57h_post
733    o move tIter0 from data.gchem to PTRACERS_Iter0 in data.ptracers
734    o pkg/diagnostics: change output frequency, now in seconds (instead
735      of Nb of iterations). This requires to change data.diagnostics.
736    checkpoint57h_pre
737    
738    o in mnc, let the user create the output dir if both mnc_outdir_date
739      and mnc_outdir_num are false
740    o add fflags() to pkg/diagnostics which allows one to specify, on a
741      per-file basis, the file precision [default behavior is unchanged]
742    o added diagnostics to pkg/kpp, including computation of mixed layer
743      depth based on a temperature/density criterion
744    o updated verification/natl_box to test the new pkg/kpp diagnostics
745    o bugs fixed (with useAbsVorticity=T & with useJamartMomAdv=T)
746    o test AB-3 code with 4th.Order advection scheme (advect_xy/input.ab3_c4)
747    o fix mnc flags in pkg/seaice so that they are "owned" by seaice,
748      not mnc -- this mistake was found by JMC and is now corrected
749    
750    checkpoint57g_post
751    o add Adams-Bashforth 3rd Order time stepping:
752      - default remains AB-2 (#undef ALLOW_ADAMSBASHFORTH_3)
753      - not yet implemented with NH, CD_Scheme, pTracers, MNC_pickup ...
754    checkpoint57g_pre
755    
756    o make lambda[Theta,Salt]ClimRelax spatially varying
757      (default remains spatially uniform constant based on tau)
758    o added new control variables
759      * init. uVel, vVel, etanN
760      * lambda[Theta,Salt]ClimRelax
761    o separate masks used for ctrl_pack/unpack 'from write_grid' output
762      (suggested by G. Forget)
763    
764    checkpoint57f_post
765    o add parameter "baseTime" = model base time = time at iteration zero
766      new function DIFF_BASE_MULTIPLE (replace DIFFERENT_MULTIPLE) to
767      account for baseTime shift
768    o move Coriolis arrays from PARAMS.h to GRID.h
769    checkpoint57f_pre
770    
771    o mnc-ifying the seaice package
772  o introduced an alternative length scale calculation for use in the limiting  o introduced an alternative length scale calculation for use in the limiting
773    maximum viscosity (off by default, see mom_vi_hdissip.F for details)    maximum viscosity (off by default, see mom_vi_hdissip.F for details)
774  o S/R ptracers_calc_diff: argument list bug for CALL KPP_CALC_DIFF_S  o S/R ptracers_calc_diff: argument list bug for CALL KPP_CALC_DIFF_S
# Line 16  o change port_rand funtion to allow to s Line 782  o change port_rand funtion to allow to s
782  o fix obscure MNC bug involving conversion between reals and integers  o fix obscure MNC bug involving conversion between reals and integers
783    - it caused no problems with certain (eg. gcc, ifc) compilers but the    - it caused no problems with certain (eg. gcc, ifc) compilers but the
784      new version is now more standards-compliant      new version is now more standards-compliant
785    o adjoint-related modifications
786      * gad_dst3_adv_?: to be able to use advscheme=30 in adjoint
787      * gad_calc_rhs: fool adjoint, revert to advscheme=30 in reverse when using 33
788      * mom_vi_hdissip: to be able to use Leith scheme in adjoint
789    
790  checkpoint57e_post  checkpoint57e_post
791  o Adding eddy stress controls a la Ferreira et al.  o Adding eddy stress controls a la Ferreira et al.
792  checkpoint57e_pre  checkpoint57e_pre (actually was tagged: eckpoint57e_pre)
793    
794  o fizhi pkg: fix AtoC and CtoA when called with same input & output array  o fizhi pkg: fix AtoC and CtoA when called with same input & output array
795    update output.txt of exp. fizhi-gridalt-hs    update output.txt of exp. fizhi-gridalt-hs

Legend:
Removed from v.1.467  
changed lines
  Added in v.1.718

  ViewVC Help
Powered by ViewVC 1.1.22