1 #ifndef ERF_RADIATION_H
2 #define ERF_RADIATION_H
23 #include <mo_gas_concentrations.h>
25 #include <Kokkos_Core.hpp>
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>
66 Init (
const amrex::Geometry& geom,
67 const amrex::BoxArray& ba,
68 amrex::MultiFab* cons_in)
override
71 int klo = geom.Domain().smallEnd(2);
72 int khi = geom.Domain().bigEnd(2);
75 m_nlay = geom.Domain().length(2);
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);
100 const amrex::BoxArray& ba,
101 amrex::Geometry& geom,
102 amrex::MultiFab* cons_in,
103 amrex::iMultiFab* lmask,
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
113 set_grids(level, step, time, dt, ba, geom,
115 lsm_input_ptrs, qheating_rates,
116 rad_fluxes, z_phys, lat_ptr, lon_ptr);
126 const amrex::BoxArray& ba,
127 amrex::Geometry& geom,
128 amrex::MultiFab* cons_in,
129 amrex::iMultiFab* lmask,
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);
150 amrex::Vector<amrex::MultiFab*>& lsm_input_ptrs);
170 finalize_impl (amrex::Vector<amrex::MultiFab*>& lsm_output_ptrs);
177 amrex::Print() <<
"Radiation advancing level " <<
m_lev <<
" at (YY-MM-DD SS) " <<
m_orbital_year <<
'-'
182 amrex::Print() <<
"DONE\n";
188 amrex::Vector<std::string>
196 amrex::Vector<std::string>
251 "sfc_alb_dir_vis",
"sfc_alb_dir_nir",
252 "sfc_alb_dif_vis",
"sfc_alb_dif_nir"};
256 "sw_flux_dn_dir_vis",
"sw_flux_dn_dir_nir",
257 "sw_flux_dn_dif_vis",
"sw_flux_dn_dif_nir",
299 const std::vector<std::string>
m_gas_names = {
"H2O",
"CO2",
"O3",
"N2O",
300 "CO" ,
"CH4",
"O2",
"N2" };
319 GasConcsK<amrex::Real, layout_t, KokkosDefaultDevice>
m_gas_concs;
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