49 |
|
|
50 |
C-- COMMON /PARM_C/ Character valued parameters used by the model. |
C-- COMMON /PARM_C/ Character valued parameters used by the model. |
51 |
C checkPtSuff :: List of checkpoint file suffices |
C checkPtSuff :: List of checkpoint file suffices |
52 |
|
C delXFile :: File containing X-spacing grid definition (1.D array) |
53 |
|
C delYFile :: File containing Y-spacing grid definition (1.D array) |
54 |
|
C horizGridFile :: File containing horizontal-grid definition |
55 |
|
C (only when using curvilinear_grid) |
56 |
C bathyFile :: File containing bathymetry. If not defined bathymetry |
C bathyFile :: File containing bathymetry. If not defined bathymetry |
57 |
C is taken from inline function. |
C is taken from inline function. |
58 |
C topoFile :: File containing the topography of the surface (unit=m) |
C topoFile :: File containing the topography of the surface (unit=m) |
82 |
C LINEAR, POLY3, UNESCO, JMD95Z, JMD95P, MDJWF, IDEALGAS |
C LINEAR, POLY3, UNESCO, JMD95Z, JMD95P, MDJWF, IDEALGAS |
83 |
C the_run_name :: string identifying the name of the model "run" |
C the_run_name :: string identifying the name of the model "run" |
84 |
COMMON /PARM_C/ checkPtSuff, |
COMMON /PARM_C/ checkPtSuff, |
85 |
|
& delXFile, delYFile, horizGridFile, |
86 |
& bathyFile, topoFile, |
& bathyFile, topoFile, |
87 |
& hydrogThetaFile, hydrogSaltFile, |
& hydrogThetaFile, hydrogSaltFile, |
88 |
& zonalWindFile, meridWindFile, thetaClimFile, |
& zonalWindFile, meridWindFile, thetaClimFile, |
97 |
& mdsioLocalDir, |
& mdsioLocalDir, |
98 |
& the_run_name |
& the_run_name |
99 |
CHARACTER*(5) checkPtSuff(maxNoChkptLev) |
CHARACTER*(5) checkPtSuff(maxNoChkptLev) |
100 |
|
CHARACTER*(MAX_LEN_FNAM) delXFile |
101 |
|
CHARACTER*(MAX_LEN_FNAM) delYFile |
102 |
|
CHARACTER*(MAX_LEN_FNAM) horizGridFile |
103 |
CHARACTER*(MAX_LEN_FNAM) bathyFile, topoFile |
CHARACTER*(MAX_LEN_FNAM) bathyFile, topoFile |
104 |
CHARACTER*(MAX_LEN_FNAM) hydrogThetaFile |
CHARACTER*(MAX_LEN_FNAM) hydrogThetaFile |
105 |
CHARACTER*(MAX_LEN_FNAM) hydrogSaltFile |
CHARACTER*(MAX_LEN_FNAM) hydrogSaltFile |
151 |
C select_rStar :: option related to r* vertical coordinate |
C select_rStar :: option related to r* vertical coordinate |
152 |
C =0 (default) use r coord. ; > 0 use r* |
C =0 (default) use r coord. ; > 0 use r* |
153 |
C tempAdvScheme :: Temp. Horiz.Advection scheme selector |
C tempAdvScheme :: Temp. Horiz.Advection scheme selector |
154 |
C tempVertAdvScheme :: Temp. Vert. Advection scheme selector |
C tempVertAdvScheme :: Temp. Vert. Advection scheme selector |
155 |
C saltAdvScheme :: Salt. Horiz.advection scheme selector |
C saltAdvScheme :: Salt. Horiz.advection scheme selector |
156 |
C saltVertAdvScheme :: Salt. Vert. Advection scheme selector |
C saltVertAdvScheme :: Salt. Vert. Advection scheme selector |
157 |
|
C selectKEscheme :: Kinetic Energy scheme selector (Vector Inv.) |
158 |
C debugLevel :: debug level selector: higher -> more writing |
C debugLevel :: debug level selector: higher -> more writing |
159 |
|
|
160 |
COMMON /PARM_I/ |
COMMON /PARM_I/ |
169 |
& nonlinFreeSurf, select_rStar, |
& nonlinFreeSurf, select_rStar, |
170 |
& tempAdvScheme, tempVertAdvScheme, |
& tempAdvScheme, tempVertAdvScheme, |
171 |
& saltAdvScheme, saltVertAdvScheme, |
& saltAdvScheme, saltVertAdvScheme, |
172 |
|
& selectKEscheme, |
173 |
& debugLevel |
& debugLevel |
174 |
INTEGER cg2dMaxIters |
INTEGER cg2dMaxIters |
175 |
INTEGER cg2dChkResFreq |
INTEGER cg2dChkResFreq |
188 |
INTEGER select_rStar |
INTEGER select_rStar |
189 |
INTEGER tempAdvScheme, tempVertAdvScheme |
INTEGER tempAdvScheme, tempVertAdvScheme |
190 |
INTEGER saltAdvScheme, saltVertAdvScheme |
INTEGER saltAdvScheme, saltVertAdvScheme |
191 |
|
INTEGER selectKEscheme |
192 |
INTEGER debugLevel |
INTEGER debugLevel |
193 |
|
|
194 |
C |
C |
229 |
C useRealFreshWaterFlux :: if True (=Natural BCS), treats P+R-E flux |
C useRealFreshWaterFlux :: if True (=Natural BCS), treats P+R-E flux |
230 |
C as a real Fresh Water (=> changes the Sea Level) |
C as a real Fresh Water (=> changes the Sea Level) |
231 |
C if F, converts P+R-E to salt flux (no SL effect) |
C if F, converts P+R-E to salt flux (no SL effect) |
232 |
C useFullLeith :: Set to true to use full Leith viscosity (may be unstable |
C useFullLeith :: Set to true to use full Leith viscosity(may be unstable |
233 |
C on irregular grids) |
C on irregular grids) |
234 |
C useAnisotropicViscAGridMax :: Set to true to use Alistair's latest |
C useAreaViscLength :: Set to true to use old scaling for viscous |
235 |
C anisotropic length scale. It is used only for maximum viscosity |
C lengths, e.g., L2=Raz. May be preferable for cube sphere. |
236 |
C calculations. Alistair recommends a value of viscA*GridMax=.25 |
C useStrainTensionVisc:: Set to true to use Strain-Tension viscous terms |
237 |
C rigidLid :: Set to true to use rigid lid |
C rigidLid :: Set to true to use rigid lid |
238 |
C implicitFreeSurface :: Set to true to use implcit free surface |
C implicitFreeSurface :: Set to true to use implcit free surface |
239 |
C exactConserv :: Set to true to conserve exactly the total Volume |
C exactConserv :: Set to true to conserve exactly the total Volume |
250 |
C useJamartMomAdv :: Use wet-point method for V.I. non-linear term |
C useJamartMomAdv :: Use wet-point method for V.I. non-linear term |
251 |
C SadournyCoriolis :: use the enstrophy conserving scheme by Sadourny |
C SadournyCoriolis :: use the enstrophy conserving scheme by Sadourny |
252 |
C upwindVorticity :: bias interpolation of vorticity in the Coriolis term |
C upwindVorticity :: bias interpolation of vorticity in the Coriolis term |
253 |
C highOrderVorticity :: use 3rd/4th order interp. of vorticity in Coriolis |
C highOrderVorticity :: use 3rd/4th order interp. of vorticity (V.I., advection) |
254 |
|
C upwindShear :: use 1rst order upwind interp. (V.I., vertical advection) |
255 |
C useAbsVorticity :: work with f+zeta in Coriolis terms |
C useAbsVorticity :: work with f+zeta in Coriolis terms |
256 |
C implicitDiffusion :: Turns implicit vertical diffusion on |
C implicitDiffusion :: Turns implicit vertical diffusion on |
257 |
C implicitViscosity :: Turns implicit vertical viscosity on |
C implicitViscosity :: Turns implicit vertical viscosity on |
288 |
C outputs from master mpi process only. |
C outputs from master mpi process only. |
289 |
C allowFreezing :: Allows surface water to freeze and form ice |
C allowFreezing :: Allows surface water to freeze and form ice |
290 |
C useOldFreezing :: use the old version (before checkpoint52a_pre, 2003-11-12) |
C useOldFreezing :: use the old version (before checkpoint52a_pre, 2003-11-12) |
|
C groundAtK1 :: put the surface(k=1) at the Lower Boundary (=ground) |
|
291 |
C pickup_write_mdsio :: use mdsio to write pickups |
C pickup_write_mdsio :: use mdsio to write pickups |
292 |
C pickup_read_mdsio :: use mdsio to read pickups |
C pickup_read_mdsio :: use mdsio to read pickups |
293 |
C pickup_write_immed :: echo the pickup immediately (for conversion) |
C pickup_write_immed :: echo the pickup immediately (for conversion) |
298 |
C for parameters chkPtFreq, pChkPtFreq, taveFreq, SEAICE_taveFreq, |
C for parameters chkPtFreq, pChkPtFreq, taveFreq, SEAICE_taveFreq, |
299 |
C KPP_taveFreq, and freq in pkg/diagnostics are converted to exact |
C KPP_taveFreq, and freq in pkg/diagnostics are converted to exact |
300 |
C calendar months and years. Requires pkg/cal. |
C calendar months and years. Requires pkg/cal. |
301 |
|
C dumpInitAndLast :: dumps model state to files at Initial (nIter0) |
302 |
|
C & Last iteration, in addition multiple of dumpFreq iter. |
303 |
COMMON /PARM_L/ usingCartesianGrid, usingSphericalPolarGrid, |
COMMON /PARM_L/ usingCartesianGrid, usingSphericalPolarGrid, |
304 |
& usingCurvilinearGrid, usingCylindricalGrid, |
& usingCurvilinearGrid, usingCylindricalGrid, |
305 |
& no_slip_sides,no_slip_bottom, |
& no_slip_sides,no_slip_bottom, |
309 |
& tempAdvection, tempForcing, |
& tempAdvection, tempForcing, |
310 |
& saltAdvection, saltForcing, |
& saltAdvection, saltForcing, |
311 |
& useRealFreshWaterFlux, |
& useRealFreshWaterFlux, |
312 |
& useFullLeith, useAnisotropicViscAGridMax, |
& useFullLeith, useStrainTensionVisc, |
313 |
|
& useAreaViscLength, |
314 |
& rigidLid, implicitFreeSurface, exactConserv, uniformLin_PhiSurf, |
& rigidLid, implicitFreeSurface, exactConserv, uniformLin_PhiSurf, |
315 |
& momStepping, tempStepping, saltStepping, |
& momStepping, tempStepping, saltStepping, |
316 |
& metricTerms, usingSphericalPolarMTerms, useNHMTerms, |
& metricTerms, usingSphericalPolarMTerms, useNHMTerms, |
318 |
& useCDscheme, |
& useCDscheme, |
319 |
& useEnergyConservingCoriolis, useJamartWetPoints, useJamartMomAdv, |
& useEnergyConservingCoriolis, useJamartWetPoints, useJamartMomAdv, |
320 |
& SadournyCoriolis, upwindVorticity, highOrderVorticity, |
& SadournyCoriolis, upwindVorticity, highOrderVorticity, |
321 |
& useAbsVorticity, |
& useAbsVorticity, upwindShear, |
322 |
& implicitDiffusion, implicitViscosity, |
& implicitDiffusion, implicitViscosity, |
323 |
& tempImplVertAdv, saltImplVertAdv, momImplVertAdv, |
& tempImplVertAdv, saltImplVertAdv, momImplVertAdv, |
324 |
& multiDimAdvection, useMultiDimAdvec, forcing_In_AB, |
& multiDimAdvection, useMultiDimAdvec, forcing_In_AB, |
327 |
& fluidIsAir, fluidIsWater, |
& fluidIsAir, fluidIsWater, |
328 |
& usingPCoords, usingZCoords, useDynP_inEos_Zc, setCenterDr, |
& usingPCoords, usingZCoords, useDynP_inEos_Zc, setCenterDr, |
329 |
& nonHydrostatic, quasiHydrostatic, globalFiles, useSingleCpuIO, |
& nonHydrostatic, quasiHydrostatic, globalFiles, useSingleCpuIO, |
330 |
& allowFreezing, useOldFreezing, groundAtK1, |
& allowFreezing, useOldFreezing, |
331 |
& usePickupBeforeC35, usePickupBeforeC54, startFromPickupAB2, |
& usePickupBeforeC35, usePickupBeforeC54, startFromPickupAB2, |
332 |
& pickup_read_mdsio, pickup_write_mdsio, pickup_write_immed, |
& pickup_read_mdsio, pickup_write_mdsio, pickup_write_immed, |
333 |
& timeave_mdsio, snapshot_mdsio, monitor_stdio, |
& timeave_mdsio, snapshot_mdsio, monitor_stdio, |
334 |
& outputTypesInclusive, debugMode, |
& outputTypesInclusive, dumpInitAndLast, debugMode, |
335 |
& inAdMode, inAdTrue, inAdFalse, inAdExact, |
& inAdMode, inAdTrue, inAdFalse, inAdExact, |
336 |
& calendarDumps |
& calendarDumps |
337 |
|
|
355 |
LOGICAL saltAdvection |
LOGICAL saltAdvection |
356 |
LOGICAL saltForcing |
LOGICAL saltForcing |
357 |
LOGICAL useRealFreshWaterFlux |
LOGICAL useRealFreshWaterFlux |
358 |
LOGICAL useFullLeith, useAnisotropicViscAGridMax |
LOGICAL useFullLeith |
359 |
|
LOGICAL useStrainTensionVisc |
360 |
|
LOGICAL useAreaViscLength |
361 |
LOGICAL rigidLid |
LOGICAL rigidLid |
362 |
LOGICAL implicitFreeSurface |
LOGICAL implicitFreeSurface |
363 |
LOGICAL exactConserv |
LOGICAL exactConserv |
377 |
LOGICAL upwindVorticity |
LOGICAL upwindVorticity |
378 |
LOGICAL highOrderVorticity |
LOGICAL highOrderVorticity |
379 |
LOGICAL useAbsVorticity |
LOGICAL useAbsVorticity |
380 |
|
LOGICAL upwindShear |
381 |
LOGICAL implicitDiffusion |
LOGICAL implicitDiffusion |
382 |
LOGICAL implicitViscosity |
LOGICAL implicitViscosity |
383 |
LOGICAL tempImplVertAdv |
LOGICAL tempImplVertAdv |
402 |
LOGICAL useSingleCpuIO |
LOGICAL useSingleCpuIO |
403 |
LOGICAL allowFreezing |
LOGICAL allowFreezing |
404 |
LOGICAL useOldFreezing |
LOGICAL useOldFreezing |
|
LOGICAL groundAtK1 |
|
405 |
LOGICAL usePickupBeforeC35 |
LOGICAL usePickupBeforeC35 |
406 |
LOGICAL usePickupBeforeC54 |
LOGICAL usePickupBeforeC54 |
407 |
LOGICAL startFromPickupAB2 |
LOGICAL startFromPickupAB2 |
408 |
|
LOGICAL dumpInitAndLast |
409 |
LOGICAL debugMode |
LOGICAL debugMode |
410 |
LOGICAL pickup_read_mdsio, pickup_write_mdsio |
LOGICAL pickup_read_mdsio, pickup_write_mdsio |
411 |
LOGICAL pickup_write_immed |
LOGICAL pickup_write_immed |
479 |
C viscA4Z :: Biharmonic viscosity coeff. for mixing of momentum laterally |
C viscA4Z :: Biharmonic viscosity coeff. for mixing of momentum laterally |
480 |
C (act on Vorticity part) ( m^4/s ) |
C (act on Vorticity part) ( m^4/s ) |
481 |
C viscC2leith :: Leith non-dimensional viscosity factor (grad(vort)) |
C viscC2leith :: Leith non-dimensional viscosity factor (grad(vort)) |
482 |
C viscC2leithD :: Modified Leith non-dimensional viscosity factor (grad(div)) |
C viscC2leithD :: Modified Leith non-dimensional visc. factor (grad(div)) |
483 |
C viscC2smag :: Smagorinsky non-dimensional viscosity factor |
C viscC2smag :: Smagorinsky non-dimensional viscosity factor (harmonic) |
484 |
|
C viscC4smag :: Smagorinsky non-dimensional viscosity factor (biharmonic) |
485 |
C viscAhMax :: Maximum eddy viscosity coeff. for mixing of |
C viscAhMax :: Maximum eddy viscosity coeff. for mixing of |
486 |
C momentum laterally ( m^2/s ) |
C momentum laterally ( m^2/s ) |
487 |
|
C viscAhReMax :: Maximum gridscale Reynolds number for eddy viscosity |
488 |
|
C coeff. for mixing of momentum laterally (non-dim) |
489 |
C viscAhGridMax:: maximum and minimum harmonic viscosity coefficients ... |
C viscAhGridMax:: maximum and minimum harmonic viscosity coefficients ... |
490 |
C viscAhGridMin:: in terms of non-dimensional grid-size dependent viscosity |
C viscAhGridMin:: in terms of non-dimensional grid-size dependent visc. |
491 |
C viscA4Max :: Maximum biharmonic viscosity coeff. for mixing of |
C viscA4Max :: Maximum biharmonic viscosity coeff. for mixing of |
492 |
C momentum laterally ( m^4/s ) |
C momentum laterally ( m^4/s ) |
493 |
|
C viscA4ReMax :: Maximum Gridscale Reynolds number for |
494 |
|
C biharmonic viscosity coeff. momentum laterally (non-dim) |
495 |
C viscAhGrid:: non-dimensional grid-size dependent viscosity |
C viscAhGrid:: non-dimensional grid-size dependent viscosity |
496 |
C viscA4Grid:: non-dimensional grid-size dependent bi-harmonic viscosity |
C viscA4Grid:: non-dimensional grid-size dependent bi-harmonic viscosity |
497 |
C viscA4GridMax:: maximum and minimum biharmonic viscosity coefficients ... |
C viscA4GridMax:: maximum and minimum biharmonic viscosity coefficients ... |
596 |
& viscAh, viscAhW, viscAhMax, |
& viscAh, viscAhW, viscAhMax, |
597 |
& viscAhGrid, viscAhGridMax, viscAhGridMin, |
& viscAhGrid, viscAhGridMax, viscAhGridMin, |
598 |
& viscC2leith, viscC2leithD, |
& viscC2leith, viscC2leithD, |
599 |
& viscC2smag, |
& viscC2smag, viscC4smag, |
600 |
& viscAhD, viscAhZ, viscA4D, viscA4Z, |
& viscAhD, viscAhZ, viscA4D, viscA4Z, |
601 |
& viscA4, viscA4W, |
& viscA4, viscA4W, |
602 |
& viscA4Max, viscA4Grid, viscA4GridMax, viscA4GridMin, |
& viscA4Max, viscA4Grid, viscA4GridMax, viscA4GridMin, |
603 |
& viscC4leith, viscC4leithD, viscAr, viscAstrain, viscAtension, |
& viscAhRemax, viscA4Remax, |
604 |
|
& viscC4leith, viscC4leithD, viscAr, |
605 |
& diffKhT, diffK4T, diffKrNrT, |
& diffKhT, diffK4T, diffKrNrT, |
606 |
& diffKhS, diffK4S, diffKrNrS, |
& diffKhS, diffK4S, diffKrNrS, |
607 |
& diffKrBL79surf, diffKrBL79deep, diffKrBL79scl, diffKrBL79Ho, |
& diffKrBL79surf, diffKrBL79deep, diffKrBL79scl, diffKrBL79Ho, |
661 |
_RL viscAhD |
_RL viscAhD |
662 |
_RL viscAhZ |
_RL viscAhZ |
663 |
_RL viscAhMax |
_RL viscAhMax |
664 |
|
_RL viscAhReMax |
665 |
_RL viscAhGrid |
_RL viscAhGrid |
666 |
_RL viscAhGridMax |
_RL viscAhGridMax |
667 |
_RL viscAhGridMin |
_RL viscAhGridMin |
668 |
_RL viscC2leith |
_RL viscC2leith |
669 |
_RL viscC2leithD |
_RL viscC2leithD |
670 |
_RL viscC2smag |
_RL viscC2smag |
671 |
_RL viscAstrain |
_RL viscC4smag |
|
_RL viscAtension |
|
672 |
_RL viscAr |
_RL viscAr |
673 |
_RL viscA4 |
_RL viscA4 |
674 |
_RL viscA4W |
_RL viscA4W |
675 |
_RL viscA4D |
_RL viscA4D |
676 |
_RL viscA4Z |
_RL viscA4Z |
677 |
_RL viscA4Max |
_RL viscA4Max |
678 |
|
_RL viscA4ReMax |
679 |
_RL viscA4Grid, viscA4GridMax, viscA4GridMin |
_RL viscA4Grid, viscA4GridMax, viscA4GridMin |
680 |
_RL viscC4leith |
_RL viscC4leith |
681 |
_RL viscC4leithD |
_RL viscC4leithD |
796 |
LOGICAL useEBM |
LOGICAL useEBM |
797 |
LOGICAL useMNC |
LOGICAL useMNC |
798 |
LOGICAL useMATRIX |
LOGICAL useMATRIX |
799 |
|
LOGICAL useRunClock |
800 |
COMMON /PARM_PACKAGES/ |
COMMON /PARM_PACKAGES/ |
801 |
& useKPP, useGMRedi, useOBCS, useAIM, useLand, useECCO, |
& useKPP, useGMRedi, useOBCS, useAIM, useLand, useECCO, |
802 |
& useSHAP_FILT, useZONAL_FILT, useGrdchk, useFLT, |
& useSHAP_FILT, useZONAL_FILT, useGrdchk, useFLT, |
803 |
& usePTRACERS, useGCHEM, |
& usePTRACERS, useGCHEM, |
804 |
& useSBO, useSEAICE, useThSIce, useBulkForce, |
& useSBO, useSEAICE, useThSIce, useBulkForce, |
805 |
& usefizhi, usegridalt, usediagnostics, useEBM, useMNC, |
& usefizhi, usegridalt, usediagnostics, useEBM, useMNC, |
806 |
& usePP81, useMY82, useOPPS, useGGL90, useMATRIX |
& usePP81, useMY82, useOPPS, useGGL90, useMATRIX, |
807 |
|
& useRunClock |
808 |
|
|
809 |
CEH3 ;;; Local Variables: *** |
CEH3 ;;; Local Variables: *** |
810 |
CEH3 ;;; mode:fortran *** |
CEH3 ;;; mode:fortran *** |