/[MITgcm]/MITgcm_contrib/high_res_cube/code-mods/SEAICE_OPTIONS.h
ViewVC logotype

Diff of /MITgcm_contrib/high_res_cube/code-mods/SEAICE_OPTIONS.h

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

revision 1.13 by dimitri, Mon Oct 15 18:22:58 2007 UTC revision 1.19 by dimitri, Mon Mar 19 20:31:59 2012 UTC
# Line 1  Line 1 
1  C $Header$  C $Header$
2    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 23  C     Sea-ice dynamics can also be turne Line 27  C     Sea-ice dynamics can also be turne
27  C     using variable SEAICEuseDYNAMICS.  C     using variable SEAICEuseDYNAMICS.
28  #define SEAICE_ALLOW_DYNAMICS  #define SEAICE_ALLOW_DYNAMICS
29    
 C--   By default, pkg/seaice defines forcing variable internally, in  
 C     SEAICE_FFIELDS.h, and reads them in from files.  When CPP option  
 C     SEAICE_EXTERNAL_FORCING is defined, the above forcing variables  
 C     are defined and provided by an external package.  At present this  
 C     option is hardwired for pkg/exf and the variables are passed using  
 C     include file EXF_FIELDS.h (=> cannot be defined without pkg/EXF )  
 #define SEAICE_EXTERNAL_FORCING  
 #ifndef ALLOW_EXF  
 # undef SEAICE_EXTERNAL_FORCING  
 #endif  
   
 #ifdef  SEAICE_EXTERNAL_FORCING  
 #  include "EXF_OPTIONS.h"  
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
32  C     open-ocean.  When this flag is set, these variables are computed  C     open-ocean.  When this flag is set, these variables are computed
33  C     in a separate external package, for example, pkg/exf, and then  C     in a separate external package, for example, pkg/exf, and then
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
   
 #else  /* SEAICE_EXTERNAL_FORCING */  
 C-    current implementation requires those options to be set:  
 # undef  SEAICE_EXTERNAL_FLUXES  
 # define ALLOW_ATM_TEMP  
 # define ALLOW_DOWNWARD_RADIATION  
 # define ALLOW_RUNOFF  
   
 #endif /* SEAICE_EXTERNAL_FORCING */  
   
 #ifdef ALLOW_OBCS  
 C- OBCS information is needed to define the correct sea ice mask.  
 #include "OBCS_OPTIONS.h"  
 #endif /* ALLOW_OBCS */  
36    
37  C--   By default, the sea-ice package uses 2-category thermodynamics.  C--   By default, the sea-ice package uses 2-category thermodynamics.
38  C     When this flag is set, an 8-category calculation of ice  C     When this flag is set, an 8-category calculation of ice
# Line 66  C     Therefore it is not possible to sw Line 43  C     Therefore it is not possible to sw
43  C     in the middle of an integration.  C     in the middle of an integration.
44  #define SEAICE_MULTICATEGORY  #define SEAICE_MULTICATEGORY
45    
46  C--   By default for B-grid dynamics solver wind stress under sea-ice is  C--   Use the Old version of seaice_growth (close to cvs version 1.70)
47  C     set to the same value as it would be if there was no sea-ice.  C     otherwise, use the merged version (with some of Ian Fenty s code)
48  C     Define following CPP flag for B-grid ice-ocean stress coupling.  #undef SEAICE_GROWTH_LEGACY
49  #undef SEAICE_TEST_ICE_STRESS_1  
50    C--   Since the missing sublimation term is now included
51  C--   By default for B-grid dynamics solver surface tilt is obtained  C     this flag is needed for backward compatibility
52  C     indirectly via geostrophic velocities.  Define following CPP  #undef SEAICE_DISABLE_SUBLIM
53  C     in order to ues ETAN instead.  
54  #undef EXPLICIT_SSH_SLOPE  C--   Suspected missing term in coupled ocn-ice heat budget (to be further tested)
55    #undef SEAICE_DISABLE_HEATCONSFIX
56  C--   By default the freezing point of water is set to the value of  
57  C     the parameter SEAICE_freeze (=-1.96 by default). To use a  C--   options only available in the merged version
58  C     simple linear dependence of the freezing point on salinity,  #ifndef SEAICE_GROWTH_LEGACY
59  C     set the following flag (pressure is assumed to have no effect,  C-    to ensure heat conservation in the coupled ocean-seaice system
60  C     which is a good assumption for the top 20 meters). With this  # undef SEAICE_HEAT_CONSERV_FIX
61  C     option defined the parameter SEAICE_freeze has no effect.  C-    to preclude infinitesimal ice concentrations:
62  #define SEAICE_VARIABLE_FREEZING_POINT  # undef ALLOW_PRECLUDE_INFINITESIMAL_AREA
63    #endif
 C--   Allow SEAICEuseFlooding, which converts snow to ice if submerged.  
 #define ALLOW_SEAICE_FLOODING  
64    
65  C--   By default sea ice is fresh.  Set following flag for salty ice.  C--   By default sea ice is fresh.  Set following flag for salty ice.
66  #define SEAICE_SALINITY  #define SEAICE_VARIABLE_SALINITY
67    
68    C--   Tracers of ice and/or ice cover.
69    #undef ALLOW_SITRACER
70    #ifdef ALLOW_SITRACER
71    C--   To try avoid 'spontaneous generation' of tracer maxima by advdiff.
72    # define ALLOW_SITRACER_ADVCAP
73    #endif
74    
75  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
76  C     historical reasons). Define the following flag to use a new  C     historical reasons). Define the following flag to use a new
77  C     (not thoroughly) test version on a C-grid  C     (not thoroughly) test version on a C-grid
78  #define SEAICE_CGRID  #define SEAICE_CGRID
79    
80  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  
81  #ifdef SEAICE_CGRID  #ifdef SEAICE_CGRID
82  #undef SEAICE_ALLOW_EVP  C     enable EVP code by defining the following flag
83    # define SEAICE_ALLOW_EVP
84    # ifdef SEAICE_ALLOW_EVP
85    C--   When set use SEAICE_zetaMin and SEAICE_evpDampC to limit
86    C--   viscosities from below and above in seaice_evp
87    C--   not necessary, and not recommended
88    #  undef SEAICE_ALLOW_CLIPZETA
89    # endif /* SEAICE_ALLOW_EVP */
90    C     allow the truncated ellipse rheology (runtime flag SEAICEuseTEM)
91    # undef SEAICE_ALLOW_TEM
92    #else /* not SEAICE_CGRID, but old B-grid */
93    C--   By default for B-grid dynamics solver wind stress under sea-ice is
94    C     set to the same value as it would be if there was no sea-ice.
95    C     Define following CPP flag for B-grid ice-ocean stress coupling.
96    # define SEAICE_BICE_STRESS
97    
98    C--   By default for B-grid dynamics solver surface tilt is obtained
99    C     indirectly via geostrophic velocities. Define following CPP
100    C     in order to use ETAN instead.
101    # define EXPLICIT_SSH_SLOPE
102    C--   Defining this flag turns on a FV-discretization of the B-grid LSOR
103    C     solver. It is smoother and includes all metric terms, similar to the
104    C     C-grid solver. It is here for completeness, but its usefulness is
105    C     unclear.
106    # undef SEAICE_LSRBNEW
107  #endif /* SEAICE_CGRID */  #endif /* SEAICE_CGRID */
108    
109  C--   When set use MAX_HEFF to cap sea ice thickness in seaice_growth  C--   When set use MAX_HEFF to cap sea ice thickness in seaice_growth
110  #define SEAICE_CAP_HEFF  #undef SEAICE_CAP_HEFF
111    C--   When set limit the Ice-Loading to mass of 1/5 of Surface ocean grid-box
112    #undef SEAICE_CAP_ICELOAD
113    C--   When set use SEAICE_clipVelocties = .true., to clip U/VICE at 40cm/s,
114    C--   not recommended
115    #undef SEAICE_ALLOW_CLIPVELS
116    C--   When set cap the sublimation latent heat flux in solve4temp
117    C     according to the available amount of ice+snow. Otherwise this
118    C     term is treated like all of the others -- residuals heat and
119    C     fw stocks are passed to the ocean at the end of seaice_growth
120    C     in a conservative manner. SEAICE_CAP_SUBLIM is not needed
121    C     as of now, but kept just in case.
122    #undef SEAICE_CAP_SUBLIM
123    
124    C     enable free drift code
125    #undef SEAICE_ALLOW_FREEDRIFT
126    
127    #endif /* ALLOW_SEAICE */
128  #endif /* SEAICE_OPTIONS_H */  #endif /* SEAICE_OPTIONS_H */
129    
130  CEH3 ;;; Local Variables: ***  CEH3 ;;; Local Variables: ***

Legend:
Removed from v.1.13  
changed lines
  Added in v.1.19

  ViewVC Help
Powered by ViewVC 1.1.22