forked from KuangLab-Harvard/SAM_SRCv6.11
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgrid.f90
172 lines (141 loc) · 8.37 KB
/
grid.f90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
module grid
use domain
use advection, only: NADV, NADVS
implicit none
character(7), parameter :: version = '6.11.8 '
character(8), parameter :: version_date = 'July 2022'
integer, parameter :: nx = nx_gl/nsubdomains_x
integer, parameter :: ny = ny_gl/nsubdomains_y
integer, parameter :: nz = nz_gl+1
integer, parameter :: nzm = nz-1
integer, parameter :: nsubdomains = nsubdomains_x * nsubdomains_y
logical, parameter :: RUN3D = ny_gl.gt.1
logical, parameter :: RUN2D = .not.RUN3D
integer, parameter :: nxp1 = nx + 1
integer, parameter :: nyp1 = ny + 1 * YES3D
integer, parameter :: nxp2 = nx + 2
integer, parameter :: nyp2 = ny + 2 * YES3D
integer, parameter :: nxp3 = nx + 3
integer, parameter :: nyp3 = ny + 3 * YES3D
integer, parameter :: nxp4 = nx + 4
integer, parameter :: nyp4 = ny + 4 * YES3D
integer, parameter :: dimx1_u = -1 !!-1 -1 -1 -1
integer, parameter :: dimx2_u = nxp3 !!nxp3 nxp3 nxp3 nxp3
integer, parameter :: dimy1_u = 1-(2+NADV)*YES3D !!1-5*YES3D 1-4*YES3D 1-3*YES3D 1-2*YES3D
integer, parameter :: dimy2_u = nyp2+NADV !!nyp5 nyp4 nyp3 nyp2
integer, parameter :: dimx1_v = -1-NADV !!-4 -3 -2 -1
integer, parameter :: dimx2_v = nxp2+NADV !!nxp5 nxp4 nxp3 nxp2
integer, parameter :: dimy1_v = 1-2*YES3D !!1-2*YES3D 1-2*YES3D 1-2*YES3D 1-2*YES3D
integer, parameter :: dimy2_v = nyp3 !!nyp3 nyp3 nyp3 nyp3
integer, parameter :: dimx1_w = -1-NADV !!-4 -3 -2 -1
integer, parameter :: dimx2_w = nxp2+NADV !!nxp5 nxp4 nxp3 nxp2
integer, parameter :: dimy1_w = 1-(2+NADV)*YES3D !!1-5*YES3D 1-4*YES3D 1-3*YES3D 1-2*YES3D
integer, parameter :: dimy2_w = nyp2+NADV !!nyp5 nyp4 nyp3 nyp2
integer, parameter :: dimx1_s = -2-NADVS !!-4 -3 -2 -2
integer, parameter :: dimx2_s = nxp3+NADVS !!nxp5 nxp4 nxp3 nxp3
integer, parameter :: dimy1_s = 1-(3+NADVS)*YES3D !!1-5*YES3D 1-4*YES3D 1-3*YES3D 1-3*YES3D
integer, parameter :: dimy2_s = nyp3+NADVS !!nyp5 nyp4 nyp3 nyp3
integer, parameter :: ncols = nx*ny
integer, parameter :: nadams = 3
! Vertical grid parameters:
real z(nz) ! height of the pressure levels above surface,m
real pres(nzm) ! pressure,mb at scalar levels
real zi(nz) ! height of the interface levels
real presi(nz) ! pressure,mb at interface levels
real adz(nzm) ! ratio of the thickness of scalar levels to dz
real adzw(nz) ! ratio of the thinckness of w levels to dz
real pres0 ! Reference surface pressure, Pa
integer:: nstep =0! current number of performed time steps
integer ncycle ! number of subcycles over the dynamical timestep
integer icycle ! current subcycle
real cfl_adv ! CFL due to advection
real cfl_advh ! CFL due to advection (horizontal)
real cfl_advz ! CFL due to advection (vertical)
real cfl_sgs ! CFL due to SGS
integer:: na=1, nb=2, nc=3 ! indeces for swapping the rhs arrays for AB scheme
real at, bt, ct ! coefficients for the Adams-Bashforth scheme
real dtn ! current dynamical timestep (can be smaller than dt)
real dt3(3) ! dynamical timesteps for three most recent time steps
real(8):: time=0. ! current time in sec.
real day ! current day (including fraction)
real dtfactor ! dtn/dt
! MPI staff:
integer rank ! rank of the current subdomain task (default 0)
integer ranknn ! rank of the "northern" subdomain task
integer rankss ! rank of the "southern" subdomain task
integer rankee ! rank of the "eastern" subdomain task
integer rankww ! rank of the "western" subdomain task
integer rankne ! rank of the "north-eastern" subdomain task
integer ranknw ! rank of the "north-western" subdomain task
integer rankse ! rank of the "south-eastern" subdomain task
integer ranksw ! rank of the "south-western" subdomain task
logical dompi ! logical switch to do multitasking
logical masterproc ! .true. if rank.eq.0
character(80) case ! id-string to identify a case-name(set in CaseName file)
logical dostatis ! flag to permit the gathering of statistics
logical dostatisrad ! flag to permit the gathering of radiation statistics
integer nstatis ! the interval between substeps to compute statistics
logical :: compute_reffc = .false.
logical :: compute_reffi = .false.
logical notopened2D ! flag to see if the 2D output datafile is opened
logical notopened3D ! flag to see if the 3D output datafile is opened
logical notopenedmom ! flag to see if the statistical moment file is opened
!-----------------------------------------
! Parameters controled by namelist PARAMETERS
real:: dx =0. ! grid spacing in x direction
real:: dy =0. ! grid spacing in y direction
real:: dz =0. ! constant grid spacing in z direction (when dz_constant=.true.)
logical:: doconstdz = .false. ! do constant vertical grid spacing set by dz
integer:: nstop =0 ! time step number to stop the integration
integer:: nelapse =999999999! time step number to elapse before stoping
integer:: nelapsemin=999999999 !bloss: number of wallclock minutes to run before stopping
real:: dt=0. ! dynamical timestep
real:: day0=0. ! starting day (including fraction)
integer:: nrad =1 ! frequency of calling the radiation routines
integer:: nprint =1000 ! frequency of printing a listing (steps)
integer:: nrestart =0 ! switch to control starting/restarting of the model
integer:: nstat =1000 ! the interval in time steps to compute statistics
integer:: nstatfrq =50 ! frequency of computing statistics
logical:: restart_sep =.false. ! write separate restart files for sub-domains
integer:: nrestart_skip =0 ! number of skips of writing restart (default 0)
logical:: output_sep =.false. ! write separate 3D and 2D files for sub-domains
character(80):: caseid =''! id-string to identify a run
character(80):: caseid_restart =''! id-string for branch restart file
character(80):: case_restart =''! id-string for branch restart file
logical:: doisccp = .false.
logical:: domodis = .false.
logical:: domisr = .false.
logical:: dosimfilesout = .false.
logical:: doSAMconditionals = .false. !core updraft,downdraft conditional statistics
logical:: dosatupdnconditionals = .false.!cloudy updrafts,downdrafts and cloud-free
logical:: doscamiopdata = .false.! initialize the case from a SCAM IOP netcdf input file
logical:: dozero_out_day0 = .false.
character(len=120):: iopfile=''
character(256):: rundatadir ='./RUNDATA' ! path to data directory
integer:: nsave3D =1000 ! frequency of writting 3D fields (steps)
integer:: nsave3Dstart =99999999! timestep to start writting 3D fields
integer:: nsave3Dend =99999999 ! timestep to end writting 3D fields
logical:: save3Dbin =.false. ! save 3D data in binary format(no 2-byte compression)
logical:: save3Dsep =.false. ! use separate file for each time point for2-model
real :: qnsave3D =0. !threshold manimum cloud water(kg/kg) to save 3D fields
logical:: dogzip3D =.false. ! gzip compress a 3D output file
logical:: rad3Dout = .false. ! output additional 3D radiation foelds (like reff)
integer:: nsave2D =1000 ! frequency of writting 2D fields (steps)
integer:: nsave2Dstart =99999999! timestep to start writting 2D fields
integer:: nsave2Dend =99999999 ! timestep to end writting 2D fields
logical:: save2Dbin =.false. ! save 2D data in binary format, rather than compressed
logical:: save2Dsep =.false. ! write separate file for each time point for 2D output
logical:: save2Davg =.false. ! flag to time-average 2D output fields (default .false.)
logical:: dogzip2D =.false. ! gzip compress a 2D output file if save2Dsep=.true.
integer:: nstatmom =1000! frequency of writting statistical moment fields (steps)
integer:: nstatmomstart =99999999! timestep to start writting statistical moment fields
integer:: nstatmomend =99999999 ! timestep to end writting statistical moment fields
logical:: savemomsep =.false.! use one file with stat moments for each time point
logical:: savemombin =.false.! save statistical moment data in binary format
integer:: nmovie =1000! frequency of writting movie fields (steps)
integer:: nmoviestart =99999999! timestep to start writting statistical moment fields
integer:: nmovieend =99999999 ! timestep to end writting statistical moment fields
logical :: isInitialized_scamiopdata = .false.
logical :: wgls_holds_omega = .false.
!-----------------------------------------
end module grid