ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_Radiation.H
Go to the documentation of this file.
1 #ifndef ERF_RADIATION_H
2 #define ERF_RADIATION_H
3 
4 /*
5  * RTE-RRTMGP radiation model interface to ERF
6  * The original code is developed by RobertPincus, and the code is open source available at:
7  * https://github.com/earth-system-radiation/rte-rrtmgp
8  * Please reference to the following paper,
9  * https://agupubs.onlinelibrary.wiley.com/doi/amrex::Real(10.1029)/2019MS001621
10  * NOTE: we use the C++ version of RTE-RRTMGP, which is the implementation of the original Fortran
11  * code using C++ KOKKOS for CUDA, HiP and SYCL application by E3SM ECP team, the C++ version
12  * of the rte-rrtmgp code is located at:
13  * https://github.com/E3SM-Project/rte-rrtmgp
14  * The RTE-RRTMGP uses BSD-3-Clause Open Source License, if you want to make changes,
15  * and modifications to the code, please refer to BSD-3-Clause Open Source License.
16  */
17 
18 #include <ctime>
19 #include <string>
20 #include <vector>
21 #include <memory>
22 
23 #include <mo_gas_concentrations.h>
24 
25 #include <Kokkos_Core.hpp>
26 
27 #include <AMReX_ParmParse.H>
28 #include <AMReX_FArrayBox.H>
29 #include <AMReX_Geometry.H>
30 #include <AMReX_TableData.H>
31 #include <AMReX_MultiFabUtil.H>
32 #include <AMReX_PlotFileUtil.H>
33 
34 #include <ERF_RadiationInterface.H>
35 #include <ERF_RRTMGP_Interface.H>
36 #include <ERF_RRTMGP_Utils.H>
37 #include <ERF_OrbCosZenith.H>
38 #include <ERF_Constants.H>
39 #include <ERF_IndexDefines.H>
40 #include <ERF_DataStruct.H>
41 #include <ERF_EOS.H>
42 
43 #include <ERF_LandSurface.H>
44 
45 class Radiation : public IRadiation {
46 public:
47 
48  #include <ERF_Kokkos.H>
49 
50  // Constructor
51  Radiation (const int& lev,
52  SolverChoice& sc);
53 
54  // Destructor
56  {
57  // Release k-distribution data and memory pool
58  if (rrtmgp::initialized) {
60  }
61  // Note that Kokkos is now finalized in main.cpp
62  }
63 
64  virtual
65  void
66  Init (const amrex::Geometry& geom,
67  const amrex::BoxArray& ba,
68  amrex::MultiFab* cons_in) override
69  {
70  // Ensure the boxes span klo -> khi
71  int klo = geom.Domain().smallEnd(2);
72  int khi = geom.Domain().bigEnd(2);
73 
74  // Reset vector of offsets for columnar data
75  m_nlay = geom.Domain().length(2);
76 
77  m_ncol = 0;
78  m_col_offsets.clear();
79  m_col_offsets.resize(int(ba.size()));
80  for (amrex::MFIter mfi(*cons_in); mfi.isValid(); ++mfi) {
81  const amrex::Box& vbx = mfi.validbox();
82  AMREX_ALWAYS_ASSERT_WITH_MESSAGE((klo == vbx.smallEnd(2)) &&
83  (khi == vbx.bigEnd(2)),
84  "Vertical decomposition with radiation is not allowed.");
85  int nx = vbx.length(0);
86  int ny = vbx.length(1);
87  m_col_offsets[mfi.index()] = m_ncol;
88  m_ncol += nx * ny;
89  }
90 
91  m_ncol_chunk = amrex::min(m_ncol, m_ncol_chunk);
92  };
93 
94  virtual
95  void
96  Run (int& level,
97  int& step,
98  amrex::Real& time,
99  const amrex::Real& dt,
100  const amrex::BoxArray& ba,
101  amrex::Geometry& geom,
102  amrex::MultiFab* cons_in,
103  amrex::iMultiFab* lmask,
104  amrex::MultiFab* t_surf,
105  amrex::Vector<amrex::MultiFab*>& lsm_input_ptrs,
106  amrex::Vector<amrex::MultiFab*>& lsm_output_ptrs,
107  amrex::MultiFab* qheating_rates,
108  amrex::MultiFab* rad_fluxes,
109  amrex::MultiFab* z_phys,
110  amrex::MultiFab* lat_ptr,
111  amrex::MultiFab* lon_ptr) override
112  {
113  set_grids(level, step, time, dt, ba, geom,
114  cons_in, lmask, t_surf,
115  lsm_input_ptrs, qheating_rates,
116  rad_fluxes, z_phys, lat_ptr, lon_ptr);
117  rad_run_impl(lsm_output_ptrs);
118  }
119 
120  // Set the grid info for columnar data in KOKKOS
121  void
122  set_grids (int& level,
123  int& step,
124  amrex::Real& time,
125  const amrex::Real& dt,
126  const amrex::BoxArray& ba,
127  amrex::Geometry& geom,
128  amrex::MultiFab* cons_in,
129  amrex::iMultiFab* lmask,
130  amrex::MultiFab* t_surf,
131  amrex::Vector<amrex::MultiFab*>& lsm_input_ptrs,
132  amrex::MultiFab* qheating_rates,
133  amrex::MultiFab* rad_fluxes,
134  amrex::MultiFab* z_phys,
135  amrex::MultiFab* lat,
136  amrex::MultiFab* lon);
137 
138  // Initialize the temporary variables
139  void
140  alloc_buffers ();
141 
142  // Clear the temporary variables
143  void
144  dealloc_buffers ();
145 
146  // Fill KOKKOS Views from AMReX MultiFabs
147  void
148  mf_to_kokkos_buffers(amrex::iMultiFab* lmask,
149  amrex::MultiFab* t_surf,
150  amrex::Vector<amrex::MultiFab*>& lsm_input_ptrs);
151 
152  // Fill AMReX MultiFabs from KOKKOS Views
153  void
154  kokkos_buffers_to_mf (amrex::Vector<amrex::MultiFab*>& lsm_output_ptrs);
155 
156  // Write the rrtmgp fluxes
157  void
159 
160  // Initialize the implementation
161  void
162  initialize_impl ();
163 
164  // Run the implementation
165  void
166  run_impl ();
167 
168  // Finalize the implementation
169  void
170  finalize_impl (amrex::Vector<amrex::MultiFab*>& lsm_output_ptrs);
171 
172  // Wrapper for implementation steps
173  void
174  rad_run_impl (amrex::Vector<amrex::MultiFab*>& lsm_output_ptrs)
175  {
176  if (m_update_rad) {
177  amrex::Print() << "Radiation advancing level " << m_lev << " at (YY-MM-DD SS) " << m_orbital_year << '-'
178  << m_orbital_mon << '-' << m_orbital_day << ' ' << m_orbital_sec << " ...";
179  this->initialize_impl();
180  this->run_impl();
181  this->finalize_impl(lsm_output_ptrs);
182  amrex::Print() << "DONE\n";
183  }
184  }
185 
186  // Get names input varnames for lsm
187  virtual
188  amrex::Vector<std::string>
190  {
191  return m_lsm_input_names;
192  }
193 
194  // Get names output varnames for lsm
195  virtual
196  amrex::Vector<std::string>
198  {
199  return m_lsm_output_names;
200  }
201 
202  // Populate datalog structures
203  void
205 
206  // Write datalog
207  virtual
208  void
209  WriteDataLog (const amrex::Real &time) override;
210 
211 private:
212 
213  // Process interface vars from ERF/AMReX
214  //===================================================================================
215 
216  // Grid level
217  int m_lev;
218 
219  // Step number
220  int m_step;
221 
222  // Current time
224 
225  // Timestep at given level
227 
228  // Geometry at given level
229  amrex::Geometry m_geom;
230 
231  // BoxArray at given level
232  amrex::BoxArray m_ba;
233 
234  // Are we updating radiation?
235  bool m_update_rad = false;
236 
237  // Are we writing out the fluxes?
238  bool m_rad_write_fluxes = false;
239 
240  bool m_first_step = true;
241 
242  // Do we have moisture and cold comps?
243  bool m_moist = false;
244  bool m_ice = false;
245 
246  // Do we have a land surface model?
247  bool m_lsm = false;
248 
249  // List of input parameter names
250  amrex::Vector<std::string> m_lsm_input_names = {"t_sfc" , "sfc_emis" ,
251  "sfc_alb_dir_vis", "sfc_alb_dir_nir",
252  "sfc_alb_dif_vis", "sfc_alb_dif_nir"};
253 
254  // List of output parameter names
255  amrex::Vector<std::string> m_lsm_output_names = {"cos_zenith_angle" , "sw_flux_dn" ,
256  "sw_flux_dn_dir_vis", "sw_flux_dn_dir_nir",
257  "sw_flux_dn_dif_vis", "sw_flux_dn_dif_nir",
258  "lw_flux_dn"};
259 
260  // T surf if no LSM is available
262 
263  // Pointer to the CC conserved vars
264  amrex::MultiFab* m_cons_in = nullptr;
265 
266  // Pointer to the radiation source terms
267  amrex::MultiFab* m_qheating_rates = nullptr;
268 
269  // Pointer to the radiation fluxes
270  amrex::MultiFab* m_rad_fluxes = nullptr;
271 
272  // Pointer to the terrain heights
273  amrex::MultiFab* m_z_phys = nullptr;
274 
275  // Pointer to latitude and longitude
276  amrex::MultiFab* m_lat = nullptr;
277  amrex::MultiFab* m_lon = nullptr;
278 
279  // Constant lat/lon if the above MFs are not valid
282 
283  // Holds output from KOKKOS views used in the datalog
284  amrex::MultiFab datalog_mf;
285 
286  // Path, data file, and coefficient file for K-distribution
287  std::string rrtmgp_file_path = ".";
288  std::string rrtmgp_coeffs_sw = "rrtmgp-data-sw-g224-2018-12-04.nc";
289  std::string rrtmgp_coeffs_lw = "rrtmgp-data-lw-g256-2018-12-04.nc";
290  std::string rrtmgp_cloud_optics_sw = "rrtmgp-cloud-optics-coeffs-sw.nc";
291  std::string rrtmgp_cloud_optics_lw = "rrtmgp-cloud-optics-coeffs-lw.nc";
296 
297  // Active gases
298  int m_ngas = 8;
299  const std::vector<std::string> m_gas_names = {"H2O", "CO2", "O3", "N2O",
300  "CO" , "CH4", "O2", "N2" };
301  const std::vector<amrex::Real> m_mol_weight_gas = {amrex::Real(18.01528), amrex::Real(44.00950), amrex::Real(47.9982), amrex::Real(44.0128),
302  amrex::Real(28.01010), amrex::Real(16.04246), amrex::Real(31.9980), amrex::Real(28.0134)}; // g/mol
303 
304  // Prescribed greenhouse gas surface concentrations in moles / moles air
306  amrex::Vector<amrex::Real> m_o3vmr;
312  //amrex::Real m_f11vmr = amrex::Real(768.7644e-12);
313  //amrex::Real m_f12vmr = amrex::Real(531.2820e-12);
314 
317  std::vector<std::string> gas_names_offset;
318 
319  GasConcsK<amrex::Real, layout_t, KokkosDefaultDevice> m_gas_concs;
320 
321  // Process interface vars modeled after EAMXX
322  //===================================================================================
323 
324  // Keep track of number of columns and levels
325  int m_ncol;
326  int m_nlay;
327 
328  // Offsets for MultiFab <-> KOKKOS transfer
329  amrex::Vector<int> m_col_offsets;
330 
331  // Whether we use aerosol forcing in radiation.
332  // Aerosol plumbing is currently not implemented; this hook is retained so a
333  // future aerosol scheme can wire in without reintroducing the parameter.
334  // Setting it true today triggers an abort in the Radiation constructor.
335  bool m_do_aerosol_rad = false;
336 
337  // Whether we do extra aerosol forcing calls
338  bool m_extra_clnsky_diag = false;
340 
341  // The orbital year, used for zenith angle calculations:
342  // If > 0, use constant orbital year for duration of simulation
343  // If < 0, use year from timestamp for orbital parameters
344  int m_orbital_year = -9999;
345  int m_orbital_mon = -9999;
346  int m_orbital_day = -9999;
347  int m_orbital_sec = -9999;
348 
349  // Orbital parameters, used for zenith angle calculations.
350  // If >= 0, bypass computation based on orbital year and use fixed parameters
351  // If < 0, compute based on orbital year, specified above
352  bool m_fixed_orbital_year = false;
353  amrex::Real m_orbital_eccen = -amrex::Real(9999.); // Eccentricity
354  amrex::Real m_orbital_obliq = -amrex::Real(9999.); // Obliquity
355  amrex::Real m_orbital_mvelp = -amrex::Real(9999.); // Vernal Equinox Mean Longitude of Perihelion
356 
357  // Value for prescribing an invariant solar constant (i.e. total solar irradiance
358  // at TOA). Used for idealized experiments such as RCE. This is only used when a
359  // positive value is supplied.
361 
362  // Fixed solar zenith angle to use for shortwave calculations
363  // This is only used if a positive value is supplied
365 
366  // Dimensions to be read from lookup data
371 
372  // Rad frequency in number of steps
374 
375  // Number of columns to process per RRTMGP chunk (controls peak memory)
376  int m_ncol_chunk = 1024;
377 
378  // Number of vars for s_mem allocation
379  int m_rad_nvar = 12;
380 
381  // Whether or not to do subcolumn sampling of cloud state for MCICA
382  bool m_do_subcol_sampling = true;
383 
384  // 1d size (1 or nlay)
386 
387  // 1d size (ncol)
402 
403  // 2d size (ncol, nlay)
420 
421  // 2d size (ncol, nlay+1)
445 
446  // 3d size (ncol, nlay+1, nswbands)
451 
452  // 3d size (ncol, nlay+1, nlwbands)
455 
456  // 2d size (ncol, nswbands)
459 
460  // Aerosol optical properties. Dormant scaffolding kept so a future aerosol
461  // coupling (e.g. SPA, prescribed aerosol climatology) can populate these
462  // without re-adding members. Only allocated when m_do_aerosol_rad is true,
463  // which currently aborts in the constructor; when aerosol coupling is
464  // wired in, remove the abort and pass these into rrtmgp_main.
465  //
466  // 3d size (ncol, nlay, n[sw,lw]bands)
471 };
472 #endif
const int khi
Definition: ERF_InitCustomPert_Bubble.H:21
Kokkos::View< RealT *, KokkosDefaultDevice > real1d_k
Definition: ERF_Kokkos.H:18
Kokkos::View< RealT ***, layout_t, KokkosDefaultDevice > real3d_k
Definition: ERF_Kokkos.H:20
Kokkos::View< RealT **, layout_t, KokkosDefaultDevice > real2d_k
Definition: ERF_Kokkos.H:19
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_RadiationInterface.H:14
Definition: ERF_Radiation.H:45
real3d_k sw_bnd_flux_dn
Definition: ERF_Radiation.H:448
amrex::MultiFab * m_lon
Definition: ERF_Radiation.H:277
real2d_k lw_flux_up
Definition: ERF_Radiation.H:428
virtual amrex::Vector< std::string > get_lsm_output_varnames() override
Definition: ERF_Radiation.H:197
real3d_k aero_tau_sw
Definition: ERF_Radiation.H:467
int m_o3_size
Definition: ERF_Radiation.H:315
real3d_k sw_bnd_flux_dir
Definition: ERF_Radiation.H:449
real2d_k sw_clnsky_flux_dn
Definition: ERF_Radiation.H:437
std::string rrtmgp_coeffs_file_sw
Definition: ERF_Radiation.H:292
std::string rrtmgp_coeffs_sw
Definition: ERF_Radiation.H:288
real2d_k d_tint
Definition: ERF_Radiation.H:422
real2d_k lw_clnclrsky_flux_dn
Definition: ERF_Radiation.H:440
int m_rad_freq_in_steps
Definition: ERF_Radiation.H:373
real2d_k lwp
Definition: ERF_Radiation.H:414
real1d_k lw_src
Definition: ERF_Radiation.H:401
real2d_k eff_radius_qi
Definition: ERF_Radiation.H:413
void dealloc_buffers()
Definition: ERF_Radiation.cpp:367
real1d_k m_gas_mol_weights
Definition: ERF_Radiation.H:316
amrex::Real m_lon_cons
Definition: ERF_Radiation.H:281
void initialize_impl()
Definition: ERF_Radiation.cpp:1033
int m_nswbands
Definition: ERF_Radiation.H:367
bool m_do_aerosol_rad
Definition: ERF_Radiation.H:335
std::string rrtmgp_coeffs_lw
Definition: ERF_Radiation.H:289
bool m_moist
Definition: ERF_Radiation.H:243
std::string rrtmgp_cloud_optics_file_lw
Definition: ERF_Radiation.H:295
amrex::MultiFab * m_cons_in
Definition: ERF_Radiation.H:264
amrex::MultiFab datalog_mf
Definition: ERF_Radiation.H:284
Radiation(const int &lev, SolverChoice &sc)
Definition: ERF_Radiation.cpp:20
real2d_k sw_heating
Definition: ERF_Radiation.H:416
void set_grids(int &level, int &step, amrex::Real &time, const amrex::Real &dt, const amrex::BoxArray &ba, amrex::Geometry &geom, amrex::MultiFab *cons_in, amrex::iMultiFab *lmask, amrex::MultiFab *t_surf, amrex::Vector< amrex::MultiFab * > &lsm_input_ptrs, amrex::MultiFab *qheating_rates, amrex::MultiFab *rad_fluxes, amrex::MultiFab *z_phys, amrex::MultiFab *lat, amrex::MultiFab *lon)
Definition: ERF_Radiation.cpp:158
bool m_lsm
Definition: ERF_Radiation.H:247
bool m_do_subcol_sampling
Definition: ERF_Radiation.H:382
real3d_k lw_bnd_flux_dn
Definition: ERF_Radiation.H:454
bool m_rad_write_fluxes
Definition: ERF_Radiation.H:238
real3d_k sw_bnd_flux_up
Definition: ERF_Radiation.H:447
real2d_k qv_lay
Definition: ERF_Radiation.H:408
std::string rrtmgp_cloud_optics_file_sw
Definition: ERF_Radiation.H:294
amrex::Vector< std::string > m_lsm_output_names
Definition: ERF_Radiation.H:255
void run_impl()
Definition: ERF_Radiation.cpp:1055
real2d_k sw_clnclrsky_flux_dn_dir
Definition: ERF_Radiation.H:432
real1d_k sfc_flux_dif_vis
Definition: ERF_Radiation.H:395
int m_step
Definition: ERF_Radiation.H:220
real2d_k lw_clnclrsky_flux_up
Definition: ERF_Radiation.H:439
real1d_k lat
Definition: ERF_Radiation.H:397
void populateDatalogMF()
Definition: ERF_Radiation.cpp:792
real2d_k qi_lay
Definition: ERF_Radiation.H:410
real2d_k sw_clrsky_flux_up
Definition: ERF_Radiation.H:433
amrex::Real m_orbital_mvelp
Definition: ERF_Radiation.H:355
real2d_k t_lev
Definition: ERF_Radiation.H:424
amrex::Vector< amrex::Real > m_o3vmr
Definition: ERF_Radiation.H:306
real1d_k o3_lay
Definition: ERF_Radiation.H:385
std::string rrtmgp_cloud_optics_sw
Definition: ERF_Radiation.H:290
real1d_k sfc_alb_dif_vis
Definition: ERF_Radiation.H:391
int m_nlwgpts
Definition: ERF_Radiation.H:370
real1d_k mu0
Definition: ERF_Radiation.H:388
real2d_k cldfrac_tot
Definition: ERF_Radiation.H:411
real1d_k sfc_flux_dir_nir
Definition: ERF_Radiation.H:394
amrex::MultiFab * m_z_phys
Definition: ERF_Radiation.H:273
real2d_k sw_clnclrsky_flux_up
Definition: ERF_Radiation.H:430
real3d_k aero_g_sw
Definition: ERF_Radiation.H:469
real2d_k sw_flux_up
Definition: ERF_Radiation.H:425
std::string rrtmgp_cloud_optics_lw
Definition: ERF_Radiation.H:291
amrex::MultiFab * m_rad_fluxes
Definition: ERF_Radiation.H:270
real3d_k sw_bnd_flux_dif
Definition: ERF_Radiation.H:450
virtual void Run(int &level, int &step, amrex::Real &time, const amrex::Real &dt, const amrex::BoxArray &ba, amrex::Geometry &geom, amrex::MultiFab *cons_in, amrex::iMultiFab *lmask, amrex::MultiFab *t_surf, amrex::Vector< amrex::MultiFab * > &lsm_input_ptrs, amrex::Vector< amrex::MultiFab * > &lsm_output_ptrs, amrex::MultiFab *qheating_rates, amrex::MultiFab *rad_fluxes, amrex::MultiFab *z_phys, amrex::MultiFab *lat_ptr, amrex::MultiFab *lon_ptr) override
Definition: ERF_Radiation.H:96
real2d_k sfc_alb_dif
Definition: ERF_Radiation.H:458
amrex::Real m_co2vmr
Definition: ERF_Radiation.H:305
bool m_extra_clnsky_diag
Definition: ERF_Radiation.H:338
real1d_k sfc_alb_dif_nir
Definition: ERF_Radiation.H:392
virtual void Init(const amrex::Geometry &geom, const amrex::BoxArray &ba, amrex::MultiFab *cons_in) override
Definition: ERF_Radiation.H:66
real2d_k lw_clnsky_flux_dn
Definition: ERF_Radiation.H:444
amrex::BoxArray m_ba
Definition: ERF_Radiation.H:232
real2d_k p_lay
Definition: ERF_Radiation.H:405
real2d_k r_lay
Definition: ERF_Radiation.H:404
int m_ncol
Definition: ERF_Radiation.H:325
real2d_k sw_flux_dn_dir
Definition: ERF_Radiation.H:427
const std::vector< amrex::Real > m_mol_weight_gas
Definition: ERF_Radiation.H:301
amrex::Real m_lat_cons
Definition: ERF_Radiation.H:280
amrex::Real m_fixed_total_solar_irradiance
Definition: ERF_Radiation.H:360
void kokkos_buffers_to_mf(amrex::Vector< amrex::MultiFab * > &lsm_output_ptrs)
Definition: ERF_Radiation.cpp:673
std::vector< std::string > gas_names_offset
Definition: ERF_Radiation.H:317
real2d_k sw_clrsky_flux_dn
Definition: ERF_Radiation.H:434
amrex::Real m_dt
Definition: ERF_Radiation.H:226
virtual amrex::Vector< std::string > get_lsm_input_varnames() override
Definition: ERF_Radiation.H:189
int m_orbital_mon
Definition: ERF_Radiation.H:345
real3d_k aero_ssa_sw
Definition: ERF_Radiation.H:468
real2d_k sw_clnsky_flux_dn_dir
Definition: ERF_Radiation.H:438
amrex::Real m_o2vmr
Definition: ERF_Radiation.H:310
void rad_run_impl(amrex::Vector< amrex::MultiFab * > &lsm_output_ptrs)
Definition: ERF_Radiation.H:174
GasConcsK< amrex::Real, layout_t, KokkosDefaultDevice > m_gas_concs
Definition: ERF_Radiation.H:319
amrex::MultiFab * m_qheating_rates
Definition: ERF_Radiation.H:267
real2d_k qc_lay
Definition: ERF_Radiation.H:409
virtual void WriteDataLog(const amrex::Real &time) override
Definition: ERF_Radiation.cpp:898
real2d_k lw_clrsky_flux_up
Definition: ERF_Radiation.H:441
amrex::Real m_n2ovmr
Definition: ERF_Radiation.H:307
amrex::Real m_rad_t_sfc
Definition: ERF_Radiation.H:261
std::string rrtmgp_file_path
Definition: ERF_Radiation.H:287
real2d_k sw_flux_dn
Definition: ERF_Radiation.H:426
void mf_to_kokkos_buffers(amrex::iMultiFab *lmask, amrex::MultiFab *t_surf, amrex::Vector< amrex::MultiFab * > &lsm_input_ptrs)
Definition: ERF_Radiation.cpp:461
int m_nlwbands
Definition: ERF_Radiation.H:368
real2d_k lw_clrsky_flux_dn
Definition: ERF_Radiation.H:442
amrex::Real m_orbital_eccen
Definition: ERF_Radiation.H:353
void finalize_impl(amrex::Vector< amrex::MultiFab * > &lsm_output_ptrs)
Definition: ERF_Radiation.cpp:1347
amrex::Real m_covmr
Definition: ERF_Radiation.H:308
int m_orbital_sec
Definition: ERF_Radiation.H:347
real2d_k z_del
Definition: ERF_Radiation.H:407
real3d_k aero_tau_lw
Definition: ERF_Radiation.H:470
int m_ncol_chunk
Definition: ERF_Radiation.H:376
real2d_k lw_flux_dn
Definition: ERF_Radiation.H:429
~Radiation()
Definition: ERF_Radiation.H:55
real2d_k sw_clrsky_flux_dn_dir
Definition: ERF_Radiation.H:435
void write_rrtmgp_fluxes()
Definition: ERF_Radiation.cpp:752
std::string rrtmgp_coeffs_file_lw
Definition: ERF_Radiation.H:293
int m_lev
Definition: ERF_Radiation.H:217
real1d_k sfc_flux_dif_nir
Definition: ERF_Radiation.H:396
int m_ngas
Definition: ERF_Radiation.H:298
real2d_k lw_heating
Definition: ERF_Radiation.H:417
real1d_k sfc_alb_dir_nir
Definition: ERF_Radiation.H:390
real2d_k lw_clnsky_flux_up
Definition: ERF_Radiation.H:443
amrex::Real m_ch4vmr
Definition: ERF_Radiation.H:309
bool m_update_rad
Definition: ERF_Radiation.H:235
real2d_k sfc_alb_dir
Definition: ERF_Radiation.H:457
bool m_ice
Definition: ERF_Radiation.H:244
amrex::Real m_fixed_solar_zenith_angle
Definition: ERF_Radiation.H:364
real1d_k lon
Definition: ERF_Radiation.H:398
int m_orbital_day
Definition: ERF_Radiation.H:346
real1d_k sfc_emis
Definition: ERF_Radiation.H:399
amrex::Real m_orbital_obliq
Definition: ERF_Radiation.H:354
amrex::Real m_n2vmr
Definition: ERF_Radiation.H:311
bool m_fixed_orbital_year
Definition: ERF_Radiation.H:352
real2d_k sw_clnsky_flux_up
Definition: ERF_Radiation.H:436
int m_nlay
Definition: ERF_Radiation.H:326
real3d_k lw_bnd_flux_up
Definition: ERF_Radiation.H:453
int m_nswgpts
Definition: ERF_Radiation.H:369
bool m_first_step
Definition: ERF_Radiation.H:240
real1d_k sfc_alb_dir_vis
Definition: ERF_Radiation.H:389
const std::vector< std::string > m_gas_names
Definition: ERF_Radiation.H:299
real2d_k sw_clrsky_heating
Definition: ERF_Radiation.H:418
bool m_extra_clnclrsky_diag
Definition: ERF_Radiation.H:339
real2d_k t_lay
Definition: ERF_Radiation.H:406
real1d_k sfc_flux_dir_vis
Definition: ERF_Radiation.H:393
real2d_k iwp
Definition: ERF_Radiation.H:415
amrex::Geometry m_geom
Definition: ERF_Radiation.H:229
amrex::MultiFab * m_lat
Definition: ERF_Radiation.H:276
real2d_k p_lev
Definition: ERF_Radiation.H:423
real2d_k lw_clrsky_heating
Definition: ERF_Radiation.H:419
real2d_k eff_radius_qc
Definition: ERF_Radiation.H:412
int m_rad_nvar
Definition: ERF_Radiation.H:379
amrex::Vector< int > m_col_offsets
Definition: ERF_Radiation.H:329
real1d_k t_sfc
Definition: ERF_Radiation.H:400
void alloc_buffers()
Definition: ERF_Radiation.cpp:225
int m_orbital_year
Definition: ERF_Radiation.H:344
real2d_k sw_clnclrsky_flux_dn
Definition: ERF_Radiation.H:431
amrex::Vector< std::string > m_lsm_input_names
Definition: ERF_Radiation.H:250
amrex::Real m_time
Definition: ERF_Radiation.H:223
@ t_surf
Definition: ERF_OceanSurf.H:14
void rrtmgp_finalize()
Definition: ERF_RRTMGP_Interface.cpp:266
bool initialized
Definition: ERF_RRTMGP_Interface.cpp:24
Definition: ERF_DataStruct.H:141