[1989] | 1 | MODULE YOMCT0 |
---|
| 2 | |
---|
| 3 | USE PARKIND1 ,ONLY : JPIM ,JPRB |
---|
| 4 | |
---|
| 5 | IMPLICIT NONE |
---|
| 6 | |
---|
| 7 | SAVE |
---|
| 8 | |
---|
| 9 | ! ------------------------------------------------------------------ |
---|
| 10 | |
---|
| 11 | !* Control variables for the job - constant within job |
---|
| 12 | |
---|
| 13 | !========== TECHNICAL SWITCHES ================================================ |
---|
| 14 | |
---|
| 15 | ! ----- configuration: |
---|
| 16 | ! NCONF : configuration of the job |
---|
| 17 | |
---|
| 18 | ! 0- 99 : 3-D integration job |
---|
| 19 | ! 100-199 : variational job |
---|
| 20 | ! 200-299 : 2-D integration job |
---|
| 21 | ! 300-349 : KALMAN filter (currently obsolete) |
---|
| 22 | ! 350-399 : predictability model (currently obsolete) |
---|
| 23 | ! 400-499 : test of the adjoint |
---|
| 24 | ! 500-599 : test of the tangent linear model |
---|
| 25 | ! 600-699 : eigenvalue/vector solvers |
---|
| 26 | ! 700-799 : optimal interpolation |
---|
| 27 | ! 800-899 : sensitivity |
---|
| 28 | ! 900-999 : miscellaneous other configurations. |
---|
| 29 | |
---|
| 30 | ! 1 : 3-D primitive equation model |
---|
| 31 | |
---|
| 32 | ! 131 : incremental 4-D VAR/3-D VAR |
---|
| 33 | |
---|
| 34 | ! 201 : shallow-water model |
---|
| 35 | ! 202 : vorticity equation model |
---|
| 36 | |
---|
| 37 | ! 401 : test of adjoint with 3-D P.E. model |
---|
| 38 | ! 421 : test of adjoint with shallow-water model |
---|
| 39 | ! 422 : test of adjoint with vorticity equation model |
---|
| 40 | |
---|
| 41 | ! 501 : test of tangent linear with 3-D P.E. model |
---|
| 42 | ! 521 : test of tangent linear with shallow-water model |
---|
| 43 | ! 522 : test of tangent linear with vorticity equation model |
---|
| 44 | |
---|
| 45 | ! 601 : eigenvalue/vector solver for 3-D P.E. model |
---|
| 46 | |
---|
| 47 | ! 701 : optimal interpolation with CANARI |
---|
| 48 | |
---|
| 49 | ! 801 : sensitivity with 3-D P.E. model |
---|
| 50 | |
---|
| 51 | ! 901 : set up initial conditions (CPREP1) |
---|
| 52 | ! 903 : set up initial conditions (CPREP5) |
---|
| 53 | ! 911 : computes dilatation matrices for spectral space |
---|
| 54 | ! 912 : computes rotation matrices for spectral space |
---|
| 55 | ! 923 : initialisation of climatologic files |
---|
| 56 | ! 931 : creation of an ARPEGE file containing the NESDIS SST (INCLITC). |
---|
| 57 | ! 932 : interpolates the sea-ice concentration field from |
---|
| 58 | ! satellite data to the ARPEGE grid (CSEAICE). |
---|
| 59 | ! 940 : corrects the dry surface pressure in an ARPEGE file |
---|
| 60 | ! to keep total mass constant compared to a reference |
---|
| 61 | ! ARPEGE file (CORMASS) |
---|
| 62 | ! 951 : difference between 2 model states (CPREP2) |
---|
| 63 | |
---|
| 64 | ! ----- ???: |
---|
| 65 | ! NTASKS : ??? (no comment provided, currently used in CANARI only). |
---|
| 66 | |
---|
| 67 | ! ----- variables linked with diagnostics and outputs: |
---|
| 68 | ! LALLOPR : .T. = print information about all allocations/deallocations |
---|
| 69 | ! NPRINTLEV : 0 = "basic prints'; 1 = "more prints"; 2 = "debug prints" |
---|
| 70 | |
---|
| 71 | ! ----- type of file used: |
---|
| 72 | ! LFDBOP : .T. = fields data base utilized |
---|
| 73 | ! LGRBOP : .T. = output in GRIB (not ARPEGE) |
---|
| 74 | ! LFBDAP : .T. = diagnostics written on trajectory files |
---|
| 75 | ! LARPEGEF : .T. = use ARPEGE files |
---|
| 76 | ! LARPEGEF_TRAJHR : .T. = use ARPEGE files for high resolution trajectory |
---|
| 77 | ! LARPEGEF_TRAJBG : .T. = use ARPEGE files for background |
---|
| 78 | ! LARPEGEF_RDGP_INIT : .T. = use grid-point ARPEGE files |
---|
| 79 | ! LARPEGEF_RDGP_TRAJHR : .T. = use grid-point ARPEGE files for HR trajectory |
---|
| 80 | ! LARPEGEF_RDGP_TRAJBG : .T. = use grid-point ARPEGE files for background |
---|
| 81 | ! CNDISPP : directory of display files |
---|
| 82 | |
---|
| 83 | ! ----- variables linked to post-processing: |
---|
| 84 | ! LFPOS : .T. = use of Full-POS rather than POS |
---|
| 85 | ! CFPNCF : name of Full-POS control file (pseudo-configuration 927) |
---|
| 86 | ! LFPART2 : .T. = second part of interpolations for changing geometry |
---|
| 87 | ! (pseudo-configuration 927) |
---|
| 88 | ! CFDIRLST : path of postprocessing listing file |
---|
| 89 | ! CNPPATH : directory of postprocessing namelist files |
---|
| 90 | |
---|
| 91 | ! ----- use of transmission coefficients stored in Fourier or spectral space: |
---|
| 92 | ! LRETCFOU : .T. = reading Fourier transmission coefficients on file |
---|
| 93 | ! for simplified physics. |
---|
| 94 | ! LWRTCFOU : .T. = writing Fourier transmission coefficients on file. |
---|
| 95 | ! LRFOUTCNORM: activates diagnostics on Fourier transmission coefficients. |
---|
| 96 | ! - LRFOUTCNORM(1)=.T.: global statistics. |
---|
| 97 | ! - LRFOUTCNORM(2)=.T.: statistics per latitude. |
---|
| 98 | ! - LRFOUTCNORM(3)=.T.: statistics per layer. |
---|
| 99 | ! - LRFOUTCNORM(4)=.T.: statistics per wavenumber. |
---|
| 100 | ! LRGPTCNORM : activates diagnostics on grid-point transmission coefficients. |
---|
| 101 | ! - LRGPTCNORM(1)=.T.: global statistics. |
---|
| 102 | ! - LRGPTCNORM(2)=.T.: statistics per latitude. |
---|
| 103 | ! - LRGPTCNORM(3)=.T.: statistics per layer. |
---|
| 104 | |
---|
| 105 | ! ----- other variables: |
---|
| 106 | ! LNF : .T. = start, .F. = restart |
---|
| 107 | ! LSMSSIG : .T. = send signals to SMS (ECMWF supervisor) |
---|
| 108 | ! LOPDIS : .T. = calls OPDIS |
---|
| 109 | ! NCYCLE : cycle identifier |
---|
| 110 | ! CNMEXP : name of the experiment |
---|
| 111 | ! An experiment is identified by its name (16 characters) |
---|
| 112 | ! and its cycle (typically same experiment but without a bug) |
---|
| 113 | ! CFCLASS : class for use by FDB |
---|
| 114 | ! CTYPE : type for use by FDB |
---|
| 115 | ! LBACKG : ??? |
---|
| 116 | ! LMINIM : ??? |
---|
| 117 | |
---|
| 118 | !========== MODEL SWITCHES ==================================================== |
---|
| 119 | ! Remark: this section containes some dynamical variables which cannot be |
---|
| 120 | ! put in NAMDYN because they are used in routines called before SUDYN |
---|
| 121 | ! and sometimes to allocate some arrays. |
---|
| 122 | |
---|
| 123 | ! ----- advection scheme, semi-Lagrangian scheme: |
---|
| 124 | ! LSLAG : .TRUE. = semi-lagrangian on |
---|
| 125 | ! LTWOTL : .TRUE. if two-time-level semi-Lagrangian scheme will be used |
---|
| 126 | ! LRFRIC : .TRUE. = Rayleigh friction in zonal wind (for p < 9.9hPa) |
---|
| 127 | ! LVERCOR : .T./.F.: thin layer hypothesis relaxed/applied. |
---|
| 128 | |
---|
| 129 | ! ----- vertical discretisation, vertical boundaries: |
---|
| 130 | ! LAPRXPK : way of computing full-levels pressures in primitive equation |
---|
| 131 | ! hydrostatic model. |
---|
| 132 | ! .T.: full levels are computed by PK=(PK+1/2 + PK-1/2)*0.5 |
---|
| 133 | ! .F.: full levels are computed by a more complicated formula |
---|
| 134 | ! consistent with "alpha" in geopotential formula. |
---|
| 135 | ! LREGETA : .T.: for the interlayer L, ETA(L)=L/NFLEVG |
---|
| 136 | ! .F.: for the interlayer L, ETA(L)=A(L)/P0+B(L) |
---|
| 137 | ! LRUBC : .T.: if radiational upper boundary condition |
---|
| 138 | |
---|
| 139 | ! ----- numbering of timesteps: |
---|
| 140 | ! NSTART : first timestep of model |
---|
| 141 | ! NSTOP : last timestep of model |
---|
| 142 | |
---|
| 143 | ! ----- quadrature: |
---|
| 144 | ! NQUAD : 1 ====> GAUSS |
---|
| 145 | |
---|
| 146 | ! ----- type of equations: |
---|
| 147 | ! LNHDYN : .T. if 3-D non-hydrostatic dynamics is active |
---|
| 148 | |
---|
| 149 | ! ----- way of computing initial state: |
---|
| 150 | ! N2DINI : 1 initialization for 2D with Haurwitz wave |
---|
| 151 | ! : 2 initialization for 2D with real fields |
---|
| 152 | ! N3DINI : 1 initialization for 3D with standard atmosphere |
---|
| 153 | ! (not available since cycle 12) |
---|
| 154 | ! : 0 initialization for 3D with real fields |
---|
| 155 | |
---|
| 156 | ! ----- semi-implicit scheme: |
---|
| 157 | ! LSITRIC : .T.: if "tridiagonal" solver is used for the vertically |
---|
| 158 | ! coupled semi-implicit equations |
---|
| 159 | |
---|
| 160 | ! ----- control of variables which are transformed in spectral space: |
---|
| 161 | ! LSPRT : .T.: if R*T/Rd "virtual temperature" as spectral variable |
---|
| 162 | |
---|
| 163 | ! ----- diagnostics and frequencies: |
---|
| 164 | ! NSPPR : 0: no spectrum printed in spnorm; only global norms averaged |
---|
| 165 | ! on the vertical are printed |
---|
| 166 | ! : 1: no spectrum printed in spnorm; only global norms averaged |
---|
| 167 | ! on the vertical and global norms on each layer are printed |
---|
| 168 | ! : 2: both total wavenumber spectrum and zonal wavenumber spectrum |
---|
| 169 | ! are printed |
---|
| 170 | ! NFRPOS : frequency of post-processing events (time-steps) |
---|
| 171 | ! NFRISP : frequency of isp (animation !) events (time-steps) |
---|
| 172 | ! NFRCO : frequency of coupled fields (time-steps) |
---|
| 173 | ! NFRCORM : mass correction frequency (>0 time-steps, <0 hours, 0 no |
---|
| 174 | ! correction) |
---|
| 175 | ! NFRHIS : frequency of history write_ups (time-steps) |
---|
| 176 | ! NFRMASSCON: frequency of mass conservation fixup (time-steps) |
---|
| 177 | ! NFRGDI : frequency of grid-point space diagnostics |
---|
| 178 | ! NFRSDI : frequency of spectral space diagnostics |
---|
| 179 | ! NFRDHFG : write-up frequency of global DDH |
---|
| 180 | ! NFRDHFZ : write-up frequency of zonal DDH |
---|
| 181 | ! NFRDHFD : write-up frequency of "limited domain" DDH |
---|
| 182 | ! NFRDHP : write-up frequency of DDH files |
---|
| 183 | ! NPOSTS : array containing postprocessing steps |
---|
| 184 | ! NPISPS : array containing isp (animation !) steps |
---|
| 185 | ! NHISTS : array containing history write-up steps |
---|
| 186 | ! NMASSCONS : array containing mass conservation fixup steps |
---|
| 187 | ! NGDITS : array containing grid point diagnostics steps |
---|
| 188 | ! NSDITS : array containing spectral diagnostics steps |
---|
| 189 | ! NDHFGTS : array containing write out steps for global DDH |
---|
| 190 | ! NDHFZTS : array containing write out steps for zonal means DDH |
---|
| 191 | ! NDHFDTS : array containing write out steps for limited areas DDH |
---|
| 192 | ! NDHPTS : array containing write out steps for DDH |
---|
| 193 | ! Explanation for N[XXX]TS: |
---|
| 194 | ! 1) if N[XXX]TS(0)=0 action if MOD(JSTEP,NFR[XXX])=0 |
---|
| 195 | ! 2) if N[XXX]TS(0)>0 N[XXX]TS(0) significant numbers in |
---|
| 196 | ! N[XXX]TS are then considered and: |
---|
| 197 | ! action for JSTEP=N[XXX]TS(.)*NFR[XXX] |
---|
| 198 | ! 3) IF N[XXX]TS(0)<0 |
---|
| 199 | ! action for JSTEP=(N[XXX]TS(.)/DELTAT)*NFR[XXX] |
---|
| 200 | |
---|
| 201 | !========== ASSIMILATION SWITCHES ============================================= |
---|
| 202 | |
---|
| 203 | ! LNOBGON : .F. if eq. .T. no stop if unsuccessful reading of CMA files |
---|
| 204 | ! LCANARI : .T. = term to control French OI |
---|
| 205 | ! LCASIG : .T. = interpolation of the model errors (French OI) |
---|
| 206 | ! LGUESS : .T. = term of first guess included |
---|
| 207 | ! LOBS : .T. = term of observations included |
---|
| 208 | ! LSIMOB : .T. = if simulated observations |
---|
| 209 | ! LOBSC1 : .T. = term of observations included in configuration 1 |
---|
| 210 | ! LSCREEN : .T. = observation screening for variational assimilation |
---|
| 211 | ! LSCREEN_OPENMP : .T. = 4DVAR screening runs in OpenMP-parallel mode over timeslots |
---|
| 212 | ! L_SPLIT_SCREEN .T. = to split screenng |
---|
| 213 | ! L_SCREEN_CALL: .T. = call to screening routine SCREEN |
---|
| 214 | ! LOBSREF : .T. = comparison to observation for the trajectory (NCONF=131) |
---|
| 215 | ! LIFSMIN : .T. = if running minimisation |
---|
| 216 | ! LIFSTRAJ: .T. = if running high resolution trajectory integration |
---|
| 217 | ! NCNTVAR : Definition of the control variable of a variational job. |
---|
| 218 | ! = 1 ===> control variables are model variables |
---|
| 219 | ! = 2 ===> control variables are normalized departures of |
---|
| 220 | ! model variables from the background field |
---|
| 221 | ! = 3 ===> .......... |
---|
| 222 | ! LOLDPP : .T. use "old" p.p. of T,Q,U and V |
---|
| 223 | ! NSTEPINI: Initial step in hours for the initial conditions |
---|
| 224 | ! at the beginning of 4D-Var trajectory (usually 3 hours). |
---|
| 225 | ! It is used to update the step while saving the FCs along |
---|
| 226 | ! the first trajectory. |
---|
| 227 | ! NINTERPTRAJ : Interpolation method applied to increments |
---|
| 228 | ! NINTERPINCR : Interpolation method applied to increments |
---|
| 229 | ! = 1 ===> Bi-linear interpolation (default) |
---|
| 230 | ! = 2 ===> Bi-cubic Rinterpolation |
---|
| 231 | ! = 3 ===> Conserving interpolation |
---|
| 232 | ! For Conserving interpolation the style is defined by: |
---|
| 233 | ! NINTERPTRAJORDER : order of interpolation for trajectories |
---|
| 234 | ! NINTERPINCRORDER : order of interpolation for increments |
---|
| 235 | ! NINTERPTRAJLIMIT : 0 if limiter is NOT used (default), 1 if used for trajectory interpolation |
---|
| 236 | ! NINTERPINCRLIMIT : 0 if limiter is NOT used (default), 1 if used for increment interpolation |
---|
| 237 | |
---|
| 238 | !========== ALADIN SWITCHES =================================================== |
---|
| 239 | |
---|
| 240 | ! LELAM : .T. = limited area model with coupling or fully biperiodic |
---|
| 241 | ! model (torus) |
---|
| 242 | ! .F. = global model (sphere) |
---|
| 243 | ! LRPLANE : .T. = plane cartesian geometry |
---|
| 244 | ! .F. = spherical geometry |
---|
| 245 | ! LTENC : TRUE if tendency coupling of surface pressure |
---|
| 246 | ! FALSE if no tend. coupling of surf. pressure |
---|
| 247 | ! LALLTC : used together with LTENC when LTENC=.T. |
---|
| 248 | ! - no meaning for quadratic tendency coupling, where just t1 coupling |
---|
| 249 | ! is applied at every NEFRCL time step |
---|
| 250 | ! - for lin. tendency coupling: |
---|
| 251 | ! TRUE if tendency coupling of surf. pres. at every step |
---|
| 252 | ! FALSE if tend. coupl., except at every NEFRCL time steps |
---|
| 253 | ! when just t1 coupling |
---|
| 254 | ! RTENC : multiplier of EALFA in the tendency coupling scheme |
---|
| 255 | ! for stability reasons (RTENC<=1. close to 1) |
---|
| 256 | |
---|
| 257 | !========== AROME SWITCH ====================================================== |
---|
| 258 | |
---|
| 259 | ! LAROME : .T. = AROME limited area model |
---|
| 260 | |
---|
| 261 | !========== ECMWF Single Column Model ========================================= |
---|
| 262 | ! LSCMEC : .T. = ECMWF Single Column Model |
---|
| 263 | ! LSFCFLX : .T. = forcing with surface fluxes (latent and sensible). |
---|
| 264 | ! REXTSHF : externally supplied sensible heat flux [W/m^2] |
---|
| 265 | ! REXTLHF : externally supplied latent heat flux [W/m^2] |
---|
| 266 | ! LROUGH : .T. = surface roughness length is externally specified |
---|
| 267 | ! REXTZ0M : externally supplied roughness length for momentum [m] |
---|
| 268 | ! REXTZ0H : externally supplied roughness length for heat [m] |
---|
| 269 | |
---|
| 270 | !========== DISTRIBUTED MEMORY SWITCHES ======================================= |
---|
| 271 | |
---|
| 272 | ! LMPOFF : .T. = switch off the message passing library initialisation |
---|
| 273 | ! requested for special cases LMESSP=.T. and NPROC=1 |
---|
| 274 | ! : .F. = (default) full message passing features |
---|
| 275 | ! NPROC : Total number of processors requested for this run |
---|
| 276 | ! N_REGIONS_NS : Number of regions (LEQ_REGIONS=T) or NPRGPNS (LEQ_REGIONS=F) |
---|
| 277 | ! N_REGIONS_EW : Maximum number of partitions for all regions |
---|
| 278 | ! N_REGIONS : Number of partitions in each region |
---|
| 279 | ! NPRGPNS : Number of processors used during grid-point phase in North-South |
---|
| 280 | ! direction (previously known as NPROCA) |
---|
| 281 | ! NPRGPEW : Number of processors used during grid-point phase in East-West |
---|
| 282 | ! direction (previously known as NPROCB) |
---|
| 283 | ! NPRTRNS : Number of processors used during transform phase in North-South |
---|
| 284 | ! direction (previously the same as NPROCA and now implemented |
---|
| 285 | ! such that NPRTRNS=NPTRW) |
---|
| 286 | ! NPRTRM : Number of processors used during spectral computations in |
---|
| 287 | ! meridional wave direction (previously the same as NPROCA |
---|
| 288 | ! and now implemented such that NPRTRM=NPTRW) |
---|
| 289 | ! NPRTRN : Number of processors used during spectral computations in total |
---|
| 290 | ! wave direction (previously the same as NPROCA and now implemented |
---|
| 291 | ! such that NPRTRN=NPTRV) |
---|
| 292 | ! NPRTRW : Number of processors used during transform phase in wave space |
---|
| 293 | ! (previously the same as NPROCA) |
---|
| 294 | ! NPRTRV : Number of processors used during transform phase in vertical |
---|
| 295 | ! direction (previously known as NPROCB) |
---|
| 296 | ! LOUTPUT : .T. = diagnostic output requested on this PE |
---|
| 297 | ! NOUTPUT : 0 = No diagnostic output |
---|
| 298 | ! 1 = Only diagnostic output from PE1 ( default ) |
---|
| 299 | ! 2 = Diagnostic output from all PEs into separate files |
---|
| 300 | ! LREFOUT : .T. compare to reference run |
---|
| 301 | ! LREFGEN : .T. to generate reference file |
---|
| 302 | ! LMPDIAG : .T. = extensive message passing diagnostic output requested |
---|
| 303 | |
---|
| 304 | !========== PC SCHEMES ======================================================== |
---|
| 305 | !---------------------------------------------- |
---|
| 306 | ! PC SCHEMES QUANTITIES CONSTANT DURING INTEGRATION |
---|
| 307 | !---------------------------------------------- |
---|
| 308 | |
---|
| 309 | ! LPC_FULL - full PC scheme switch (with reiterations of trajectories) |
---|
| 310 | |
---|
| 311 | ! LPC_OLD - iterative scheme without trajectories recalculations |
---|
| 312 | ! - with iteration of D3 terms (Bubnova et all., 1995) |
---|
| 313 | |
---|
| 314 | ! LPC_NESC - non-extrapolating two-time level SL SI scheme |
---|
| 315 | ! - X(t+dt/2) = X(t) during predictor |
---|
| 316 | |
---|
| 317 | !========== FORCING SWITCH ==================================================== |
---|
| 318 | ! LSFORC - switch to activate the large scale forcings in setup and cpg |
---|
| 319 | !============================================================================== |
---|
| 320 | |
---|
| 321 | ! * Parameters: |
---|
| 322 | INTEGER(KIND=JPIM), PARAMETER :: JPNPST=240 |
---|
| 323 | |
---|
| 324 | ! * Technical switches: |
---|
| 325 | INTEGER(KIND=JPIM) :: NCONF |
---|
| 326 | INTEGER(KIND=JPIM) :: NTASKS ! ?????? |
---|
| 327 | LOGICAL :: LALLOPR |
---|
| 328 | INTEGER(KIND=JPIM) :: NPRINTLEV |
---|
| 329 | LOGICAL :: LFDBOP |
---|
| 330 | LOGICAL :: LGRBOP |
---|
| 331 | LOGICAL :: LFBDAP |
---|
| 332 | LOGICAL :: LARPEGEF |
---|
| 333 | LOGICAL :: LARPEGEF_TRAJHR |
---|
| 334 | LOGICAL :: LARPEGEF_TRAJBG |
---|
| 335 | LOGICAL :: LARPEGEF_RDGP_INIT |
---|
| 336 | LOGICAL :: LARPEGEF_RDGP_TRAJHR |
---|
| 337 | LOGICAL :: LARPEGEF_RDGP_TRAJBG |
---|
| 338 | CHARACTER (LEN = 120) :: CNDISPP |
---|
| 339 | LOGICAL :: LFPOS |
---|
| 340 | CHARACTER (LEN = 6) :: CFPNCF |
---|
| 341 | LOGICAL :: LFPART2 |
---|
| 342 | CHARACTER (LEN = 120) :: CFDIRLST |
---|
| 343 | CHARACTER (LEN = 120) :: CNPPATH |
---|
| 344 | LOGICAL :: LRETCFOU |
---|
| 345 | LOGICAL :: LWRTCFOU |
---|
| 346 | LOGICAL :: LRFOUTCNORM(4) |
---|
| 347 | LOGICAL :: LRGPTCNORM(3) |
---|
| 348 | LOGICAL :: LNF |
---|
| 349 | LOGICAL :: LSMSSIG |
---|
| 350 | LOGICAL :: LOPDIS |
---|
| 351 | INTEGER(KIND=JPIM) :: NCYCLE=128 |
---|
| 352 | CHARACTER (LEN = 16) :: CNMEXP |
---|
| 353 | CHARACTER (LEN = 2) :: CFCLASS |
---|
| 354 | CHARACTER (LEN = 2) :: CTYPE |
---|
| 355 | LOGICAL :: LBACKG |
---|
| 356 | LOGICAL :: LMINIM |
---|
| 357 | |
---|
| 358 | ! * Model switches: |
---|
| 359 | LOGICAL :: LSLAG |
---|
| 360 | LOGICAL :: LTWOTL |
---|
| 361 | LOGICAL :: LRFRIC |
---|
| 362 | LOGICAL :: LVERCOR |
---|
| 363 | LOGICAL :: LAPRXPK |
---|
| 364 | LOGICAL :: LREGETA |
---|
| 365 | LOGICAL :: LRUBC |
---|
| 366 | INTEGER(KIND=JPIM) :: NSTART |
---|
| 367 | INTEGER(KIND=JPIM) :: NSTOP |
---|
| 368 | INTEGER(KIND=JPIM) :: NQUAD |
---|
| 369 | LOGICAL :: LNHDYN |
---|
| 370 | INTEGER(KIND=JPIM) :: N2DINI |
---|
| 371 | INTEGER(KIND=JPIM) :: N3DINI |
---|
| 372 | LOGICAL :: LSITRIC |
---|
| 373 | LOGICAL :: LSPRT |
---|
| 374 | INTEGER(KIND=JPIM) :: NSPPR |
---|
| 375 | INTEGER(KIND=JPIM) :: NFRPOS |
---|
| 376 | INTEGER(KIND=JPIM) :: NFRISP |
---|
| 377 | INTEGER(KIND=JPIM) :: NFRCORM |
---|
| 378 | INTEGER(KIND=JPIM) :: NFRCO |
---|
| 379 | INTEGER(KIND=JPIM) :: NFRHIS |
---|
| 380 | INTEGER(KIND=JPIM) :: NFRMASSCON |
---|
| 381 | INTEGER(KIND=JPIM) :: NFRGDI |
---|
| 382 | INTEGER(KIND=JPIM) :: NFRSDI |
---|
| 383 | INTEGER(KIND=JPIM) :: NFRDHFG |
---|
| 384 | INTEGER(KIND=JPIM) :: NFRDHFZ |
---|
| 385 | INTEGER(KIND=JPIM) :: NFRDHFD |
---|
| 386 | INTEGER(KIND=JPIM) :: NFRDHP |
---|
| 387 | INTEGER(KIND=JPIM) :: NPOSTS(0:JPNPST) |
---|
| 388 | INTEGER(KIND=JPIM) :: NPISPS(0:JPNPST) |
---|
| 389 | INTEGER(KIND=JPIM) :: NHISTS(0:JPNPST) |
---|
| 390 | INTEGER(KIND=JPIM) :: NMASSCONS(0:JPNPST) |
---|
| 391 | INTEGER(KIND=JPIM) :: NGDITS(0:JPNPST) |
---|
| 392 | INTEGER(KIND=JPIM) :: NSDITS(0:JPNPST) |
---|
| 393 | INTEGER(KIND=JPIM) :: NDHFGTS(0:JPNPST) |
---|
| 394 | INTEGER(KIND=JPIM) :: NDHFZTS(0:JPNPST) |
---|
| 395 | INTEGER(KIND=JPIM) :: NDHFDTS(0:JPNPST) |
---|
| 396 | INTEGER(KIND=JPIM) :: NDHPTS(0:JPNPST) |
---|
| 397 | |
---|
| 398 | ! * Assimilation: |
---|
| 399 | LOGICAL :: LNOBGON |
---|
| 400 | LOGICAL :: LCANARI |
---|
| 401 | LOGICAL :: LCASIG |
---|
| 402 | LOGICAL :: LGUESS |
---|
| 403 | LOGICAL :: LOBS |
---|
| 404 | LOGICAL :: LSIMOB |
---|
| 405 | LOGICAL :: LOBSC1 |
---|
| 406 | LOGICAL :: LSCREEN |
---|
| 407 | LOGICAL :: LSCREEN_OPENMP |
---|
| 408 | LOGICAL :: L_SPLIT_SCREEN |
---|
| 409 | LOGICAL :: L_SCREEN_CALL |
---|
| 410 | LOGICAL :: LOBSREF |
---|
| 411 | LOGICAL :: LIFSMIN |
---|
| 412 | LOGICAL :: LIFSTRAJ |
---|
| 413 | INTEGER(KIND=JPIM) :: NCNTVAR |
---|
| 414 | LOGICAL :: LOLDPP |
---|
| 415 | INTEGER(KIND=JPIM) :: NSTEPINI |
---|
| 416 | INTEGER(KIND=JPIM) :: NINTERPTRAJ |
---|
| 417 | INTEGER(KIND=JPIM) :: NINTERPINCR |
---|
| 418 | INTEGER(KIND=JPIM) :: NINTERPTRAJLIMIT |
---|
| 419 | INTEGER(KIND=JPIM) :: NINTERPINCRLIMIT |
---|
| 420 | INTEGER(KIND=JPIM) :: NINTERPTRAJORDER |
---|
| 421 | INTEGER(KIND=JPIM) :: NINTERPINCRORDER |
---|
| 422 | |
---|
| 423 | ! * ALADIN: |
---|
| 424 | LOGICAL :: LELAM |
---|
| 425 | LOGICAL :: LRPLANE |
---|
| 426 | LOGICAL :: LTENC |
---|
| 427 | LOGICAL :: LALLTC |
---|
| 428 | REAL(KIND=JPRB) :: RTENC |
---|
| 429 | |
---|
| 430 | ! * AROME: |
---|
| 431 | LOGICAL :: LAROME |
---|
| 432 | |
---|
| 433 | ! * ECMWF Single Column Model: |
---|
| 434 | LOGICAL :: LSCMEC |
---|
| 435 | LOGICAL :: LSFCFLX |
---|
| 436 | REAL(KIND=JPRB) :: REXTSHF |
---|
| 437 | REAL(KIND=JPRB) :: REXTLHF |
---|
| 438 | LOGICAL :: LROUGH |
---|
| 439 | REAL(KIND=JPRB) :: REXTZ0M |
---|
| 440 | REAL(KIND=JPRB) :: REXTZ0H |
---|
| 441 | |
---|
| 442 | ! * Distributed memory: |
---|
| 443 | LOGICAL :: LMPOFF |
---|
| 444 | INTEGER(KIND=JPIM) :: NPROC |
---|
| 445 | INTEGER(KIND=JPIM) :: N_REGIONS_NS |
---|
| 446 | INTEGER(KIND=JPIM) :: N_REGIONS_EW |
---|
| 447 | INTEGER(KIND=JPIM),ALLOCATABLE :: N_REGIONS(:) |
---|
| 448 | INTEGER(KIND=JPIM) :: NPRGPNS |
---|
| 449 | INTEGER(KIND=JPIM) :: NPRGPEW |
---|
| 450 | INTEGER(KIND=JPIM) :: NPRTRNS |
---|
| 451 | INTEGER(KIND=JPIM) :: NPRTRM |
---|
| 452 | INTEGER(KIND=JPIM) :: NPRTRN |
---|
| 453 | INTEGER(KIND=JPIM) :: NPRTRW |
---|
| 454 | INTEGER(KIND=JPIM) :: NPRTRV |
---|
| 455 | LOGICAL :: LOUTPUT |
---|
| 456 | INTEGER(KIND=JPIM) :: NOUTPUT |
---|
| 457 | LOGICAL :: LREFOUT |
---|
| 458 | LOGICAL :: LREFGEN |
---|
| 459 | LOGICAL :: LMPDIAG |
---|
| 460 | |
---|
| 461 | ! * PC schemes. |
---|
| 462 | LOGICAL :: LPC_FULL |
---|
| 463 | LOGICAL :: LPC_OLD |
---|
| 464 | LOGICAL :: LPC_NESC |
---|
| 465 | ! |
---|
| 466 | ! * FORCING |
---|
| 467 | LOGICAL :: LSFORC |
---|
| 468 | ! ------------------------------------------------------------------ |
---|
[2056] | 469 | !$OMP THREADPRIVATE(cfclass,cfdirlst,cfpncf,cndispp,cnmexp,cnppath,ctype,l_screen_call,l_split_screen,lallopr,lalltc) |
---|
| 470 | !$OMP THREADPRIVATE(laprxpk,larome,larpegef,larpegef_rdgp_init,larpegef_rdgp_trajbg,larpegef_rdgp_trajhr) |
---|
| 471 | !$OMP THREADPRIVATE(larpegef_trajbg,larpegef_trajhr,lbackg,lcanari,lcasig,lelam,lfbdap,lfdbop,lfpart2,lfpos) |
---|
| 472 | !$OMP THREADPRIVATE(lgrbop,lguess,lifsmin,lifstraj,lminim,lmpdiag,lmpoff,lnf,lnhdyn,lnobgon,lobs,lobsc1,lobsref) |
---|
| 473 | !$OMP THREADPRIVATE(loldpp,lopdis,loutput,lpc_full,lpc_nesc,lpc_old,lrefgen,lrefout,lregeta,lretcfou,lrfoutcnorm) |
---|
| 474 | !$OMP THREADPRIVATE(lrfric,lrgptcnorm,lrough,lrplane,lrubc,lscmec,lscreen,lscreen_openmp,lsfcflx,lsforc,lsimob) |
---|
| 475 | !$OMP THREADPRIVATE(lsitric,lslag,lsmssig,lsprt,ltenc,ltwotl,lvercor,lwrtcfou,n2dini,n3dini,n_regions_ew,n_regions_ns) |
---|
| 476 | !$OMP THREADPRIVATE(ncntvar,nconf,ncycle,ndhfdts,ndhfgts,ndhfzts,ndhpts,nfrco,nfrcorm,nfrdhfd,nfrdhfg,nfrdhfz,nfrdhp) |
---|
| 477 | !$OMP THREADPRIVATE(nfrgdi,nfrhis,nfrisp,nfrmasscon,nfrpos,nfrsdi,ngdits,nhists,ninterpincr,ninterpincrlimit) |
---|
| 478 | !$OMP THREADPRIVATE(ninterpincrorder,ninterptraj,ninterptrajlimit,ninterptrajorder,nmasscons,noutput,npisps,nposts) |
---|
| 479 | !$OMP THREADPRIVATE(nprgpew,nprgpns,nprintlev,nproc,nprtrm,nprtrn,nprtrns,nprtrv,nprtrw,nquad,nsdits,nsppr,nstart) |
---|
| 480 | !$OMP THREADPRIVATE(nstepini,nstop,ntasks,rextlhf,rextshf,rextz0h,rextz0m,rtenc) |
---|
| 481 | !$OMP THREADPRIVATE(n_regions) |
---|
[1989] | 482 | END MODULE YOMCT0 |
---|