/[MITgcm]/MITgcm/pkg/seaice/SEAICE_OPTIONS.h
ViewVC logotype

Diff of /MITgcm/pkg/seaice/SEAICE_OPTIONS.h

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

revision 1.38 by dimitri, Mon Mar 1 23:46:13 2010 UTC revision 1.81 by mlosch, Fri Apr 28 17:20:33 2017 UTC
# Line 1  Line 1 
1  C $Header$  C $Header$
2  C $Name$  C $Name$
3    
4  C     /==========================================================\  C     *==========================================================*
5  C     | SEAICE_OPTIONS.h                                         |  C     | SEAICE_OPTIONS.h
6  C     | o CPP options file for sea ice package.                  |  C     | o CPP options file for sea ice package.
7  C     |==========================================================|  C     *==========================================================*
8  C     | Use this file for selecting options within the sea ice   |  C     | Use this file for selecting options within the sea ice
9  C     | package.                                                 |  C     | package.
10  C     \==========================================================/  C     *==========================================================*
11    
12  #ifndef SEAICE_OPTIONS_H  #ifndef SEAICE_OPTIONS_H
13  #define SEAICE_OPTIONS_H  #define SEAICE_OPTIONS_H
14  #include "PACKAGES_CONFIG.h"  #include "PACKAGES_CONFIG.h"
15  #include "CPP_OPTIONS.h"  #include "CPP_OPTIONS.h"
16    
17    #ifdef ALLOW_SEAICE
18    C     Package-specific Options & Macros go here
19    
20  C--   Write "text-plots" of certain fields in STDOUT for debugging.  C--   Write "text-plots" of certain fields in STDOUT for debugging.
21  #undef SEAICE_DEBUG  #undef SEAICE_DEBUG
22    
# Line 31  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--   Exclude Wind-Stress common block (in SEAICE.h). This option
38  C     When this flag is set, an 8-category calculation of ice  C     should ALWAYS been left undef (just listed here for the record)
39  C     thermodynamics is carried out in groatb.F  #undef SEAICE_EXCLUDE_WIND_STRESS
40  C     Note the pickup_seaice.* generated by this option differ  
41  C     from those generated with the default 2-category model.  C--   This CPP flag has been retired.  The number of ice categories
42  C     Therefore it is not possible to switch between the two  C     used to solve for seaice flux is now specified by run-time
43  C     in the middle of an integration.  C     parameter SEAICE_multDim.
44  #undef SEAICE_MULTICATEGORY  C     Note: be aware of pickup_seaice.* compatibility issues when
45    C     restarting a simulation with a different number of categories.
46  C--   By default the freezing point of water is set to the value of  c#define SEAICE_MULTICATEGORY
47  C     the parameter SEAICE_freeze (=-1.96 by default). To use a  
48  C     simple linear dependence of the freezing point on salinity,  C--   run with sea Ice Thickness Distribution (ITD);
49  C     set the following flag (pressure is assumed to have no effect,  C     set number of categories (nITD) in SEAICE_SIZE.h
50  C     which is a good assumption for the top 20 meters). With this  #undef SEAICE_ITD
51  C     option defined the parameter SEAICE_freeze has no effect.  
52  #undef SEAICE_VARIABLE_FREEZING_POINT  C--   Since the missing sublimation term is now included
53    C     this flag is needed for backward compatibility
54  C--   Allow SEAICEuseFlooding, which converts snow to ice if submerged.  #undef SEAICE_DISABLE_SUBLIM
55  #define ALLOW_SEAICE_FLOODING  
56    C--   Suspected missing term in coupled ocn-ice heat budget (to be confirmed)
57  C--   By default sea ice is fresh.  Set following flag for salty ice.  #undef SEAICE_DISABLE_HEATCONSFIX
58  #undef SEAICE_SALINITY  
59    C--   Default is constant seaice salinity (SEAICE_salt0); Define the following
60  C--   Track sea ice age.  C     flag to consider (space & time) variable salinity: advected and forming
61  #undef SEAICE_AGE  C     seaice with a fraction (=SEAICE_saltFrac) of freezing seawater salinity.
62    C- Note: SItracer also offers an alternative way to handle variable salinity.
63    #undef SEAICE_VARIABLE_SALINITY
64    
65    C--   Tracers of ice and/or ice cover.
66    #undef ALLOW_SITRACER
67    #ifdef ALLOW_SITRACER
68    C--   To try avoid 'spontaneous generation' of tracer maxima by advdiff.
69    # define ALLOW_SITRACER_ADVCAP
70    #endif
71    
72    C--   Enable grease ice parameterization
73    C     The grease ice parameterization delays formation of solid
74    C     sea ice from frazil ice by a time constant and provides a
75    C     dynamic calculation of the initial solid sea ice thickness
76    C     HO as a function of winds, currents and available grease ice
77    C     volume. Grease ice does not significantly reduce heat loss
78    C     from the ocean in winter and area covered by grease is thus
79    C     handled like open water.
80    C     (For details see Smedsrud and Martin, 2014, Ann.Glac.)
81    C     Set SItrName(1) = 'grease' in namelist SEAICE_PARM03 in data.seaice
82    C     then output SItr01 is SItrNameLong(1) = 'grease ice volume fraction',
83    C     with SItrUnit(1) = '[0-1]', which needs to be multiplied by SIheff
84    C     to yield grease ice volume. Additionally, the actual grease ice
85    C     layer thickness (diagnostic SIgrsLT) can be saved.
86    #undef SEAICE_GREASE
87    C--   grease ice uses SItracer:
88    #ifdef SEAICE_GREASE
89    # define ALLOW_SITRACER
90    # define ALLOW_SITRACER_ADVCAP
91    #endif
92    
93  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
94  C     historical reasons). Define the following flag to use a new  C     historical reasons). Define the following flag to use a new
95  C     (not thoroughly) test version on a C-grid  C     (not thoroughly) test version on a C-grid
96  #define SEAICE_CGRID  #define SEAICE_CGRID
97    
98  C--   Only for the C-grid version it is possible to  C--   Only for the C-grid version it is possible to
99  #ifdef SEAICE_CGRID  #ifdef SEAICE_CGRID
100    C     enable advection of sea ice momentum
101    # undef SEAICE_ALLOW_MOM_ADVECTION
102    C     enable JFNK code by defining the following flag
103    # define SEAICE_ALLOW_JFNK
104    C     enable Krylov code by defining the following flag
105    # define SEAICE_ALLOW_KRYLOV
106    C     enable LSR to use global (multi-tile) tri-diagonal solver
107    # undef SEAICE_GLOBAL_3DIAG_SOLVER
108  C     enable EVP code by defining the following flag  C     enable EVP code by defining the following flag
109  # define SEAICE_ALLOW_EVP  # define SEAICE_ALLOW_EVP
110  # ifdef SEAICE_ALLOW_EVP  # ifdef SEAICE_ALLOW_EVP
111  C--   When set use SEAICE_zetaMin and SEAICE_evpDampC to limit  C--   When set use SEAICE_zetaMin and SEAICE_evpDampC to limit viscosities
112  C--   viscosities from below and above in seaice_evp  C     from below and above in seaice_evp: not necessary, and not recommended
 C--   not necessary, and not recommended  
113  #  undef SEAICE_ALLOW_CLIPZETA  #  undef SEAICE_ALLOW_CLIPZETA
114  # endif /* SEAICE_ALLOW_EVP */  # endif /* SEAICE_ALLOW_EVP */
115    C     smooth regularization (without max-function) of delta for
116    C     better differentiability
117    # undef SEAICE_DELTA_SMOOTHREG
118    C     regularize zeta to zmax with a smooth tanh-function instead
119    C     of a min(zeta,zmax). This improves convergence of iterative
120    C     solvers (Lemieux and Tremblay 2009, JGR). No effect on EVP
121    # undef SEAICE_ZETA_SMOOTHREG
122  C     allow the truncated ellipse rheology (runtime flag SEAICEuseTEM)  C     allow the truncated ellipse rheology (runtime flag SEAICEuseTEM)
123  # undef SEAICE_ALLOW_TEM  # undef SEAICE_ALLOW_TEM
124    C     Use LSR vector code; not useful on non-vector machines, because it
125    C     slows down convergence considerably, but the extra iterations are
126    C     more than made up by the much faster code on vector machines. For
127    C     the only regularly test vector machine these flags a specified
128    C     in the build options file SUPER-UX_SX-8_sxf90_awi, so that we comment
129    C     them out here.
130    # undef SEAICE_VECTORIZE_LSR
131    C     Use zebra-method (alternate lines) for line-successive-relaxation
132    C     This modification improves the convergence of the vector code
133    C     dramatically, so that is may actually be useful in general, but
134    C     that needs to be tested. Can be used without vectorization options.
135    # undef SEAICE_LSR_ZEBRA
136    C     Use parameterisation of grounding ice for a better representation
137    C     of fastice in shallow seas
138    # undef SEAICE_ALLOW_BOTTOMDRAG
139  #else /* not SEAICE_CGRID, but old B-grid */  #else /* not SEAICE_CGRID, but old B-grid */
140  C--   By default for B-grid dynamics solver wind stress under sea-ice is  C--   By default for B-grid dynamics solver wind stress under sea-ice is
141  C     set to the same value as it would be if there was no sea-ice.  C     set to the same value as it would be if there was no sea-ice.
# Line 84  C--   By default for B-grid dynamics sol Line 146  C--   By default for B-grid dynamics sol
146  C     indirectly via geostrophic velocities. Define following CPP  C     indirectly via geostrophic velocities. Define following CPP
147  C     in order to use ETAN instead.  C     in order to use ETAN instead.
148  # define EXPLICIT_SSH_SLOPE  # define EXPLICIT_SSH_SLOPE
149    C--   Defining this flag turns on FV-discretization of the B-grid LSOR solver.
150    C     It is smoother and includes all metric terms, similar to C-grid solvers.
151    C     It is here for completeness, but its usefulness is unclear.
152    # undef SEAICE_LSRBNEW
153  #endif /* SEAICE_CGRID */  #endif /* SEAICE_CGRID */
154    
155  C--   When set use MAX_HEFF to cap sea ice thickness in seaice_growth  C--   When set limit the Ice-Loading to mass of 1/5 of Surface ocean grid-box
156  #undef SEAICE_CAP_HEFF  #undef SEAICE_CAP_ICELOAD
157  C--   When set use SEAICE_clipVelocties = .true., to clip U/VICE at 40cm/s,  C--   When set use SEAICE_clipVelocties = .true., to clip U/VICE at 40cm/s,
158  C--   not recommended  C     not recommended
159  #undef SEAICE_ALLOW_CLIPVELS  #undef SEAICE_ALLOW_CLIPVELS
160    C--   When set cap the sublimation latent heat flux in solve4temp according
161    C     to the available amount of ice+snow. Otherwise this term is treated
162    C     like all of the others -- residuals heat and fw stocks are passed to
163    C     the ocean at the end of seaice_growth in a conservative manner.
164    C     SEAICE_CAP_SUBLIM is not needed as of now, but kept just in case.
165    #undef SEAICE_CAP_SUBLIM
166    
167    C--   Enable free drift code
168    #undef SEAICE_ALLOW_FREEDRIFT
169    
170    C--   pkg/seaice cost functions compile flags
171    c       >>> Sea-ice volume (requires pkg/cost)
172    #undef ALLOW_COST_ICE
173    c       >>> Sea-ice misfit to obs (requires pkg/cost and ecco)
174    #undef ALLOW_SEAICE_COST_SMR_AREA
175    
176    #endif /* ALLOW_SEAICE */
177  #endif /* SEAICE_OPTIONS_H */  #endif /* SEAICE_OPTIONS_H */
178    
179  CEH3 ;;; Local Variables: ***  CEH3 ;;; Local Variables: ***

Legend:
Removed from v.1.38  
changed lines
  Added in v.1.81

  ViewVC Help
Powered by ViewVC 1.1.22