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 |
228 |
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) |
229 |
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 |
230 |
C on irregular grids) |
C on irregular grids) |
231 |
|
C useAnisotropicViscAGridMax :: Set to true to use Alistair's latest |
232 |
|
C anisotropic length scale. It is used only for maximum viscosity |
233 |
|
C calculations. Alistair recommends a value of viscA*GridMax=.25 |
234 |
C rigidLid :: Set to true to use rigid lid |
C rigidLid :: Set to true to use rigid lid |
235 |
C implicitFreeSurface :: Set to true to use implcit free surface |
C implicitFreeSurface :: Set to true to use implcit free surface |
236 |
C exactConserv :: Set to true to conserve exactly the total Volume |
C exactConserv :: Set to true to conserve exactly the total Volume |
247 |
C useJamartMomAdv :: Use wet-point method for V.I. non-linear term |
C useJamartMomAdv :: Use wet-point method for V.I. non-linear term |
248 |
C SadournyCoriolis :: use the enstrophy conserving scheme by Sadourny |
C SadournyCoriolis :: use the enstrophy conserving scheme by Sadourny |
249 |
C upwindVorticity :: bias interpolation of vorticity in the Coriolis term |
C upwindVorticity :: bias interpolation of vorticity in the Coriolis term |
250 |
C highOrderVorticity :: use 3rd/4th order interp. of vorticity in Coriolis |
C highOrderVorticity :: use 3rd/4th order interp. of vorticity (V.I., advection) |
251 |
|
C upwindShear :: use 1rst order upwind interp. (V.I., vertical advection) |
252 |
C useAbsVorticity :: work with f+zeta in Coriolis terms |
C useAbsVorticity :: work with f+zeta in Coriolis terms |
253 |
C implicitDiffusion :: Turns implicit vertical diffusion on |
C implicitDiffusion :: Turns implicit vertical diffusion on |
254 |
C implicitViscosity :: Turns implicit vertical viscosity on |
C implicitViscosity :: Turns implicit vertical viscosity on |
259 |
C useMultiDimAdvec :: True if multi-dim advection is used at least once |
C useMultiDimAdvec :: True if multi-dim advection is used at least once |
260 |
C forcing_In_AB :: if False, put forcing (Temp,Salt,Tracers) contribution |
C forcing_In_AB :: if False, put forcing (Temp,Salt,Tracers) contribution |
261 |
C out off Adams-Bashforth time stepping. |
C out off Adams-Bashforth time stepping. |
262 |
|
C startFromPickupAB2 :: with AB-3 code, start from an AB-2 pickup |
263 |
C doThetaClimRelax :: Set true if relaxation to temperature |
C doThetaClimRelax :: Set true if relaxation to temperature |
264 |
C climatology is required. |
C climatology is required. |
265 |
C doSaltClimRelax :: Set true if relaxation to salinity |
C doSaltClimRelax :: Set true if relaxation to salinity |
285 |
C outputs from master mpi process only. |
C outputs from master mpi process only. |
286 |
C allowFreezing :: Allows surface water to freeze and form ice |
C allowFreezing :: Allows surface water to freeze and form ice |
287 |
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) |
|
288 |
C pickup_write_mdsio :: use mdsio to write pickups |
C pickup_write_mdsio :: use mdsio to write pickups |
289 |
C pickup_read_mdsio :: use mdsio to read pickups |
C pickup_read_mdsio :: use mdsio to read pickups |
290 |
C pickup_write_immed :: echo the pickup immediately (for conversion) |
C pickup_write_immed :: echo the pickup immediately (for conversion) |
291 |
C timeave_mdsio :: use mdsio for timeave output |
C timeave_mdsio :: use mdsio for timeave output |
292 |
C snapshot_mdsio :: use mdsio for "snapshot" (dumpfreq/diagfreq) output |
C snapshot_mdsio :: use mdsio for "snapshot" (dumpfreq/diagfreq) output |
|
C seaice_mdsio :: use mdsio for seaice output |
|
293 |
C monitor_stdio :: use stdio for monitor output |
C monitor_stdio :: use stdio for monitor output |
294 |
C calendarDumps :: When set, approximate months (30-31 days) and years (360-372 days) |
C calendarDumps :: When set, approximate months (30-31 days) and years (360-372 days) |
295 |
C for parameters chkPtFreq, pChkPtFreq, taveFreq, SEAICE_taveFreq, |
C for parameters chkPtFreq, pChkPtFreq, taveFreq, SEAICE_taveFreq, |
296 |
C KPP_taveFreq, and freq in pkg/diagnostics are converted to exact |
C KPP_taveFreq, and freq in pkg/diagnostics are converted to exact |
297 |
C calendar months and years. Requires pkg/cal. |
C calendar months and years. Requires pkg/cal. |
298 |
|
C nodumps :: Logical Flag to indicate whether to do ANY dumps at all |
299 |
COMMON /PARM_L/ usingCartesianGrid, usingSphericalPolarGrid, |
COMMON /PARM_L/ usingCartesianGrid, usingSphericalPolarGrid, |
300 |
& usingCurvilinearGrid, usingCylindricalGrid, |
& usingCurvilinearGrid, usingCylindricalGrid, |
301 |
& no_slip_sides,no_slip_bottom, |
& no_slip_sides,no_slip_bottom, |
305 |
& tempAdvection, tempForcing, |
& tempAdvection, tempForcing, |
306 |
& saltAdvection, saltForcing, |
& saltAdvection, saltForcing, |
307 |
& useRealFreshWaterFlux, |
& useRealFreshWaterFlux, |
308 |
& useFullLeith, |
& useFullLeith, useAnisotropicViscAGridMax, |
309 |
& rigidLid, implicitFreeSurface, exactConserv, uniformLin_PhiSurf, |
& rigidLid, implicitFreeSurface, exactConserv, uniformLin_PhiSurf, |
310 |
& momStepping, tempStepping, saltStepping, |
& momStepping, tempStepping, saltStepping, |
311 |
& metricTerms, usingSphericalPolarMTerms, useNHMTerms, |
& metricTerms, usingSphericalPolarMTerms, useNHMTerms, |
313 |
& useCDscheme, |
& useCDscheme, |
314 |
& useEnergyConservingCoriolis, useJamartWetPoints, useJamartMomAdv, |
& useEnergyConservingCoriolis, useJamartWetPoints, useJamartMomAdv, |
315 |
& SadournyCoriolis, upwindVorticity, highOrderVorticity, |
& SadournyCoriolis, upwindVorticity, highOrderVorticity, |
316 |
& useAbsVorticity, |
& useAbsVorticity, upwindShear, |
317 |
& implicitDiffusion, implicitViscosity, |
& implicitDiffusion, implicitViscosity, |
318 |
& tempImplVertAdv, saltImplVertAdv, momImplVertAdv, |
& tempImplVertAdv, saltImplVertAdv, momImplVertAdv, |
319 |
& multiDimAdvection, useMultiDimAdvec, forcing_In_AB, |
& multiDimAdvection, useMultiDimAdvec, forcing_In_AB, |
322 |
& fluidIsAir, fluidIsWater, |
& fluidIsAir, fluidIsWater, |
323 |
& usingPCoords, usingZCoords, useDynP_inEos_Zc, setCenterDr, |
& usingPCoords, usingZCoords, useDynP_inEos_Zc, setCenterDr, |
324 |
& nonHydrostatic, quasiHydrostatic, globalFiles, useSingleCpuIO, |
& nonHydrostatic, quasiHydrostatic, globalFiles, useSingleCpuIO, |
325 |
& allowFreezing, useOldFreezing, groundAtK1, |
& allowFreezing, useOldFreezing, |
326 |
& usePickupBeforeC35, usePickupBeforeC54, debugMode, |
& usePickupBeforeC35, usePickupBeforeC54, startFromPickupAB2, |
|
& readPickupWithTracer, writePickupWithTracer, |
|
327 |
& pickup_read_mdsio, pickup_write_mdsio, pickup_write_immed, |
& pickup_read_mdsio, pickup_write_mdsio, pickup_write_immed, |
328 |
& timeave_mdsio, snapshot_mdsio, monitor_stdio, seaice_mdsio, |
& timeave_mdsio, snapshot_mdsio, monitor_stdio, |
329 |
& outputTypesInclusive, |
& outputTypesInclusive, debugMode, |
330 |
& inAdMode, inAdTrue, inAdFalse, inAdExact, |
& inAdMode, inAdTrue, inAdFalse, inAdExact, |
331 |
& calendarDumps |
& calendarDumps, nodumps |
332 |
|
|
333 |
LOGICAL usingCartesianGrid |
LOGICAL usingCartesianGrid |
334 |
LOGICAL usingSphericalPolarGrid |
LOGICAL usingSphericalPolarGrid |
350 |
LOGICAL saltAdvection |
LOGICAL saltAdvection |
351 |
LOGICAL saltForcing |
LOGICAL saltForcing |
352 |
LOGICAL useRealFreshWaterFlux |
LOGICAL useRealFreshWaterFlux |
353 |
LOGICAL useFullLeith |
LOGICAL useFullLeith, useAnisotropicViscAGridMax |
354 |
LOGICAL rigidLid |
LOGICAL rigidLid |
355 |
LOGICAL implicitFreeSurface |
LOGICAL implicitFreeSurface |
356 |
LOGICAL exactConserv |
LOGICAL exactConserv |
370 |
LOGICAL upwindVorticity |
LOGICAL upwindVorticity |
371 |
LOGICAL highOrderVorticity |
LOGICAL highOrderVorticity |
372 |
LOGICAL useAbsVorticity |
LOGICAL useAbsVorticity |
373 |
|
LOGICAL upwindShear |
374 |
LOGICAL implicitDiffusion |
LOGICAL implicitDiffusion |
375 |
LOGICAL implicitViscosity |
LOGICAL implicitViscosity |
376 |
LOGICAL tempImplVertAdv |
LOGICAL tempImplVertAdv |
395 |
LOGICAL useSingleCpuIO |
LOGICAL useSingleCpuIO |
396 |
LOGICAL allowFreezing |
LOGICAL allowFreezing |
397 |
LOGICAL useOldFreezing |
LOGICAL useOldFreezing |
|
LOGICAL groundAtK1 |
|
398 |
LOGICAL usePickupBeforeC35 |
LOGICAL usePickupBeforeC35 |
399 |
LOGICAL usePickupBeforeC54 |
LOGICAL usePickupBeforeC54 |
400 |
|
LOGICAL startFromPickupAB2 |
401 |
LOGICAL debugMode |
LOGICAL debugMode |
|
LOGICAL readPickupWithTracer |
|
|
LOGICAL writePickupWithTracer |
|
402 |
LOGICAL pickup_read_mdsio, pickup_write_mdsio |
LOGICAL pickup_read_mdsio, pickup_write_mdsio |
403 |
LOGICAL pickup_write_immed |
LOGICAL pickup_write_immed |
404 |
LOGICAL timeave_mdsio, snapshot_mdsio, monitor_stdio |
LOGICAL timeave_mdsio, snapshot_mdsio, monitor_stdio |
|
LOGICAL seaice_mdsio |
|
405 |
LOGICAL outputTypesInclusive |
LOGICAL outputTypesInclusive |
406 |
LOGICAL inAdMode, inAdTrue, inAdFalse, inAdExact |
LOGICAL inAdMode, inAdTrue, inAdFalse, inAdExact |
407 |
LOGICAL calendarDumps |
LOGICAL calendarDumps |
408 |
|
LOGICAL nodumps |
409 |
|
|
410 |
C-- COMMON /PARM_R/ "Real" valued parameters used by the model. |
C-- COMMON /PARM_R/ "Real" valued parameters used by the model. |
411 |
C cg2dTargetResidual |
C cg2dTargetResidual |
515 |
C freesurfFac :: Parameter to turn implicit free surface term on or off |
C freesurfFac :: Parameter to turn implicit free surface term on or off |
516 |
C freesurfac = 1. uses implicit free surface |
C freesurfac = 1. uses implicit free surface |
517 |
C freesurfac = 0. uses rigid lid |
C freesurfac = 0. uses rigid lid |
518 |
|
C abEps :: Adams-Bashforth-2 stabilizing weight |
519 |
|
C alph_AB :: Adams-Bashforth-3 primary factor |
520 |
|
C beta_AB :: Adams-Bashforth-3 secondary factor |
521 |
C implicSurfPress :: parameter of the Crank-Nickelson time stepping : |
C implicSurfPress :: parameter of the Crank-Nickelson time stepping : |
522 |
C Implicit part of Surface Pressure Gradient ( 0-1 ) |
C Implicit part of Surface Pressure Gradient ( 0-1 ) |
523 |
C implicDiv2Dflow :: parameter of the Crank-Nickelson time stepping : |
C implicDiv2Dflow :: parameter of the Crank-Nickelson time stepping : |
579 |
& cg2dpcOffDFac, cg3dTargetResidual, |
& cg2dpcOffDFac, cg3dTargetResidual, |
580 |
& delR, delRc, delX, delY, |
& delR, delRc, delX, delY, |
581 |
& deltaT, deltaTmom, dTtracerLev, deltaTfreesurf, deltaTClock, |
& deltaT, deltaTmom, dTtracerLev, deltaTfreesurf, deltaTClock, |
582 |
& abeps, |
& abEps, alph_AB, beta_AB, |
583 |
& phiMin, thetaMin, rSphere, recip_RSphere, f0, beta, |
& phiMin, thetaMin, rSphere, recip_RSphere, f0, beta, |
584 |
& viscAh, viscAhW, viscAhMax, |
& viscAh, viscAhW, viscAhMax, |
585 |
& viscAhGrid, viscAhGridMax, viscAhGridMin, |
& viscAhGrid, viscAhGridMax, viscAhGridMin, |
610 |
& hFacMinDr, hFacMinDp, |
& hFacMinDr, hFacMinDp, |
611 |
& horiVertRatio, recip_horiVertRatio, |
& horiVertRatio, recip_horiVertRatio, |
612 |
& ivdc_kappa, Ro_SeaLevel, |
& ivdc_kappa, Ro_SeaLevel, |
613 |
& bottomDragLinear,bottomDragQuadratic, |
& bottomDragLinear,bottomDragQuadratic,nh_Am2, |
614 |
& tCylIn, tCylOut |
& tCylIn, tCylOut |
615 |
|
|
616 |
|
_RL nh_Am2 |
617 |
_RL cg2dTargetResidual |
_RL cg2dTargetResidual |
618 |
_RL cg2dTargetResWunit |
_RL cg2dTargetResWunit |
619 |
_RL cg3dTargetResidual |
_RL cg3dTargetResidual |
627 |
_RL deltaTmom |
_RL deltaTmom |
628 |
_RL dTtracerLev(Nr) |
_RL dTtracerLev(Nr) |
629 |
_RL deltaTfreesurf |
_RL deltaTfreesurf |
630 |
_RL abeps |
_RL abEps, alph_AB, beta_AB |
631 |
_RL phiMin |
_RL phiMin |
632 |
_RL thetaMin |
_RL thetaMin |
633 |
_RL rSphere |
_RL rSphere |
781 |
LOGICAL usediagnostics |
LOGICAL usediagnostics |
782 |
LOGICAL useEBM |
LOGICAL useEBM |
783 |
LOGICAL useMNC |
LOGICAL useMNC |
784 |
|
LOGICAL useMATRIX |
785 |
|
LOGICAL useRunClock |
786 |
COMMON /PARM_PACKAGES/ |
COMMON /PARM_PACKAGES/ |
787 |
& useKPP, useGMRedi, useOBCS, useAIM, useLand, useECCO, |
& useKPP, useGMRedi, useOBCS, useAIM, useLand, useECCO, |
788 |
& useSHAP_FILT, useZONAL_FILT, useGrdchk, useFLT, |
& useSHAP_FILT, useZONAL_FILT, useGrdchk, useFLT, |
789 |
& usePTRACERS, useGCHEM, |
& usePTRACERS, useGCHEM, |
790 |
& useSBO, useSEAICE, useThSIce, useBulkForce, |
& useSBO, useSEAICE, useThSIce, useBulkForce, |
791 |
& usefizhi, usegridalt, usediagnostics, useEBM, useMNC, |
& usefizhi, usegridalt, usediagnostics, useEBM, useMNC, |
792 |
& usePP81, useMY82, useOPPS, useGGL90 |
& usePP81, useMY82, useOPPS, useGGL90, useMATRIX, |
793 |
|
& useRunClock |
794 |
|
|
795 |
CEH3 ;;; Local Variables: *** |
CEH3 ;;; Local Variables: *** |
796 |
CEH3 ;;; mode:fortran *** |
CEH3 ;;; mode:fortran *** |