CCPP SciDoc v7.0.x  v7.0.0
Common Community Physics Package Developed at DTC
 
Loading...
Searching...
No Matches
rrtmgp_sw_gas_optics.F90
1
3
7 use mo_rte_kind, only: wl, wp
8 use mo_gas_optics_rrtmgp, only: ty_gas_optics_rrtmgp
9 use mo_gas_concentrations, only: ty_gas_concs
10 use radiation_tools, only: check_error_msg
11 use netcdf
12 use mpi_f08
13
14 implicit none
15 real(wp),parameter :: &
16 tsi_default = 1360.85767381726, &
17 mg_default = 0.1567652, &
18 sb_default = 902.7126
19
20 ! RRTMGP k-distribution LUTs.
21 type(ty_gas_optics_rrtmgp) :: sw_gas_props
22 integer :: &
23 ntempssw, npresssw, ngptssw, nabsorberssw, nextrabsorberssw, nminorabsorberssw, &
24 nmixingfracssw, nlayerssw, nbndssw, npairssw, nminor_absorber_intervals_lowersw,&
25 nminor_absorber_intervals_uppersw, ncontributors_lowersw, ncontributors_uppersw
26 integer, dimension(:), allocatable :: &
27 kminor_start_lowersw, & !< Starting index in the [1, nContributors] vector for a contributor
28
29 kminor_start_uppersw
31 integer, dimension(:,:), allocatable :: &
32 band2gptsw, & !< Beginning and ending gpoint for each band
33 minor_limits_gpt_lowersw, & !< Beginning and ending gpoint for each minor interval in lower atmosphere
34 minor_limits_gpt_uppersw
35 integer, dimension(:,:,:), allocatable :: &
36 key_speciessw
37 real(wp) :: &
38 press_ref_tropsw, & !< Reference pressure separating the lower and upper atmosphere [Pa]
39 temp_ref_psw, & !< Standard spectroscopic reference pressure [Pa]
40 temp_ref_tsw, & !< Standard spectroscopic reference temperature [K]
41 tsi_defaultsw, & !<
42 mg_defaultsw, & !< Mean value of Mg2 index over the average solar cycle from the NRLSSI2 model of solar variability
43 sb_defaultsw
44 real(wp), dimension(:), allocatable :: &
45 press_refsw, & !< Pressures for reference atmosphere; press_ref(# reference layers) [Pa]
46 temp_refsw, & !< Temperatures for reference atmosphere; temp_ref(# reference layers) [K]
47 solar_quietsw, & !< Spectrally-dependent quiet sun irradiance from the NRLSSI2 model of solar variability
48 solar_facularsw, & !< Spectrally-dependent facular term from the NRLSSI2 model of solar variability
49 solar_sunspotsw
50 real(wp), dimension(:,:), allocatable :: &
51 band_limssw
52 real(wp), dimension(:,:,:), allocatable :: &
53 vmr_refsw, & !< Volume mixing ratios for reference atmosphere
54 kminor_lowersw, & !< (transformed from [nTemp x nEta x nGpt x nAbsorbers] array to
55
56 kminor_uppersw, &
58 rayl_lowersw, &
59 rayl_uppersw
60 real(wp), dimension(:,:,:,:), allocatable :: &
61 kmajorsw
62 character(len=32), dimension(:), allocatable :: &
63 gas_namessw, & !< Names of absorbing gases
64 gas_minorsw, & !< Name of absorbing minor gas
65 identifier_minorsw, & !< Unique string identifying minor gas
66 minor_gases_lowersw, & !< Names of minor absorbing gases in lower atmosphere
67 minor_gases_uppersw, & !< Names of minor absorbing gases in upper atmosphere
68 scaling_gas_lowersw, & !< Absorption also depends on the concentration of this gas
69 scaling_gas_uppersw
70 logical(wl), dimension(:), allocatable :: &
71 minor_scales_with_density_lowersw, & !< Density scaling is applied to minor absorption coefficients
72 minor_scales_with_density_uppersw, & !< Density scaling is applied to minor absorption coefficients
73 scale_by_complement_lowersw, & !< Absorption is scaled by concentration of scaling_gas (F) or its complement (T)
74 scale_by_complement_uppersw
75contains
76
85 subroutine rrtmgp_sw_gas_optics_init(rrtmgp_root_dir, rrtmgp_sw_file_gas, &
86 active_gases_array, mpicomm, mpirank, mpiroot, errmsg, errflg)
87
88 ! Inputs
89 character(len=128),intent(in) :: &
90 rrtmgp_root_dir, & !< RTE-RRTMGP root directory
91 rrtmgp_sw_file_gas
92 character(len=*), dimension(:), intent(in) :: &
93 active_gases_array
94 type(mpi_comm),intent(in) :: &
95 mpicomm
96 integer,intent(in) :: &
97 mpirank, & !< Current MPI rank
98 mpiroot
99
100 ! Outputs
101 character(len=*), intent(out) :: &
102 errmsg
103 integer, intent(out) :: &
104 errflg
105
106 ! Local variables
107 integer :: status, ncid, dimid, varID, mpierr, iChar
108 integer,dimension(:),allocatable :: temp1, temp2, temp3, temp4
109 character(len=264) :: sw_gas_props_file
110 type(ty_gas_concs) :: gas_concs ! RRTMGP DDT containing active trace gases
111
112 ! Initialize
113 errmsg = ''
114 errflg = 0
115
116 ! Filenames are set in the gfphysics_nml
117 sw_gas_props_file = trim(rrtmgp_root_dir)//trim(rrtmgp_sw_file_gas)
118
119 ! #######################################################################################
120 !
121 ! Read dimensions for k-distribution fields...
122 ! (ONLY master processor(0), if MPI enabled)
123 !
124 ! #######################################################################################
125 if (mpirank .eq. mpiroot) then
126 write (*,*) 'Reading RRTMGP shortwave k-distribution metadata ... '
127
128 ! Open file
129 status = nf90_open(trim(sw_gas_props_file), nf90_nowrite, ncid)
130
131 ! Read dimensions for k-distribution fields
132 status = nf90_inq_dimid(ncid, 'temperature', dimid)
133 status = nf90_inquire_dimension(ncid, dimid, len=ntempssw)
134 status = nf90_inq_dimid(ncid, 'pressure', dimid)
135 status = nf90_inquire_dimension(ncid, dimid, len=npresssw)
136 status = nf90_inq_dimid(ncid, 'absorber', dimid)
137 status = nf90_inquire_dimension(ncid, dimid, len=nabsorberssw)
138 status = nf90_inq_dimid(ncid, 'minor_absorber',dimid)
139 status = nf90_inquire_dimension(ncid, dimid, len=nminorabsorberssw)
140 status = nf90_inq_dimid(ncid, 'absorber_ext', dimid)
141 status = nf90_inquire_dimension(ncid, dimid, len=nextrabsorberssw)
142 status = nf90_inq_dimid(ncid, 'mixing_fraction', dimid)
143 status = nf90_inquire_dimension(ncid, dimid, len=nmixingfracssw)
144 status = nf90_inq_dimid(ncid, 'atmos_layer', dimid)
145 status = nf90_inquire_dimension(ncid, dimid, len=nlayerssw)
146 status = nf90_inq_dimid(ncid, 'bnd', dimid)
147 status = nf90_inquire_dimension(ncid, dimid, len=nbndssw)
148 status = nf90_inq_dimid(ncid, 'gpt', dimid)
149 status = nf90_inquire_dimension(ncid, dimid, len=ngptssw)
150 status = nf90_inq_dimid(ncid, 'pair', dimid)
151 status = nf90_inquire_dimension(ncid, dimid, len=npairssw)
152 status = nf90_inq_dimid(ncid, 'contributors_lower',dimid)
153 status = nf90_inquire_dimension(ncid, dimid, len=ncontributors_lowersw)
154 status = nf90_inq_dimid(ncid, 'contributors_upper', dimid)
155 status = nf90_inquire_dimension(ncid, dimid, len=ncontributors_uppersw)
156 status = nf90_inq_dimid(ncid, 'minor_absorber_intervals_lower', dimid)
157 status = nf90_inquire_dimension(ncid, dimid, len=nminor_absorber_intervals_lowersw)
158 status = nf90_inq_dimid(ncid, 'minor_absorber_intervals_upper', dimid)
159 status = nf90_inquire_dimension(ncid, dimid, len=nminor_absorber_intervals_uppersw)
160
161 endif ! On master processor
162
163 ! Other processors waiting...
164 call mpi_barrier(mpicomm, mpierr)
165
166 ! #######################################################################################
167 !
168 ! Broadcast dimensions...
169 ! (ALL processors)
170 !
171 ! #######################################################################################
172 call mpi_bcast(nbndssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
173 call mpi_bcast(ngptssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
174 call mpi_bcast(nmixingfracssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
175 call mpi_bcast(ntempssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
176 call mpi_bcast(npresssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
177 call mpi_bcast(nabsorberssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
178 call mpi_bcast(nextrabsorberssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
179 call mpi_bcast(nminorabsorberssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
180 call mpi_bcast(nlayerssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
181 call mpi_bcast(npairssw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
182 call mpi_bcast(ncontributors_uppersw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
183 call mpi_bcast(ncontributors_lowersw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
184 call mpi_bcast(nminor_absorber_intervals_uppersw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
185 call mpi_bcast(nminor_absorber_intervals_lowersw, 1, mpi_integer, mpiroot, mpicomm, mpierr)
186
187 ! #######################################################################################
188 !
189 ! Allocate space for arrays...
190 ! (ALL processors)
191 !
192 ! #######################################################################################
193 if (.not. allocated(gas_namessw)) &
194 allocate(gas_namessw(nabsorberssw))
195 if (.not. allocated(scaling_gas_lowersw)) &
196 allocate(scaling_gas_lowersw(nminor_absorber_intervals_lowersw))
197 if (.not. allocated(scaling_gas_uppersw)) &
198 allocate(scaling_gas_uppersw(nminor_absorber_intervals_uppersw))
199 if (.not. allocated(gas_minorsw)) &
200 allocate(gas_minorsw(nminorabsorberssw))
201 if (.not. allocated(identifier_minorsw)) &
202 allocate(identifier_minorsw(nminorabsorberssw))
203 if (.not. allocated(minor_gases_lowersw)) &
204 allocate(minor_gases_lowersw(nminor_absorber_intervals_lowersw))
205 if (.not. allocated(minor_gases_uppersw)) &
206 allocate(minor_gases_uppersw(nminor_absorber_intervals_uppersw))
207 if (.not. allocated(minor_limits_gpt_lowersw)) &
208 allocate(minor_limits_gpt_lowersw(npairssw,nminor_absorber_intervals_lowersw))
209 if (.not. allocated(minor_limits_gpt_uppersw)) &
210 allocate(minor_limits_gpt_uppersw(npairssw,nminor_absorber_intervals_uppersw))
211 if (.not. allocated(band2gptsw)) &
212 allocate(band2gptsw(2,nbndssw))
213 if (.not. allocated(key_speciessw)) &
214 allocate(key_speciessw(2,nlayerssw,nbndssw))
215 if (.not. allocated(band_limssw)) &
216 allocate(band_limssw(2,nbndssw))
217 if (.not. allocated(press_refsw)) &
218 allocate(press_refsw(npresssw))
219 if (.not. allocated(temp_refsw)) &
220 allocate(temp_refsw(ntempssw))
221 if (.not. allocated(vmr_refsw)) &
222 allocate(vmr_refsw(nlayerssw, nextrabsorberssw, ntempssw))
223 if (.not. allocated(kminor_lowersw)) &
224 allocate(kminor_lowersw(ncontributors_lowersw, nmixingfracssw, ntempssw))
225 if (.not. allocated(kmajorsw)) &
226 allocate(kmajorsw(ngptssw, nmixingfracssw, npresssw+1, ntempssw))
227 if (.not. allocated(kminor_start_lowersw)) &
228 allocate(kminor_start_lowersw(nminor_absorber_intervals_lowersw))
229 if (.not. allocated(kminor_uppersw)) &
230 allocate(kminor_uppersw(ncontributors_uppersw, nmixingfracssw, ntempssw))
231 if (.not. allocated(kminor_start_uppersw)) &
232 allocate(kminor_start_uppersw(nminor_absorber_intervals_uppersw))
233 if (.not. allocated(minor_scales_with_density_lowersw)) &
234 allocate(minor_scales_with_density_lowersw(nminor_absorber_intervals_lowersw))
235 if (.not. allocated(minor_scales_with_density_uppersw)) &
236 allocate(minor_scales_with_density_uppersw(nminor_absorber_intervals_uppersw))
237 if (.not. allocated(scale_by_complement_lowersw)) &
238 allocate(scale_by_complement_lowersw(nminor_absorber_intervals_lowersw))
239 if (.not. allocated(scale_by_complement_uppersw)) &
240 allocate(scale_by_complement_uppersw(nminor_absorber_intervals_uppersw))
241 if (.not. allocated(rayl_uppersw)) &
242 allocate(rayl_uppersw(ngptssw, nmixingfracssw, ntempssw))
243 if (.not. allocated(rayl_lowersw)) &
244 allocate(rayl_lowersw(ngptssw, nmixingfracssw, ntempssw))
245 if (.not. allocated(solar_quietsw)) &
246 allocate(solar_quietsw(ngptssw))
247 if (.not. allocated(solar_facularsw)) &
248 allocate(solar_facularsw(ngptssw))
249 if (.not. allocated(solar_sunspotsw)) &
250 allocate(solar_sunspotsw(ngptssw))
251 if (.not. allocated(temp1)) &
252 allocate(temp1(nminor_absorber_intervals_lowersw))
253 if (.not. allocated(temp2)) &
254 allocate(temp2(nminor_absorber_intervals_uppersw))
255 if (.not. allocated(temp3)) &
256 allocate(temp3(nminor_absorber_intervals_lowersw))
257 if (.not. allocated(temp4)) &
258 allocate(temp4(nminor_absorber_intervals_uppersw))
259
260 ! #######################################################################################
261 !
262 ! Read in data ...
263 ! (ONLY master processor(0), if MPI enabled)
264 !
265 ! #######################################################################################
266 if (mpirank .eq. mpiroot) then
267 write (*,*) 'Reading RRTMGP shortwave k-distribution data ... '
268 status = nf90_inq_varid(ncid, 'gas_names', varid)
269 status = nf90_get_var( ncid, varid, gas_namessw)
270 status = nf90_inq_varid(ncid, 'scaling_gas_lower', varid)
271 status = nf90_get_var( ncid, varid, scaling_gas_lowersw)
272 status = nf90_inq_varid(ncid, 'scaling_gas_upper', varid)
273 status = nf90_get_var( ncid, varid, scaling_gas_uppersw)
274 status = nf90_inq_varid(ncid, 'gas_minor', varid)
275 status = nf90_get_var( ncid, varid, gas_minorsw)
276 status = nf90_inq_varid(ncid, 'identifier_minor', varid)
277 status = nf90_get_var( ncid, varid, identifier_minorsw)
278 status = nf90_inq_varid(ncid, 'minor_gases_lower', varid)
279 status = nf90_get_var( ncid, varid, minor_gases_lowersw)
280 status = nf90_inq_varid(ncid, 'minor_gases_upper', varid)
281 status = nf90_get_var( ncid, varid, minor_gases_uppersw)
282 status = nf90_inq_varid(ncid, 'minor_limits_gpt_lower', varid)
283 status = nf90_get_var( ncid, varid, minor_limits_gpt_lowersw)
284 status = nf90_inq_varid(ncid, 'minor_limits_gpt_upper', varid)
285 status = nf90_get_var( ncid, varid, minor_limits_gpt_uppersw)
286 status = nf90_inq_varid(ncid, 'bnd_limits_gpt', varid)
287 status = nf90_get_var( ncid, varid, band2gptsw)
288 status = nf90_inq_varid(ncid, 'key_species', varid)
289 status = nf90_get_var( ncid, varid, key_speciessw)
290 status = nf90_inq_varid(ncid,'bnd_limits_wavenumber', varid)
291 status = nf90_get_var( ncid, varid, band_limssw)
292 status = nf90_inq_varid(ncid, 'press_ref', varid)
293 status = nf90_get_var( ncid, varid, press_refsw)
294 status = nf90_inq_varid(ncid, 'temp_ref', varid)
295 status = nf90_get_var( ncid, varid, temp_refsw)
296 status = nf90_inq_varid(ncid, 'absorption_coefficient_ref_P', varid)
297 status = nf90_get_var( ncid, varid, temp_ref_psw)
298 status = nf90_inq_varid(ncid, 'absorption_coefficient_ref_T', varid)
299 status = nf90_get_var( ncid, varid, temp_ref_tsw)
300 status = nf90_inq_varid(ncid, 'tsi_default', varid)
301 if (status .eq. 0) then
302 status = nf90_get_var( ncid, varid, tsi_defaultsw)
303 else
304 tsi_defaultsw = tsi_default
305 endif
306 status = nf90_inq_varid(ncid, 'mg_default', varid)
307 if (status .eq. 0) then
308 status = nf90_get_var( ncid, varid, mg_defaultsw)
309 else
310 mg_defaultsw = mg_default
311 endif
312 status = nf90_inq_varid(ncid, 'sb_default', varid)
313 if (status .eq. 0) then
314 status = nf90_get_var( ncid, varid, sb_defaultsw)
315 else
316 sb_defaultsw = sb_default
317 endif
318 status = nf90_inq_varid(ncid, 'press_ref_trop', varid)
319 status = nf90_get_var( ncid, varid, press_ref_tropsw)
320 status = nf90_inq_varid(ncid, 'kminor_lower', varid)
321 status = nf90_get_var( ncid, varid, kminor_lowersw)
322 status = nf90_inq_varid(ncid, 'kminor_upper', varid)
323 status = nf90_get_var( ncid, varid, kminor_uppersw)
324 status = nf90_inq_varid(ncid, 'vmr_ref', varid)
325 status = nf90_get_var( ncid, varid, vmr_refsw)
326 status = nf90_inq_varid(ncid, 'kmajor', varid)
327 status = nf90_get_var( ncid, varid, kmajorsw)
328 status = nf90_inq_varid(ncid, 'kminor_start_lower', varid)
329 status = nf90_get_var( ncid, varid, kminor_start_lowersw)
330 status = nf90_inq_varid(ncid, 'kminor_start_upper', varid)
331 status = nf90_get_var( ncid, varid, kminor_start_uppersw)
332 status = nf90_inq_varid(ncid, 'solar_source_quiet', varid)
333 status = nf90_get_var( ncid, varid, solar_quietsw)
334 status = nf90_inq_varid(ncid, 'solar_source_facular', varid)
335 status = nf90_get_var( ncid, varid, solar_facularsw)
336 status = nf90_inq_varid(ncid, 'solar_source_sunspot', varid)
337 status = nf90_get_var( ncid, varid, solar_sunspotsw)
338 status = nf90_inq_varid(ncid, 'rayl_lower', varid)
339 status = nf90_get_var( ncid, varid, rayl_lowersw)
340 status = nf90_inq_varid(ncid, 'rayl_upper', varid)
341 status = nf90_get_var( ncid, varid, rayl_uppersw)
342
343 ! Logical fields are read in as integers and then converted to logicals.
344 status = nf90_inq_varid(ncid,'minor_scales_with_density_lower', varid)
345 status = nf90_get_var( ncid, varid,temp1)
346 minor_scales_with_density_lowersw(:) = .false.
347 where(temp1 .eq. 1) minor_scales_with_density_lowersw(:) = .true.
348 status = nf90_inq_varid(ncid,'minor_scales_with_density_upper', varid)
349 status = nf90_get_var( ncid, varid,temp2)
350 minor_scales_with_density_uppersw(:) = .false.
351 where(temp2 .eq. 1) minor_scales_with_density_uppersw(:) = .true.
352 status = nf90_inq_varid(ncid,'scale_by_complement_lower', varid)
353 status = nf90_get_var( ncid, varid,temp3)
354 scale_by_complement_lowersw(:) = .false.
355 where(temp3 .eq. 1) scale_by_complement_lowersw(:) = .true.
356 status = nf90_inq_varid(ncid,'scale_by_complement_upper', varid)
357 status = nf90_get_var( ncid, varid,temp4)
358 scale_by_complement_uppersw(:) = .false.
359 where(temp4 .eq. 1) scale_by_complement_uppersw(:) = .true.
360
361 ! Close
362 status = nf90_close(ncid)
363 endif ! Master process
364
365 ! Other processors waiting...
366 call mpi_barrier(mpicomm, mpierr)
367
368 ! #######################################################################################
369 !
370 ! Broadcast data...
371 ! (ALL processors)
372 !
373 ! #######################################################################################
374
375 ! Real scalars
376#ifdef RTE_USE_SP
377 call mpi_bcast(press_ref_tropsw, 1, mpi_real, mpiroot, mpicomm, mpierr)
378 call mpi_bcast(temp_ref_psw, 1, mpi_real, mpiroot, mpicomm, mpierr)
379 call mpi_bcast(temp_ref_tsw, 1, mpi_real, mpiroot, mpicomm, mpierr)
380 call mpi_bcast(tsi_defaultsw, 1, mpi_real, mpiroot, mpicomm, mpierr)
381 call mpi_bcast(mg_defaultsw, 1, mpi_real, mpiroot, mpicomm, mpierr)
382 call mpi_bcast(sb_defaultsw, 1, mpi_real, mpiroot, mpicomm, mpierr)
383#else
384 call mpi_bcast(press_ref_tropsw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
385 call mpi_bcast(temp_ref_psw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
386 call mpi_bcast(temp_ref_tsw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
387 call mpi_bcast(tsi_defaultsw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
388 call mpi_bcast(mg_defaultsw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
389 call mpi_bcast(sb_defaultsw, 1, mpi_double_precision, mpiroot, mpicomm, mpierr)
390#endif
391
392 ! Integer arrays
393 call mpi_bcast(kminor_start_lowersw, &
394 size(kminor_start_lowersw), mpi_integer, mpiroot, mpicomm, mpierr)
395 call mpi_bcast(kminor_start_uppersw, &
396 size(kminor_start_uppersw), mpi_integer, mpiroot, mpicomm, mpierr)
397 call mpi_bcast(band2gptsw, &
398 size(band2gptsw), mpi_integer, mpiroot, mpicomm, mpierr)
399 call mpi_bcast(minor_limits_gpt_lowersw, &
400 size(minor_limits_gpt_lowersw), mpi_integer, mpiroot, mpicomm, mpierr)
401 call mpi_bcast(minor_limits_gpt_uppersw, &
402 size(minor_limits_gpt_uppersw), mpi_integer, mpiroot, mpicomm, mpierr)
403 call mpi_bcast(key_speciessw, &
404 size(key_speciessw), mpi_integer, mpiroot, mpicomm, mpierr)
405
406 ! Real arrays
407#ifdef RTE_USE_SP
408 call mpi_bcast(press_refsw, &
409 size(press_refsw), mpi_real, mpiroot, mpicomm, mpierr)
410 call mpi_bcast(temp_refsw, &
411 size(temp_refsw), mpi_real, mpiroot, mpicomm, mpierr)
412 call mpi_bcast(solar_quietsw, &
413 size(solar_quietsw), mpi_real, mpiroot, mpicomm, mpierr)
414 call mpi_bcast(solar_facularsw, &
415 size(solar_facularsw), mpi_real, mpiroot, mpicomm, mpierr)
416 call mpi_bcast(solar_sunspotsw, &
417 size(solar_sunspotsw), mpi_real, mpiroot, mpicomm, mpierr)
418 call mpi_bcast(band_limssw, &
419 size(band_limssw), mpi_real, mpiroot, mpicomm, mpierr)
420 call mpi_bcast(vmr_refsw, &
421 size(vmr_refsw), mpi_real, mpiroot, mpicomm, mpierr)
422 call mpi_bcast(kminor_lowersw, &
423 size(kminor_lowersw), mpi_real, mpiroot, mpicomm, mpierr)
424 call mpi_bcast(kminor_uppersw, &
425 size(kminor_uppersw), mpi_real, mpiroot, mpicomm, mpierr)
426 call mpi_bcast(rayl_lowersw, &
427 size(rayl_lowersw), mpi_real, mpiroot, mpicomm, mpierr)
428 call mpi_bcast(rayl_uppersw, &
429 size(rayl_uppersw), mpi_real, mpiroot, mpicomm, mpierr)
430 call mpi_bcast(kmajorsw, &
431 size(kmajorsw), mpi_real, mpiroot, mpicomm, mpierr)
432#else
433 call mpi_bcast(press_refsw, &
434 size(press_refsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
435 call mpi_bcast(temp_refsw, &
436 size(temp_refsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
437 call mpi_bcast(solar_quietsw, &
438 size(solar_quietsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
439 call mpi_bcast(solar_facularsw, &
440 size(solar_facularsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
441 call mpi_bcast(solar_sunspotsw, &
442 size(solar_sunspotsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
443 call mpi_bcast(band_limssw, &
444 size(band_limssw), mpi_double_precision, mpiroot, mpicomm, mpierr)
445 call mpi_bcast(vmr_refsw, &
446 size(vmr_refsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
447 call mpi_bcast(kminor_lowersw, &
448 size(kminor_lowersw), mpi_double_precision, mpiroot, mpicomm, mpierr)
449 call mpi_bcast(kminor_uppersw, &
450 size(kminor_uppersw), mpi_double_precision, mpiroot, mpicomm, mpierr)
451 call mpi_bcast(rayl_lowersw, &
452 size(rayl_lowersw), mpi_double_precision, mpiroot, mpicomm, mpierr)
453 call mpi_bcast(rayl_uppersw, &
454 size(rayl_uppersw), mpi_double_precision, mpiroot, mpicomm, mpierr)
455 call mpi_bcast(kmajorsw, &
456 size(kmajorsw), mpi_double_precision, mpiroot, mpicomm, mpierr)
457#endif
458 ! Characters
459 do ichar=1,nabsorberssw
460 call mpi_bcast(gas_namessw(ichar), &
461 len(gas_namessw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
462 enddo
463 do ichar=1,nminorabsorberssw
464 call mpi_bcast(gas_minorsw(ichar), &
465 len(gas_minorsw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
466 call mpi_bcast(identifier_minorsw(ichar), &
467 len(identifier_minorsw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
468 enddo
469 do ichar=1,nminor_absorber_intervals_lowersw
470 call mpi_bcast(minor_gases_lowersw(ichar), &
471 len(minor_gases_lowersw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
472 call mpi_bcast(scaling_gas_lowersw(ichar), &
473 len(scaling_gas_lowersw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
474 enddo
475
476 do ichar=1,nminor_absorber_intervals_uppersw
477 call mpi_bcast(minor_gases_uppersw(ichar), &
478 len(minor_gases_uppersw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
479 call mpi_bcast(scaling_gas_uppersw(ichar), &
480 len(scaling_gas_uppersw(ichar)), mpi_character, mpiroot, mpicomm, mpierr)
481 enddo
482
483 ! Logicals
484 call mpi_bcast(minor_scales_with_density_lowersw, &
485 size(minor_scales_with_density_lowersw), mpi_logical, mpiroot, mpicomm, mpierr)
486 call mpi_bcast(minor_scales_with_density_uppersw, &
487 size(minor_scales_with_density_uppersw), mpi_logical, mpiroot, mpicomm, mpierr)
488 call mpi_bcast(scale_by_complement_lowersw, &
489 size(scale_by_complement_lowersw), mpi_logical, mpiroot, mpicomm, mpierr)
490 call mpi_bcast(scale_by_complement_uppersw, &
491 size(scale_by_complement_uppersw), mpi_logical, mpiroot, mpicomm, mpierr)
492
493 call mpi_barrier(mpicomm, mpierr)
494
495 ! #######################################################################################
496 !
497 ! Initialize RRTMGP DDT's...
498 !
499 ! #######################################################################################
500 call check_error_msg('rrtmgp_sw_gas_optics_init_gas_concs',gas_concs%init(active_gases_array))
501 call check_error_msg('rrtmgp_sw_gas_optics_init_load',sw_gas_props%load(gas_concs, &
502 gas_namessw, key_speciessw, band2gptsw, band_limssw, press_refsw, press_ref_tropsw,&
503 temp_refsw, temp_ref_psw, temp_ref_tsw, vmr_refsw, kmajorsw, kminor_lowersw, &
504 kminor_uppersw, gas_minorsw, identifier_minorsw, minor_gases_lowersw, &
505 minor_gases_uppersw, minor_limits_gpt_lowersw, minor_limits_gpt_uppersw, &
506 minor_scales_with_density_lowersw, minor_scales_with_density_uppersw, &
507 scaling_gas_lowersw, scaling_gas_uppersw, scale_by_complement_lowersw, &
508 scale_by_complement_uppersw, kminor_start_lowersw, kminor_start_uppersw, &
509 solar_quietsw, solar_facularsw, solar_sunspotsw, tsi_defaultsw, mg_defaultsw, &
510 sb_defaultsw, rayl_lowersw, rayl_uppersw))
511
512 end subroutine rrtmgp_sw_gas_optics_init
513end module rrtmgp_sw_gas_optics
514
This module contains tools for radiation.
This module contains a routine to initialize the k-distribution data used by the RRTMGP shortwave rad...