/[MITgcm]/MITgcm_contrib/llc_hires/llc_540/code/CPP_OPTIONS.h
ViewVC logotype

Annotation of /MITgcm_contrib/llc_hires/llc_540/code/CPP_OPTIONS.h

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


Revision 1.2 - (hide annotations) (download)
Tue Sep 3 18:43:41 2019 UTC (5 years, 11 months ago) by zhc
Branch: MAIN
Changes since 1.1: +2 -2 lines
File MIME type: text/plain
no profile; blank tile

1 zhc 1.2 C $Header: /u/gcmpack/MITgcm_contrib/llc_hires/llc_540/code/CPP_OPTIONS.h,v 1.1 2019/08/23 18:19:49 zhc Exp $
2 zhc 1.1 C $Name: $
3    
4     #ifndef CPP_OPTIONS_H
5     #define CPP_OPTIONS_H
6    
7     CBOP
8     C !ROUTINE: CPP_OPTIONS.h
9     C !INTERFACE:
10     C #include "CPP_OPTIONS.h"
11    
12     C !DESCRIPTION:
13     C *==================================================================*
14     C | main CPP options file for the model:
15     C | Control which optional features to compile in model/src code.
16     C *==================================================================*
17     CEOP
18    
19     C CPP flags controlling particular source code features
20    
21     C-- Forcing code options:
22    
23     C o Shortwave heating as extra term in external_forcing.F
24     C Note: this should be a run-time option
25     #define SHORTWAVE_HEATING
26    
27     C o Include/exclude Geothermal Heat Flux at the bottom of the ocean
28     #define ALLOW_GEOTHERMAL_FLUX
29    
30     C o Allow to account for heating due to friction (and momentum dissipation)
31     #undef ALLOW_FRICTION_HEATING
32    
33     C o Allow mass source or sink of Fluid in the interior
34     C (3-D generalisation of oceanic real-fresh water flux)
35     #undef ALLOW_ADDFLUID
36    
37     C o Include pressure loading code
38     #define ATMOSPHERIC_LOADING
39    
40     C o Include/exclude balancing surface forcing fluxes code
41     #define ALLOW_BALANCE_FLUXES
42    
43     C o Include/exclude balancing surface forcing relaxation code
44     #define ALLOW_BALANCE_RELAX
45    
46     C o Include/exclude checking for negative salinity
47     #undef CHECK_SALINITY_FOR_NEGATIVE_VALUES
48    
49     C-- Options to discard parts of the main code:
50    
51     C o Exclude/allow external forcing-fields load
52     C this allows to read & do simple linear time interpolation of oceanic
53     C forcing fields, if no specific pkg (e.g., EXF) is used to compute them.
54     #undef EXCLUDE_FFIELDS_LOAD
55    
56     C o Include/exclude phi_hyd calculation code
57     #define INCLUDE_PHIHYD_CALCULATION_CODE
58    
59     C-- Vertical mixing code options:
60    
61     C o Include/exclude call to S/R CONVECT
62     #define INCLUDE_CONVECT_CALL
63    
64     C o Include/exclude call to S/R CALC_DIFFUSIVITY
65     #define INCLUDE_CALC_DIFFUSIVITY_CALL
66    
67     C o Allow full 3D specification of vertical diffusivity
68     #define ALLOW_3D_DIFFKR
69    
70     C o Allow latitudinally varying BryanLewis79 vertical diffusivity
71     #undef ALLOW_BL79_LAT_VARY
72    
73     C o Exclude/allow partial-cell effect (physical or enhanced) in vertical mixing
74     C this allows to account for partial-cell in vertical viscosity and diffusion,
75     C either from grid-spacing reduction effect or as artificially enhanced mixing
76     C near surface & bottom for too thin grid-cell
77     #undef EXCLUDE_PCELL_MIX_CODE
78    
79     C-- Time-stepping code options:
80    
81     C o Include/exclude combined Surf.Pressure and Drag Implicit solver code
82 zhc 1.2 #define ALLOW_SOLVE4_PS_AND_DRAG
83 zhc 1.1
84     C o Include/exclude Implicit vertical advection code
85     #define INCLUDE_IMPLVERTADV_CODE
86    
87     C o Include/exclude AdamsBashforth-3rd-Order code
88     #define ALLOW_ADAMSBASHFORTH_3
89    
90     C-- Model formulation options:
91    
92     C o Allow/exclude "Exact Convervation" of fluid in Free-Surface formulation
93     C that ensures that d/dt(eta) is exactly equal to - Div.Transport
94     #define EXACT_CONSERV
95    
96     C o Allow the use of Non-Linear Free-Surface formulation
97     C this implies that grid-cell thickness (hFactors) varies with time
98     #define NONLIN_FRSURF
99     #define DISABLE_SIGMA_CODE
100    
101     C o Include/exclude nonHydrostatic code
102     #undef ALLOW_NONHYDROSTATIC
103    
104     C o Include/exclude GM-like eddy stress in momentum code
105     #undef ALLOW_EDDYPSI
106    
107     C-- Algorithm options:
108    
109     C o Use Non Self-Adjoint (NSA) conjugate-gradient solver
110     #undef ALLOW_CG2D_NSA
111    
112     C o Include/exclude code for single reduction Conjugate-Gradient solver
113     #undef ALLOW_SRCG
114    
115     C o Choices for implicit solver routines solve_*diagonal.F
116     C The following has low memory footprint, but not suitable for AD
117     #undef SOLVE_DIAGONAL_LOWMEMORY
118     C The following one suitable for AD but does not vectorize
119     #define SOLVE_DIAGONAL_KINNER
120    
121     C-- Retired code options:
122    
123     C o ALLOW isotropic scaling of harmonic and bi-harmonic terms when
124     C using an locally isotropic spherical grid with (dlambda) x (dphi*cos(phi))
125     C *only for use on a lat-lon grid*
126     C Setting this flag here affects both momentum and tracer equation unless
127     C it is set/unset again in other header fields (e.g., GAD_OPTIONS.h).
128     C The definition of the flag is commented to avoid interference with
129     C such other header files.
130     C The preferred method is specifying a value for viscAhGrid or viscA4Grid
131     C in data which is then automatically scaled by the grid size;
132     C the old method of specifying viscAh/viscA4 and this flag is provided
133     C for completeness only (and for use with the adjoint).
134     C#define ISOTROPIC_COS_SCALING
135    
136     C o This flag selects the form of COSINE(lat) scaling of bi-harmonic term.
137     C *only for use on a lat-lon grid*
138     C Has no effect if ISOTROPIC_COS_SCALING is undefined.
139     C Has no effect on vector invariant momentum equations.
140     C Setting this flag here affects both momentum and tracer equation unless
141     C it is set/unset again in other header fields (e.g., GAD_OPTIONS.h).
142     C The definition of the flag is commented to avoid interference with
143     C such other header files.
144     C#define COSINEMETH_III
145    
146     C o Use "OLD" UV discretisation near boundaries (*not* recommended)
147     C Note - only works with pkg/mom_fluxform and "no_slip_sides=.FALSE."
148     C because the old code did not have no-slip BCs
149     #undef OLD_ADV_BCS
150    
151     C o Use LONG.bin, LATG.bin, etc., initialization for ini_curviliear_grid.F
152     C Default is to use "new" grid files (OLD_GRID_IO undef) but OLD_GRID_IO
153     C is still useful with, e.g., single-domain curvilinear configurations.
154     #undef OLD_GRID_IO
155    
156     C o Use thsice+seaice (old) call sequence: ice-Dyn,ice-Advect,ice-Thermo(thsice)
157     C as opposed to new sequence: ice-Thermo(thsice),ice-Dyn,ice-Advect
158     #undef OLD_THSICE_CALL_SEQUENCE
159    
160     C o Use old EXTERNAL_FORCING_U,V,T,S subroutines (for backward compatibility)
161     #undef USE_OLD_EXTERNAL_FORCING
162    
163     C-- Other option files:
164    
165     C o Execution environment support options
166     #include "CPP_EEOPTIONS.h"
167    
168     C o Include/exclude single header file containing multiple packages options
169     C (AUTODIFF, COST, CTRL, ECCO, EXF ...) instead of the standard way where
170     C each of the above pkg get its own options from its specific option file.
171     C Although this method, inherited from ECCO setup, has been traditionally
172     C used for all adjoint built, work is in progress to allow to use the
173     C standard method also for adjoint built.
174     c#ifdef PACKAGES_CONFIG_H
175     c# include "ECCO_CPPOPTIONS.h"
176     c#endif
177    
178     #endif /* CPP_OPTIONS_H */

  ViewVC Help
Powered by ViewVC 1.1.22