/[MITgcm]/MITgcm/verification/1D_ocean_ice_column/code/SEAICE_OPTIONS.h
ViewVC logotype

Diff of /MITgcm/verification/1D_ocean_ice_column/code/SEAICE_OPTIONS.h

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

revision 1.14 by gforget, Thu Mar 8 01:17:57 2012 UTC revision 1.15 by jmc, Tue Oct 23 00:10:01 2012 UTC
# Line 25  C     This option is provided to allow u Line 25  C     This option is provided to allow u
25  C     on the thermodynamics component of the code only.  C     on the thermodynamics component of the code only.
26  C     Sea-ice dynamics can also be turned off at runtime  C     Sea-ice dynamics can also be turned off at runtime
27  C     using variable SEAICEuseDYNAMICS.  C     using variable SEAICEuseDYNAMICS.
28  #undef SEAICE_ALLOW_DYNAMICS  #define SEAICE_ALLOW_DYNAMICS
29    
30  C--   By default, the sea-ice package uses its own integrated bulk  C--   By default, the sea-ice package uses its own integrated bulk
31  C     formulae to compute fluxes (fu, fv, EmPmR, Qnet, and Qsw) over  C     formulae to compute fluxes (fu, fv, EmPmR, Qnet, and Qsw) over
# Line 34  C     in a separate external package, fo Line 34  C     in a separate external package, fo
34  C     modified for sea-ice effects by pkg/seaice.  C     modified for sea-ice effects by pkg/seaice.
35  #define SEAICE_EXTERNAL_FLUXES  #define SEAICE_EXTERNAL_FLUXES
36    
37  C--   By default, the sea-ice package uses 2-category thermodynamics.  C--   The actual number of ice categories used to solve for seaice flux is
38  C     When this flag is set, an 8-category calculation of ice  C     now a run-time parameter (SEAICE_multDim).
39  C     thermodynamics is carried out in groatb.F  C     This CPP-flag will be completely removed soon (no longer in main code);
40  C     Note the pickup_seaice.* generated by this option differ  C     it is just used to set default number of categories, i.e., =1 if undef,
41  C     from those generated with the default 2-category model.  C     or =MULTDIM if defined (MULTDIM=7 in default SEAICE_SIZE.h).
42  C     Therefore it is not possible to switch between the two  C     Note: be aware of pickup_seaice.* compatibility issues when restarting
43  C     in the middle of an integration.  C     a simulation with a different number of categories.
44  #undef SEAICE_MULTICATEGORY  #undef SEAICE_MULTICATEGORY
45    
46    C--   Use the Old version of seaice_growth (close to cvs version 1.70)
47    C     otherwise, use the merged version (with some of Ian Fenty s code)
48    #undef SEAICE_GROWTH_LEGACY
49  #undef SEAICE_MODIFY_GROWTH_ADJ  #undef SEAICE_MODIFY_GROWTH_ADJ
 #undef SEAICE_SIMPLIFY_GROWTH_ADJ  
50    
51  C--   Since the missing sublimation term is now included  C--   Since the missing sublimation term is now included
52  C     this flag is needed for backward compatibility  C     this flag is needed for backward compatibility
53  #define SEAICE_DISABLE_SUBLIM  #define SEAICE_DISABLE_SUBLIM
54    
55  C--   Suspected missing term in coupled ocn-ice heat budget (to be further tested)  C--   Suspected missing term in coupled ocn-ice heat budget (to be confirmed)
56  #define SEAICE_DISABLE_HEATCONSFIX  #define SEAICE_DISABLE_HEATCONSFIX
57    
58  C--   By default cdm wind stress under sea-ice is set to the  C--   Default is constant seaice salinity (SEAICE_salt0); Define the following
59  C     same value as it would be if there was no sea-ice.  C     flag to consider (space & time) variable salinity: advected and forming
60  C     This is a placeholder until a more physically-sensible  C     seaice with a fraction (=SEAICE_saltFrac) of freezing seawater salinity.
61  C     stable solution is developed.  Apparently ocean stress  C- Note: SItracer also offers an alternative way to handle variable salinity.
62  C     that is based on sea-ice velocity can cause trouble in  #define SEAICE_VARIABLE_SALINITY
63  C     Arctic Ocean configurations.  This temporary solution  
64  C     also corresponds to that adopted by CCSM-2.  For the  C--   Tracers of ice and/or ice cover.
65  C     adventurous user who requires ice-modified stress,  #undef ALLOW_SITRACER
66  C     following options are available.  #ifdef ALLOW_SITRACER
67  #undef SEAICE_ORIGINAL_BAD_ICE_STRESS  C--   To try avoid 'spontaneous generation' of tracer maxima by advdiff.
68  #undef SEAICE_TEST_ICE_STRESS_1  # define ALLOW_SITRACER_ADVCAP
69    #endif
70    
71  C--   By default the seaice model is discretized on a B-Grid (for  C--   By default the seaice model is discretized on a B-Grid (for
72  C     historical reasons). Define the following flag to use a new  C     historical reasons). Define the following flag to use a new
73  C     (not thoroughly) test version on a C-grid  C     (not thoroughly) test version on a C-grid
74  #define SEAICE_CGRID  #undef SEAICE_CGRID
75    
76  C--   Only for the C-grid version it is possible to enable EVP code by  C--   Only for the C-grid version it is possible to
 C     defining the following flag  
77  #ifdef SEAICE_CGRID  #ifdef SEAICE_CGRID
78  #define SEAICE_ALLOW_EVP  C     enable JFNK code by defining the following flag
79    # define SEAICE_ALLOW_JFNK
80    C     enable EVP code by defining the following flag
81    # define SEAICE_ALLOW_EVP
82    # ifdef SEAICE_ALLOW_EVP
83    C--   When set use SEAICE_zetaMin and SEAICE_evpDampC to limit viscosities
84    C     from below and above in seaice_evp: not necessary, and not recommended
85    #  undef SEAICE_ALLOW_CLIPZETA
86    # else /* not EVP */
87    C     regularize zeta to zmax with a smooth tanh-function instead
88    C     of a min(zeta,zmax). This improves convergence of iterative
89    C     solvers (Lemieux and Tremblay 2009, JGR). No effect on EVP
90    #  undef SEAICE_ZETA_SMOOTHREG
91    # endif /* SEAICE_ALLOW_EVP */
92    C     allow the truncated ellipse rheology (runtime flag SEAICEuseTEM)
93    # undef SEAICE_ALLOW_TEM
94    #else /* not SEAICE_CGRID, but old B-grid */
95    C--   By default for B-grid dynamics solver wind stress under sea-ice is
96    C     set to the same value as it would be if there was no sea-ice.
97    C     Define following CPP flag for B-grid ice-ocean stress coupling.
98    # define SEAICE_BICE_STRESS
99    
100    C--   By default for B-grid dynamics solver surface tilt is obtained
101    C     indirectly via geostrophic velocities. Define following CPP
102    C     in order to use ETAN instead.
103    # define EXPLICIT_SSH_SLOPE
104    C--   Defining this flag turns on FV-discretization of the B-grid LSOR solver.
105    C     It is smoother and includes all metric terms, similar to C-grid solvers.
106    C     It is here for completeness, but its usefulness is unclear.
107    # undef SEAICE_LSRBNEW
108  #endif /* SEAICE_CGRID */  #endif /* SEAICE_CGRID */
109    
110  C--   By default sea ice is fresh.  Set following flag for salty ice.  C--   When set use MAX_HEFF to cap seaice thickness in seaice_growth;
111  #define SEAICE_VARIABLE_SALINITY  C     currently only relevant for SEAICE_GROWTH_LEGACY
112    #undef SEAICE_CAP_HEFF
113    C--   When set limit the Ice-Loading to mass of 1/5 of Surface ocean grid-box
114    #undef SEAICE_CAP_ICELOAD
115    C--   When set use SEAICE_clipVelocties = .true., to clip U/VICE at 40cm/s,
116    C     not recommended
117    #undef SEAICE_ALLOW_CLIPVELS
118    C--   When set cap the sublimation latent heat flux in solve4temp according
119    C     to the available amount of ice+snow. Otherwise this term is treated
120    C     like all of the others -- residuals heat and fw stocks are passed to
121    C     the ocean at the end of seaice_growth in a conservative manner.
122    C     SEAICE_CAP_SUBLIM is not needed as of now, but kept just in case.
123    #undef SEAICE_CAP_SUBLIM
124    
125    C--   Enable free drift code
126    #undef SEAICE_ALLOW_FREEDRIFT
127    
128    C--   run with sea ice thickness distribution;
129    C     set number of categories (nITD) in SEAICE_SIZE.h
130    #undef SEAICE_ITD
131    C
132    C--   SEAICE_ITD replaces SEAICE_MULTICATEGORY
133    #ifdef SEAICE_ITD
134    #undef SEAICE_MULTICATEGORY
135    #endif
136    
137  #endif /* ALLOW_SEAICE */  #endif /* ALLOW_SEAICE */
138  #endif /* SEAICE_OPTIONS_H */  #endif /* SEAICE_OPTIONS_H */

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.15

  ViewVC Help
Powered by ViewVC 1.1.22