/[MITgcm]/MITgcm/model/inc/PARAMS.h
ViewVC logotype

Annotation of /MITgcm/model/inc/PARAMS.h

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


Revision 1.115 - (hide annotations) (download)
Sat Jun 26 02:37:17 2004 UTC (19 years, 10 months ago) by jmc
Branch: MAIN
Changes since 1.114: +11 -4 lines
File MIME type: text/plain
T & S: separate Vert.Advec.Scheme from horizontal Advec.Scheme

1 jmc 1.115 C $Header: /u/gcmpack/MITgcm/model/inc/PARAMS.h,v 1.114 2004/06/24 20:25:44 afe Exp $
2 mlosch 1.74 C $Name: $
3 cnh 1.1 C
4 cnh 1.63 CBOP
5     C !ROUTINE: PARAMS.h
6     C !INTERFACE:
7     C include PARAMS.h
8     C !DESCRIPTION: \bv
9     C *==========================================================*
10     C | PARAMS.h
11     C | o Header file defining model "parameters".
12     C *==========================================================*
13     C | The values from the model standard input file are
14     C | stored into the variables held here. Notes describing
15     C | the parameters can also be found here.
16     C *==========================================================*
17     C \ev
18     CEOP
19 cnh 1.13
20     C Macros for special grid options
21     #include "PARAMS_MACROS.h"
22 cnh 1.1
23     C-- Contants
24     C Useful physical values
25     Real*8 PI
26     PARAMETER ( PI = 3.14159265358979323844D0 )
27     Real*8 deg2rad
28     PARAMETER ( deg2rad = 2.D0*PI/360.D0 )
29    
30 cnh 1.7 C Symbolic values
31 cnh 1.63 C precXXXX :: Used to indicate what precision to use for
32 cnh 1.7 C dumping model state.
33     INTEGER precFloat32
34 adcroft 1.36 PARAMETER ( precFloat32 = 32 )
35 cnh 1.7 INTEGER precFloat64
36 adcroft 1.36 PARAMETER ( precFloat64 = 64 )
37 cnh 1.63 C UNSET_xxx :: Used to indicate variables that have not been given a value
38 cnh 1.28 Real*8 UNSET_FLOAT8
39     PARAMETER ( UNSET_FLOAT8 = 1.234567D5 )
40     Real*4 UNSET_FLOAT4
41     PARAMETER ( UNSET_FLOAT4 = 1.234567E5 )
42     _RL UNSET_RL
43     PARAMETER ( UNSET_RL = 1.234567D5 )
44     _RS UNSET_RS
45     PARAMETER ( UNSET_RS = 1.234567E5 )
46     INTEGER UNSET_I
47     PARAMETER ( UNSET_I = 123456789 )
48 cnh 1.7
49     C Checkpoint data
50     INTEGER maxNoChkptLev
51     PARAMETER ( maxNoChkptLev = 2 )
52    
53 cnh 1.1 C-- COMMON /PARM_C/ Character valued parameters used by the model.
54 cnh 1.63 C checkPtSuff :: List of checkpoint file suffices
55     C bathyFile :: File containing bathymetry. If not defined bathymetry
56 cnh 1.16 C is taken from inline function.
57 cnh 1.63 C topoFile :: File containing the topography of the surface (unit=m)
58 jmc 1.55 C (mainly used for the atmosphere = ground height).
59 cnh 1.63 C hydrogThetaFile :: File containing initial hydrographic data for potential
60 cnh 1.16 C temperature.
61 cnh 1.63 C hydrogSaltFile :: File containing initial hydrographic data for salinity.
62     C zonalWindFile :: File containing zonal wind data
63     C meridWindFile :: File containing meridional wind data
64     C thetaClimFile :: File containing theta climataology used
65 cnh 1.18 C in relaxation term -lambda(theta-theta*)
66 cnh 1.63 C saltClimFile :: File containing salt climataology used
67 cnh 1.18 C in relaxation term -lambda(salt-salt*)
68 cnh 1.63 C surfQfile :: File containing surface heat flux
69     C surfQswfile :: File containing surface shortwave radiation
70     C dQdTfile :: File containing thermal relaxation coefficient
71     C EmPmRfile :: File containing surface fresh water flux
72 mlosch 1.73 C pLoadFile :: File containing pressure loading
73 cnh 1.63 C buoyancyRelation :: Flag used to indicate which relation to use to
74 cnh 1.26 C get buoyancy.
75 mlosch 1.74 C eosType :: choose the equation of state:
76 jmc 1.87 C LINEAR, POLY3, UNESCO, JMD95Z, JMD95P, MDJWF, IDEALGAS
77 cnh 1.16 COMMON /PARM_C/ checkPtSuff,
78 jmc 1.55 & bathyFile, topoFile,
79     & hydrogThetaFile, hydrogSaltFile,
80 cnh 1.18 & zonalWindFile, meridWindFile, thetaClimFile,
81 adcroft 1.37 & saltClimFile, buoyancyRelation,
82 heimbach 1.45 & EmPmRfile, surfQfile, surfQswfile,
83 heimbach 1.50 & uVelInitFile, vVelInitFile, pSurfInitFile,
84 mlosch 1.74 & dQdTfile, ploadFile,
85 heimbach 1.92 & eosType, pickupSuff,
86 afe 1.114 & mdsioLocalDir, tCyl
87 cnh 1.7 CHARACTER*(5) checkPtSuff(maxNoChkptLev)
88 jmc 1.55 CHARACTER*(MAX_LEN_FNAM) bathyFile, topoFile
89 cnh 1.16 CHARACTER*(MAX_LEN_FNAM) hydrogThetaFile
90     CHARACTER*(MAX_LEN_FNAM) hydrogSaltFile
91     CHARACTER*(MAX_LEN_FNAM) zonalWindFile
92     CHARACTER*(MAX_LEN_FNAM) meridWindFile
93 cnh 1.18 CHARACTER*(MAX_LEN_FNAM) thetaClimFile
94     CHARACTER*(MAX_LEN_FNAM) saltClimFile
95 adcroft 1.37 CHARACTER*(MAX_LEN_FNAM) surfQfile
96 heimbach 1.45 CHARACTER*(MAX_LEN_FNAM) surfQswfile
97 adcroft 1.37 CHARACTER*(MAX_LEN_FNAM) EmPmRfile
98 cnh 1.26 CHARACTER*(MAX_LEN_FNAM) buoyancyRelation
99 adcroft 1.42 CHARACTER*(MAX_LEN_FNAM) uVelInitFile
100     CHARACTER*(MAX_LEN_FNAM) vVelInitFile
101 adcroft 1.43 CHARACTER*(MAX_LEN_FNAM) pSurfInitFile
102 heimbach 1.50 CHARACTER*(MAX_LEN_FNAM) dQdTfile
103 mlosch 1.73 CHARACTER*(MAX_LEN_FNAM) ploadFile
104 heimbach 1.92 CHARACTER*(MAX_LEN_FNAM) mdsioLocalDir
105 mlosch 1.74 CHARACTER*(6) eosType
106 adcroft 1.90 CHARACTER*(10) pickupSuff
107 afe 1.114 _RL tCyl
108 cnh 1.7
109 cnh 1.1 C-- COMMON /PARM_I/ Integer valued parameters used by the model.
110 cnh 1.63 C cg2dMaxIters :: Maximum number of iterations in the
111 cnh 1.1 C two-dimensional con. grad solver.
112 cnh 1.63 C cg2dChkResFreq :: Frequency with which to check residual
113 cnh 1.1 C in con. grad solver.
114 cnh 1.63 C cg3dMaxIters :: Maximum number of iterations in the
115 cnh 1.33 C three-dimensional con. grad solver.
116 cnh 1.63 C cg3dChkResFreq :: Frequency with which to check residual
117 cnh 1.33 C in con. grad solver.
118 cnh 1.63 C nIter0 :: Start time-step number of for this run
119     C nTimeSteps :: Number of timesteps to execute
120     C numStepsPerPickup :: For offline setup. Frequency of pickup
121 cnh 1.1 C of flow fields.
122 cnh 1.63 C writeStatePrec :: Precision used for writing model state.
123     C writeBinaryPrec :: Precision used for writing binary files
124     C readBinaryPrec :: Precision used for reading binary files
125     C nCheckLev :: Holds current checkpoint level
126     C nonlinFreeSurf :: option related to non-linear free surface
127 jmc 1.55 C =0 Linear free surface ; >0 Non-linear
128 jmc 1.84 C select_rStar :: option related to r* vertical coordinate
129     C =0 (default) use r coord. ; > 0 use r*
130 jmc 1.115 C tempAdvScheme :: Temp. Horiz.Advection scheme selector
131     C tempVertAdvScheme :: Temp. Vert. Advection scheme selector
132     C saltAdvScheme :: Salt. Horiz.advection scheme selector
133     C saltVertAdvScheme :: Salt. Vert. Advection scheme selector
134     C debugLevel :: debug level selector: higher -> more writing
135 cnh 1.34
136 cnh 1.1 COMMON /PARM_I/
137     & cg2dMaxIters,
138     & cg2dChkResFreq,
139 cnh 1.33 & cg3dMaxIters,
140     & cg3dChkResFreq,
141 adcroft 1.41 & nIter0, nTimeSteps, nEndIter,
142 cnh 1.7 & numStepsPerPickup,
143     & writeStatePrec, nCheckLev,
144 cnh 1.34 & writeBinaryPrec, readBinaryPrec,
145 jmc 1.84 & nonlinFreeSurf, select_rStar,
146 jmc 1.115 & tempAdvScheme, tempVertAdvScheme,
147     & saltAdvScheme, saltVertAdvScheme,
148     & tracerAdvScheme,
149 heimbach 1.92 & debugLevel
150 cnh 1.1 INTEGER cg2dMaxIters
151     INTEGER cg2dChkResFreq
152 cnh 1.33 INTEGER cg3dMaxIters
153     INTEGER cg3dChkResFreq
154 cnh 1.1 INTEGER nIter0
155     INTEGER nTimeSteps
156 adcroft 1.41 INTEGER nEndIter
157 cnh 1.1 INTEGER numStepsPerPickup
158 cnh 1.7 INTEGER writeStatePrec
159     INTEGER writeBinaryPrec
160     INTEGER readBinaryPrec
161     INTEGER nCheckLev
162 jmc 1.55 INTEGER nonlinFreeSurf
163 jmc 1.84 INTEGER select_rStar
164 jmc 1.115 INTEGER tempAdvScheme, tempVertAdvScheme
165     INTEGER saltAdvScheme, saltVertAdvScheme
166 adcroft 1.57 INTEGER tracerAdvScheme
167 heimbach 1.92 INTEGER debugLevel
168    
169     C
170     INTEGER debLevZero
171     PARAMETER(debLevZero=0)
172     INTEGER debLevA
173     PARAMETER(debLevA=1)
174     INTEGER debLevB
175     PARAMETER(debLevB=2)
176 cnh 1.1
177     C-- COMMON /PARM_L/ Logical valued parameters used by the model.
178 cnh 1.63 C usingCartesianGrid :: If TRUE grid generation will be in a cartesian
179 cnh 1.1 C coordinate frame.
180 cnh 1.63 C usingSphericalPolarGrid :: If TRUE grid generation will be in a
181 cnh 1.1 C spherical polar frame.
182 afe 1.114 C usingCylindricalGrid :: If TRUE grid generation will be Cylindrical
183 cnh 1.63 C no_slip_sides :: Impose "no-slip" at lateral boundaries.
184     C no_slip_bottom :: Impose "no-slip" at bottom boundary.
185     C staggerTimeStep :: enable a Stagger time stepping T,S Rho then U,V
186     C momViscosity :: Flag which turns momentum friction terms on and off.
187     C momAdvection :: Flag which turns advection of momentum on and off.
188     C momForcing :: Flag which turns external forcing of momentum on
189 cnh 1.1 C and off.
190 cnh 1.63 C momPressureForcing :: Flag which turns pressure term in momentum equation
191 cnh 1.9 C on and off.
192 cnh 1.63 C metricTerms :: Flag which turns metric terms on or off.
193     C usingSphericalPolarMTerms :: If TRUE use spherical polar metric terms.
194 adcroft 1.77 C useNHMTerms :: If TRUE use non-hydrostatic metric terms.
195 cnh 1.63 C useCoriolis :: Flag which turns the coriolis terms on and off.
196     C tempDiffusion :: Flag which turns diffusion of temperature on
197 cnh 1.1 C and off.
198 cnh 1.63 C tempAdvection :: Flag which turns advection of temperature on
199 cnh 1.1 C and off.
200 cnh 1.63 C tempForcing :: Flag which turns external forcing of temperature on
201 cnh 1.1 C and off.
202 jmc 1.71 C saltDiffusion :: Flag which turns diffusion of salinity on
203 cnh 1.1 C and off.
204 jmc 1.71 C saltAdvection :: Flag which turns advection of salinity on
205 cnh 1.1 C and off.
206 jmc 1.71 C saltForcing :: Flag which turns external forcing of salinity on
207 cnh 1.1 C and off.
208 jmc 1.71 C useRealFreshWaterFlux :: if True (=Natural BCS), treats P+R-E flux
209     C as a real Fresh Water (=> changes the Sea Level)
210     C if F, converts P+R-E to salt flux (no SL effect)
211 cnh 1.63 C rigidLid :: Set to true to use rigid lid
212     C implicitFreeSurface :: Set to true to use implcit free surface
213     C exactConserv :: Set to true to conserve exactly the total Volume
214     C uniformLin_PhiSurf :: Set to true to use a uniform Bo_surf in the
215 jmc 1.55 C linear relation Phi_surf = Bo_surf*eta
216 cnh 1.63 C momStepping :: Turns momentum equation time-stepping off
217     C tempStepping :: Turns temperature equation time-stepping off
218     C saltStepping :: Turns salinity equation time-stepping off
219     C tr1Stepping :: Turns passive tracer 1 time-stepping on/off
220     C useConstantF :: Coriolis parameter set to f0
221     C useBetaPlaneF :: Coriolis parameter set to f0 + beta.y
222     C useSphereF :: Coriolis parameter set to 2.omega.sin(phi)
223 jmc 1.89 C useCDscheme :: use CD-scheme to calculate Coriolis terms.
224 jmc 1.71 C useJamartWetPoints :: Use wet-point method for Coriolis (Jamart and Ozer, 1986)
225 adcroft 1.113 C useJamartMomAdv :: Use wet-point method for V.I. non-linear term
226 adcroft 1.111 C SadournyCoriolis :: use the enstrophy conserving scheme by Sadourny
227     C upwindVorticity :: bias interpolation of vorticity in the Coriolis term
228     C highOrderVorticity :: use 3rd/4th order interp. of vorticity in Coriolis
229     C useAbsVorticity :: work with f+zeta in Coriolis terms
230 cnh 1.63 C implicitDiffusion :: Turns implicit vertical diffusion on
231     C implicitViscosity :: Turns implicit vertical viscosity on
232 jmc 1.100 C tempImplVertAdv :: Turns on implicit vertical advection for Temperature
233     C saltImplVertAdv :: Turns on implicit vertical advection for Salinity
234     C momImplVertAdv :: Turns on implicit vertical advection for Momentum
235 jmc 1.71 C multiDimAdvection :: Flag that enable multi-dimension advection
236     C forcing_In_AB :: if False, put forcing (Temp,Salt,Tracers) contribution
237     C out off Adams-Bashforth time stepping.
238 cnh 1.63 C doThetaClimRelax :: Set true if relaxation to temperature
239 cnh 1.18 C climatology is required.
240 cnh 1.63 C doSaltClimRelax :: Set true if relaxation to salinity
241 cnh 1.18 C climatology is required.
242 cnh 1.63 C periodicExternalForcing :: Set true if forcing is time-dependant
243     C usingPCoords :: Set to indicate that we are working in pressure
244 jmc 1.87 C coords. (jmc: is it still used ?)
245 cnh 1.63 C usingZCoords :: Set to indicate that we are working in height
246 jmc 1.87 C coords. (jmc: is it still used ?)
247     C useDynP_inEos_Zc :: use the dynamical pressure in EOS (with Z-coord.)
248     C this requires specific code for restart & exchange
249 jmc 1.70 C setCenterDr :: set cell Center depth and put Interface at the middle
250 cnh 1.63 C nonHydrostatic :: Using non-hydrostatic terms
251 adcroft 1.79 C quasiHydrostatic :: Using non-hydrostatic terms in hydrostatic algorithm
252 cnh 1.63 C globalFiles :: Selects between "global" and "tiled" files
253 dimitri 1.85 C useSingleCpuIO :: On SGI platforms, option globalFiles is either
254     C slow (f77) or does not work (f90). When
255     C useSingleCpuIO is set, mdsio_writefield.F
256     C outputs from master mpi process only.
257 jmc 1.97 C allowFreezing :: Allows surface water to freeze and form ice
258     C useOldFreezing :: use the old version (before checkpoint52a_pre, 2003-11-12)
259 cnh 1.63 C groundAtK1 :: put the surface(k=1) at the Lower Boundary (=ground)
260 cnh 1.1 COMMON /PARM_L/ usingCartesianGrid, usingSphericalPolarGrid,
261 afe 1.114 & usingCurvilinearGrid, usingCylindricalGrid,
262 adcroft 1.36 & no_slip_sides,no_slip_bottom,
263 adcroft 1.46 & staggerTimeStep,
264 cnh 1.33 & momViscosity, momAdvection, momForcing, useCoriolis,
265 adcroft 1.58 & momPressureForcing, vectorInvariantMomentum,
266     & tempDiffusion, tempAdvection, tempForcing,
267 cnh 1.8 & saltDiffusion, saltAdvection, saltForcing,
268 jmc 1.68 & useRealFreshWaterFlux,
269 jmc 1.55 & rigidLid, implicitFreeSurface, exactConserv, uniformLin_PhiSurf,
270 heimbach 1.56 & momStepping, tempStepping, saltStepping, tr1Stepping,
271 adcroft 1.77 & metricTerms, usingSphericalPolarMTerms, useNHMTerms,
272 cnh 1.15 & useConstantF, useBetaPlaneF, useSphereF,
273 jmc 1.89 & useCDscheme,
274 adcroft 1.113 & useEnergyConservingCoriolis, useJamartWetPoints, useJamartMomAdv,
275 adcroft 1.111 & SadournyCoriolis, upwindVorticity, highOrderVorticity,
276     & useAbsVorticity,
277 adcroft 1.40 & implicitDiffusion, implicitViscosity,
278 jmc 1.100 & tempImplVertAdv, saltImplVertAdv, momImplVertAdv,
279 jmc 1.71 & multiDimAdvection, forcing_In_AB,
280 heimbach 1.56 & doThetaClimRelax, doSaltClimRelax, doTr1ClimRelax,
281 jmc 1.70 & periodicExternalForcing,
282 jmc 1.87 & usingPCoords, usingZCoords, useDynP_inEos_Zc, setCenterDr,
283 dimitri 1.85 & nonHydrostatic, quasiHydrostatic, globalFiles, useSingleCpuIO,
284 jmc 1.97 & allowFreezing, useOldFreezing, groundAtK1,
285 heimbach 1.56 & usePickupBeforeC35, debugMode,
286 jmc 1.71 & readPickupWithTracer, writePickupWithTracer
287 cnh 1.1 LOGICAL usingCartesianGrid
288     LOGICAL usingSphericalPolarGrid
289 afe 1.114 LOGICAL usingCylindricalGrid
290 adcroft 1.52 LOGICAL usingCurvilinearGrid
291 cnh 1.15 LOGICAL usingSphericalPolarMTerms
292 adcroft 1.77 LOGICAL useNHMTerms
293 adcroft 1.36 LOGICAL no_slip_sides
294     LOGICAL no_slip_bottom
295 adcroft 1.46 LOGICAL staggerTimeStep
296 cnh 1.1 LOGICAL momViscosity
297     LOGICAL momAdvection
298     LOGICAL momForcing
299 cnh 1.9 LOGICAL momPressureForcing
300 cnh 1.1 LOGICAL useCoriolis
301 adcroft 1.58 LOGICAL vectorInvariantMomentum
302 cnh 1.1 LOGICAL tempDiffusion
303     LOGICAL tempAdvection
304     LOGICAL tempForcing
305     LOGICAL saltDiffusion
306     LOGICAL saltAdvection
307     LOGICAL saltForcing
308 jmc 1.68 LOGICAL useRealFreshWaterFlux
309 adcroft 1.52 LOGICAL rigidLid
310 cnh 1.8 LOGICAL implicitFreeSurface
311 adcroft 1.52 LOGICAL exactConserv
312 jmc 1.55 LOGICAL uniformLin_PhiSurf
313 cnh 1.10 LOGICAL momStepping
314     LOGICAL tempStepping
315 adcroft 1.17 LOGICAL saltStepping
316 heimbach 1.56 LOGICAL tr1Stepping
317 cnh 1.15 LOGICAL metricTerms
318     LOGICAL useConstantF
319     LOGICAL useBetaPlaneF
320     LOGICAL useSphereF
321 jmc 1.89 LOGICAL useCDscheme
322 jmc 1.71 LOGICAL useEnergyConservingCoriolis
323     LOGICAL useJamartWetPoints
324 adcroft 1.113 LOGICAL useJamartMomAdv
325 adcroft 1.111 LOGICAL SadournyCoriolis
326     LOGICAL upwindVorticity
327     LOGICAL highOrderVorticity
328     LOGICAL useAbsVorticity
329 adcroft 1.14 LOGICAL implicitDiffusion
330 adcroft 1.40 LOGICAL implicitViscosity
331 jmc 1.100 LOGICAL tempImplVertAdv
332     LOGICAL saltImplVertAdv
333     LOGICAL momImplVertAdv
334 jmc 1.71 LOGICAL multiDimAdvection
335     LOGICAL forcing_In_AB
336 cnh 1.18 LOGICAL doThetaClimRelax
337     LOGICAL doSaltClimRelax
338 heimbach 1.56 LOGICAL doTr1ClimRelax
339 adcroft 1.19 LOGICAL periodicExternalForcing
340 cnh 1.29 LOGICAL usingPCoords
341     LOGICAL usingZCoords
342 jmc 1.87 LOGICAL useDynP_inEos_Zc
343 jmc 1.70 LOGICAL setCenterDr
344 adcroft 1.37 LOGICAL nonHydrostatic
345 adcroft 1.79 LOGICAL quasiHydrostatic
346 adcroft 1.38 LOGICAL globalFiles
347 dimitri 1.85 LOGICAL useSingleCpuIO
348 adcroft 1.38 LOGICAL allowFreezing
349 jmc 1.97 LOGICAL useOldFreezing
350 adcroft 1.46 LOGICAL groundAtK1
351 heimbach 1.51 LOGICAL usePickupBeforeC35
352 adcroft 1.54 LOGICAL debugMode
353 heimbach 1.56 LOGICAL readPickupWithTracer
354     LOGICAL writePickupWithTracer
355 cnh 1.1
356     C-- COMMON /PARM_R/ "Real" valued parameters used by the model.
357 adcroft 1.52 C gg2dTargetResidual
358 cnh 1.63 C :: Target residual for cg2d solver; no unit (RHS normalisation)
359 adcroft 1.52 C cg2dTargetResWunit
360 cnh 1.63 C :: Target residual for cg2d solver; W unit (No RHS normalisation)
361 cnh 1.33 C cg3dTargetResidual
362 cnh 1.63 C :: Target residual for cg3d solver.
363     C cg2dpcOffDFac :: Averaging weight for preconditioner off-diagonal.
364 cnh 1.7 C Note. 20th May 1998
365     C I made a weird discovery! In the model paper we argue
366     C for the form of the preconditioner used here ( see
367     C A Finite-volume, Incompressible Navier-Stokes Model
368     C ...., Marshall et. al ). The algebra gives a simple
369     C 0.5 factor for the averaging of ac and aCw to get a
370     C symmettric pre-conditioner. By using a factor of 0.51
371     C i.e. scaling the off-diagonal terms in the
372     C preconditioner down slightly I managed to get the
373     C number of iterations for convergence in a test case to
374     C drop form 192 -> 134! Need to investigate this further!
375     C For now I have introduced a parameter cg2dpcOffDFac which
376     C defaults to 0.51 but can be set at runtime.
377 cnh 1.63 C delR :: Vertical grid spacing ( units of r ).
378 jmc 1.70 C delRc :: Vertical grid spacing between cell centers (r unit).
379 cnh 1.63 C delX :: Separation between cell faces (m) or (deg), depending
380 cnh 1.1 C delY on input flags.
381 cnh 1.63 C gravity :: Accel. due to gravity ( m/s^2 )
382 cnh 1.32 C recip_gravity and its inverse
383 cnh 1.63 C gBaro :: Accel. due to gravity used in barotropic equation ( m/s^2 )
384 mlosch 1.75 C rhoNil :: Reference density for the linear equation of state
385 cnh 1.63 C rhoConst :: Vertically constant reference density
386 mlosch 1.75 C rhoConstFresh :: Constant reference density for fresh water (rain)
387 cnh 1.63 C startTime :: Start time for model ( s )
388     C phiMin :: Latitude of southern most cell face.
389     C thetaMin :: Longitude of western most cell face (this
390 cnh 1.1 C is an "inert" parameter but it is included
391     C to make geographical references simple.)
392 cnh 1.63 C rSphere :: Radius of sphere for a spherical polar grid ( m ).
393     C recip_RSphere :: Reciprocal radius of sphere ( m ).
394     C f0 :: Reference coriolis parameter ( 1/s )
395 cnh 1.1 C ( Southern edge f for beta plane )
396 cnh 1.63 C beta :: df/dy ( s^-1.m^-1 )
397     C omega :: Angular velocity ( rad/s )
398 jmc 1.88 C rotationPeriod :: Rotation period (s) (= 2.pi/omega)
399 cnh 1.63 C viscAh :: Eddy viscosity coeff. for mixing of
400 cnh 1.1 C momentum laterally ( m^2/s )
401 cnh 1.63 C viscAr :: Eddy viscosity coeff. for mixing of
402 cnh 1.24 C momentum vertically ( units of r^2/s )
403 cnh 1.63 C viscA4 :: Biharmonic viscosity coeff. for mixing of
404 cnh 1.1 C momentum laterally ( m^4/s )
405 adcroft 1.110 C viscC2leith :: Leith non-dimensional viscosity factor
406 adcroft 1.102 C viscAhMax :: Maximum eddy viscosity coeff. for mixing of
407     C momentum laterally ( m^2/s )
408     C viscA4Max :: Maximum biharmonic viscosity coeff. for mixing of
409     C momentum laterally ( m^4/s )
410     C viscAhGrid:: non-dimensional grid-size dependent viscosity
411     C viscA4Grid:: non-dimensional grid-size dependent bi-harmonic viscosity
412 adcroft 1.110 C viscC4leith :: Leith non-dimensional viscosity factor
413 cnh 1.63 C diffKhT :: Laplacian diffusion coeff. for mixing of
414 cnh 1.1 C heat laterally ( m^2/s )
415 cnh 1.63 C diffKrT :: Laplacian diffusion coeff. for mixing of
416 cnh 1.24 C heat vertically ( units of r^2/s )
417 cnh 1.63 C diffK4T :: Biharmonic diffusion coeff. for mixing of
418 cnh 1.1 C heat laterally ( m^4/s )
419 cnh 1.63 C diffKhS :: Laplacian diffusion coeff. for mixing of
420 cnh 1.1 C salt laterally ( m^2/s )
421 cnh 1.63 C diffKrS :: Laplacian diffusion coeff. for mixing of
422 cnh 1.24 C salt vertically ( units of r^2/s )
423 cnh 1.63 C diffK4S :: Biharmonic diffusion coeff. for mixing of
424 cnh 1.1 C salt laterally ( m^4/s )
425 adcroft 1.112 C diffKrBL79surf :: T/S surface diffusivity (m^2/s) Bryan and Lewis, 1979
426     C diffKrBL79deep :: T/S deep diffusivity (m^2/s) Bryan and Lewis, 1979
427     C diffKrBL79scl :: depth scale for arctan fn (m) Bryan and Lewis, 1979
428     C diffKrBL79Ho :: depth offset for arctan fn (m) Bryan and Lewis, 1979
429 cnh 1.63 C deltaT :: Default timestep ( s )
430     C deltaTClock :: Timestep used as model "clock". This determines the
431 cnh 1.7 C IO frequencies and is used in tagging output. It can
432     C be totally different to the dynamical time. Typically
433     C it will be the deep-water timestep for accelerated runs.
434     C Frequency of checkpointing and dumping of the model state
435     C are referenced to this clock. ( s )
436 cnh 1.63 C deltaTMom :: Timestep for momemtum equations ( s )
437     C deltaTtracer :: Timestep for tracer equations ( s )
438 adcroft 1.72 C deltaTfreesurf :: Timestep for free-surface equation ( s )
439 cnh 1.63 C freesurfFac :: Parameter to turn implicit free surface term on or off
440 cnh 1.8 C freesurfac = 1. uses implicit free surface
441     C freesurfac = 0. uses rigid lid
442 cnh 1.63 C implicSurfPress :: parameter of the Crank-Nickelson time stepping :
443 jmc 1.48 C Implicit part of Surface Pressure Gradient ( 0-1 )
444 cnh 1.63 C implicDiv2Dflow :: parameter of the Crank-Nickelson time stepping :
445 jmc 1.48 C Implicit part of barotropic flow Divergence ( 0-1 )
446 cnh 1.63 C hFacMin :: Minimum fraction size of a cell (affects hFacC etc...)
447     C hFacMinDz :: Minimum dimesional size of a cell (affects hFacC etc..., m)
448     C hFacMinDp :: Minimum dimesional size of a cell (affects hFacC etc..., Pa)
449     C hFacMinDr :: Minimum dimesional size of a cell (affects hFacC etc..., units of r)
450     C hFacInf :: Threshold (inf and sup) for fraction size of surface cell
451 adcroft 1.52 C hFacSup that control vanishing and creating levels
452 cnh 1.63 C tauCD :: CD scheme coupling timescale ( 1/s )
453     C rCD :: CD scheme normalised coupling parameter ( 0-1 )
454     C startTime :: Starting time for this integration ( s ).
455     C endTime :: Ending time for this integration ( s ).
456     C chkPtFreq :: Frequency of rolling check pointing ( s ).
457     C pChkPtFreq :: Frequency of permanent check pointing ( s ).
458     C dumpFreq :: Frequency with which model state is written to
459 cnh 1.24 C post-processing files ( s ).
460 cnh 1.63 C diagFreq :: Frequency with which model writes diagnostic output
461 adcroft 1.59 C of intermediate quantities.
462 cnh 1.63 C afFacMom :: Advection of momentum term tracer parameter
463     C vfFacMom :: Momentum viscosity tracer parameter
464     C pfFacMom :: Momentum pressure forcing tracer parameter
465     C cfFacMom :: Coriolis term tracer parameter
466     C foFacMom :: Momentum forcing tracer parameter
467     C mtFacMom :: Metric terms tracer parameter
468     C cosPower :: Power of cosine of latitude to multiply viscosity
469     C cAdjFreq :: Frequency of convective adjustment
470 cnh 1.24 C
471 jmc 1.76 C taveFreq :: Frequency with which time-averaged model state
472     C is written to post-processing files ( s ).
473     C tave_lastIter :: (for state variable only) fraction of the last time
474     C step (of each taveFreq period) put in the time average.
475     C (fraction for 1rst iter = 1 - tave_lastIter)
476 cnh 1.63 C tauThetaClimRelax :: Relaxation to climatology time scale ( s ).
477     C lambdaThetaClimRelax :: Inverse time scale for relaxation ( 1/s ).
478     C tauSaltClimRelax :: Relaxation to climatology time scale ( s ).
479     C lambdaSaltClimRelax :: Inverse time scale for relaxation ( 1/s ).
480 jmc 1.95 C latBandClimRelax :: latitude band where Relaxation to Clim. is applied,
481     C i.e. where |yC| <= latBandClimRelax
482 cnh 1.63 C externForcingPeriod :: Is the period of which forcing varies (eg. 1 month)
483     C externForcingCycle :: Is the repeat time of the forcing (eg. 1 year)
484 adcroft 1.19 C (note: externForcingCycle must be an integer
485     C number times externForcingPeriod)
486 jmc 1.68 C convertFW2Salt :: salinity, used to convert Fresh-Water Flux to Salt Flux
487     C (use model surface (local) value if set to -1)
488     C temp_EvPrRn :: temperature of Rain & Evap.
489     C salt_EvPrRn :: salinity of Rain & Evap.
490     C trac_EvPrRn :: tracer concentration in Rain & Evap.
491     C (notes: a) tracer content of Rain/Evap only used if both
492     C NonLin_FrSurf & useRealFreshWater are set.
493     C b) use model surface (local) value if set to UNSET_RL)
494 cnh 1.63 C horiVertRatio :: Ratio on units in vertical to units in horizontal.
495 cnh 1.31 C recip_horiVertRatio ( 1 if horiz in m and vertical in m ).
496 cnh 1.30 C ( g*rho if horiz in m and vertical in Pa ).
497 cnh 1.63 C Ro_SeaLevel :: standard position of Sea-Level in "R" coordinate, used as
498 adcroft 1.46 C starting value (k=1) for vertical coordinate (rf(1)=Ro_SeaLevel)
499 cnh 1.63 C bottomDragLinear :: Drag coefficient built in to core dynamics
500 adcroft 1.64 C --"-"-- Quadratic ( linear: 1/s, quadratic: 1/m )
501 adcroft 1.52 COMMON /PARM_R/ cg2dTargetResidual, cg2dTargetResWunit,
502     & cg2dpcOffDFac, cg3dTargetResidual,
503 jmc 1.96 & delR, delRc, delX, delY,
504 adcroft 1.72 & deltaT, deltaTmom, deltaTtracer, deltaTfreesurf, deltaTClock,
505     & abeps, startTime,
506 adcroft 1.52 & phiMin, thetaMin, rSphere, recip_RSphere, f0, beta,
507 adcroft 1.78 & fCori, fCoriG, fCoriCos,
508 adcroft 1.110 & viscAh, viscAhMax, viscAhGrid, viscC2leith,
509     & viscA4, viscA4Max, viscA4Grid, viscC4leith,
510 adcroft 1.102 & viscAr, viscAstrain, viscAtension,
511 jmc 1.96 & diffKhT, diffK4T, diffKrT,
512     & diffKhS, diffK4S, diffKrS,
513 adcroft 1.112 & diffKrBL79surf, diffKrBL79deep, diffKrBL79scl, diffKrBL79Ho,
514 jmc 1.48 & delT, tauCD, rCD, freeSurfFac, implicSurfPress, implicDiv2Dflow,
515 adcroft 1.52 & hFacMin, hFacMinDz, hFacInf, hFacSup,
516 cnh 1.32 & gravity, recip_Gravity, gBaro, rhonil, recip_rhonil,
517 mlosch 1.75 & recip_rhoConst, rhoConst,
518 jmc 1.76 & rhoConstFresh, convertEmP2rUnit, tRef, sRef,
519 heimbach 1.103 & endTime, chkPtFreq, pchkPtFreq, dumpFreq, adjDumpFreq,
520 jmc 1.76 & diagFreq, taveFreq, tave_lastIter, monitorFreq,
521 cnh 1.15 & afFacMom, vfFacMom, pfFacMom, cfFacMom, foFacMom, mtFacMom,
522 jmc 1.88 & cosPower, cAdjFreq, omega, rotationPeriod,
523 heimbach 1.56 & tauThetaClimRelax, lambdaThetaClimRelax,
524 adcroft 1.19 & tauSaltClimRelax, lambdaSaltClimRelax,
525 jmc 1.95 & tauTr1ClimRelax, lambdaTr1ClimRelax, latBandClimRelax,
526 cnh 1.27 & externForcingCycle, externForcingPeriod,
527 jmc 1.68 & convertFW2Salt, temp_EvPrRn, salt_EvPrRn, trac_EvPrRn,
528 jmc 1.96 & hFacMinDr, hFacMinDp,
529 jmc 1.68 & horiVertRatio, recip_horiVertRatio,
530 jmc 1.67 & ivdc_kappa, Ro_SeaLevel,
531 adcroft 1.46 & bottomDragLinear,bottomDragQuadratic
532 cnh 1.27
533 adcroft 1.6 _RL cg2dTargetResidual
534 adcroft 1.52 _RL cg2dTargetResWunit
535 cnh 1.33 _RL cg3dTargetResidual
536 cnh 1.7 _RL cg2dpcOffDFac
537 cnh 1.25 _RL delR(Nr)
538 jmc 1.70 _RL delRc(Nr+1)
539 adcroft 1.6 _RL delX(Nx)
540     _RL delY(Ny)
541     _RL deltaT
542 cnh 1.7 _RL deltaTClock
543 adcroft 1.6 _RL deltaTmom
544     _RL deltaTtracer
545 adcroft 1.72 _RL deltaTfreesurf
546 adcroft 1.6 _RL abeps
547     _RL phiMin
548     _RL thetaMin
549     _RL rSphere
550 cnh 1.25 _RL recip_RSphere
551 adcroft 1.6 _RL f0
552 cnh 1.8 _RL freeSurfFac
553 jmc 1.48 _RL implicSurfPress
554     _RL implicDiv2Dflow
555 adcroft 1.22 _RL hFacMin
556     _RL hFacMinDz
557 cnh 1.28 _RL hFacMinDp
558 cnh 1.27 _RL hFacMinDr
559 adcroft 1.52 _RL hFacInf
560     _RL hFacSup
561 adcroft 1.6 _RL beta
562     _RL viscAh
563 adcroft 1.102 _RL viscAhMax
564     _RL viscAhGrid
565 adcroft 1.110 _RL viscC2leith
566 adcroft 1.60 _RL viscAstrain
567     _RL viscAtension
568 cnh 1.25 _RL viscAr
569 adcroft 1.6 _RL viscA4
570 adcroft 1.102 _RL viscA4Max
571     _RL viscA4Grid
572 adcroft 1.110 _RL viscC4leith
573 adcroft 1.6 _RL diffKhT
574 cnh 1.25 _RL diffKrT
575 adcroft 1.6 _RL diffK4T
576     _RL diffKhS
577 cnh 1.25 _RL diffKrS
578 adcroft 1.6 _RL diffK4S
579 adcroft 1.112 _RL diffKrBL79surf
580     _RL diffKrBL79deep
581     _RL diffKrBL79scl
582     _RL diffKrBL79Ho
583 adcroft 1.6 _RL delt
584     _RL tauCD
585     _RL rCD
586     _RL gravity
587 cnh 1.32 _RL recip_gravity
588 cnh 1.8 _RL gBaro
589 adcroft 1.6 _RL rhonil
590 cnh 1.25 _RL recip_rhonil
591     _RL rhoConst
592 cnh 1.26 _RL recip_rhoConst
593 mlosch 1.75 _RL rhoConstFresh
594 jmc 1.76 _RL convertEmP2rUnit
595 cnh 1.25 _RL tRef(Nr)
596     _RL sRef(Nr)
597 adcroft 1.52 _RS fCori(1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
598     _RS fCoriG(1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
599 adcroft 1.78 _RS fCoriCos(1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
600 adcroft 1.6 _RL startTime
601     _RL endTime
602     _RL chkPtFreq
603 cnh 1.7 _RL pChkPtFreq
604 adcroft 1.6 _RL dumpFreq
605 heimbach 1.103 _RL adjDumpFreq
606 adcroft 1.59 _RL diagFreq
607 adcroft 1.20 _RL taveFreq
608 jmc 1.76 _RL tave_lastIter
609 adcroft 1.53 _RL monitorFreq
610 cnh 1.9 _RL afFacMom
611     _RL vfFacMom
612     _RL pfFacMom
613     _RL cfFacMom
614     _RL foFacMom
615 cnh 1.15 _RL mTFacMom
616 adcroft 1.39 _RL cosPower
617 cnh 1.9 _RL cAdjFreq
618 cnh 1.15 _RL omega
619 jmc 1.88 _RL rotationPeriod
620 cnh 1.18 _RL tauThetaClimRelax
621     _RL lambdaThetaClimRelax
622     _RL tauSaltClimRelax
623     _RL lambdaSaltClimRelax
624 heimbach 1.56 _RL tauTr1ClimRelax
625     _RL lambdaTr1ClimRelax
626 jmc 1.95 _RL latBandClimRelax
627 adcroft 1.19 _RL externForcingCycle
628     _RL externForcingPeriod
629 jmc 1.68 _RL convertFW2Salt
630     _RL temp_EvPrRn
631     _RL salt_EvPrRn
632     _RL trac_EvPrRn
633 cnh 1.30 _RL horiVertRatio
634 cnh 1.31 _RL recip_horiVertRatio
635 adcroft 1.41 _RL ivdc_kappa
636 adcroft 1.46 _RL Ro_SeaLevel
637     _RL bottomDragLinear
638     _RL bottomDragQuadratic
639 adcroft 1.6
640 jmc 1.91 C-- COMMON /PARM_A/ Thermodynamics constants ?
641     COMMON /PARM_A/ HeatCapacity_Cp,recip_Cp
642 adcroft 1.6 _RL HeatCapacity_Cp
643 adcroft 1.36 _RL recip_Cp
644 jmc 1.55
645 jmc 1.91 C-- COMMON /PARM_ATM/ Atmospheric physical parameters (Ideal Gas EOS, ...)
646     C celsius2K :: convert centigrade (Celsius) degree to Kelvin
647 jmc 1.83 C atm_Po :: standard reference pressure
648     C atm_Cp :: specific heat (Cp) of the (dry) air at constant pressure
649     C atm_Rd :: gas constant for dry air
650 cnh 1.63 C atm_kappa :: kappa = R/Cp (R: constant of Ideal Gas EOS)
651 jmc 1.94 C atm_Rq :: water vapour specific volume anomaly relative to dry air
652     C (e.g. typical value = (29/18 -1) 10^-3 with q [g/kg])
653 jmc 1.83 C integr_GeoPot :: option to select the way we integrate the geopotential
654 jmc 1.55 C (still a subject of discussions ...)
655 jmc 1.83 C selectFindRoSurf :: select the way surf. ref. pressure (=Ro_surf) is
656     C derived from the orography. Implemented: 0,1 (see INI_P_GROUND)
657 jmc 1.91 COMMON /PARM_ATM/
658     & celsius2K,
659 jmc 1.94 & atm_Cp, atm_Rd, atm_kappa, atm_Rq, atm_Po,
660 jmc 1.91 & integr_GeoPot, selectFindRoSurf
661     _RL celsius2K
662 jmc 1.94 _RL atm_Po, atm_Cp, atm_Rd, atm_kappa, atm_Rq
663 jmc 1.83 INTEGER integr_GeoPot, selectFindRoSurf
664 cnh 1.7
665 adcroft 1.44 C Logical flags for selecting packages
666 heimbach 1.45 LOGICAL useKPP
667     LOGICAL useGMRedi
668 adcroft 1.46 LOGICAL useOBCS
669 jmc 1.49 LOGICAL useAIM
670 jmc 1.91 LOGICAL useLand
671 heimbach 1.56 LOGICAL useGrdchk
672 heimbach 1.45 LOGICAL useECCO
673 adcroft 1.52 LOGICAL useSHAP_FILT
674 jmc 1.67 LOGICAL useZONAL_FILT
675 adcroft 1.62 LOGICAL useFLT
676 adcroft 1.69 LOGICAL usePTRACERS
677 dimitri 1.86 LOGICAL useSBO
678 heimbach 1.80 LOGICAL useSEAICE
679 jmc 1.98 LOGICAL useBulkForce
680     LOGICAL useThSIce
681 molod 1.99 LOGICAL usefizhi
682     LOGICAL usegridalt
683 molod 1.101 LOGICAL usediagnostics
684 heimbach 1.109 LOGICAL useEBM
685 adcroft 1.44 COMMON /PARM_PACKAGES/
686 jmc 1.91 & useKPP, useGMRedi, useOBCS, useAIM, useLand, useECCO,
687 adcroft 1.69 & useSHAP_FILT, useZONAL_FILT, useGrdchk, useFLT,
688 molod 1.101 & usePTRACERS, useSBO, useSEAICE, useThSIce, useBulkForce,
689 heimbach 1.109 & usefizhi, usegridalt, usediagnostics, useEBM
690 edhill 1.105
691     C Run-time flags for early-initialization of MNC
692     LOGICAL
693     & useMNC,
694 edhill 1.106 & mnc_use_indir, mnc_use_outdir, mnc_outdir_date,
695 edhill 1.108 & mnc_echo_gvtypes, mnc_pickup_write, mnc_pickup_read,
696 edhill 1.107 & mnc_use_for_mon
697 edhill 1.106 CHARACTER*(MAX_LEN_FNAM) mnc_outdir_str
698     CHARACTER*(MAX_LEN_FNAM) mnc_indir_str
699 edhill 1.105 COMMON /PARM_MNC/
700     & useMNC,
701 edhill 1.106 & mnc_use_indir, mnc_use_outdir, mnc_outdir_date,
702 edhill 1.108 & mnc_echo_gvtypes, mnc_pickup_write, mnc_pickup_read,
703 edhill 1.107 & mnc_outdir_str, mnc_indir_str,
704     & mnc_use_for_mon
705 edhill 1.105
706    
707     CEH3 ;;; Local Variables: ***
708     CEH3 ;;; mode:fortran ***
709     CEH3 ;;; End: ***

  ViewVC Help
Powered by ViewVC 1.1.22