/[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.127 - (hide annotations) (download)
Fri Sep 17 22:57:11 2004 UTC (19 years, 8 months ago) by heimbach
Branch: MAIN
CVS Tags: checkpoint55, checkpoint55c_post, checkpoint55d_post, checkpoint55d_pre, checkpoint55b_post, checkpoint55a_post, checkpoint55e_post
Changes since 1.126: +2 -4 lines
File MIME type: text/plain
o remove all tr1-related code (ALLOW_PASSIVE_TRACER)
  (adjoint stuff still has some tr1 names, but all use ptracer arrays)

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

  ViewVC Help
Powered by ViewVC 1.1.22