1058 const auto ncol =
m_ncol;
1059 const auto nlay =
m_nlay;
1065 double obliqr, lambm0, mvelpp;
1070 if (eccen >= 0 && obliq >= 0 && mvelp >= 0) {
1075 mvelp, obliqr, lambm0, mvelpp);
1086 orbital_decl(calday, eccen, mvelpp, lambm0, obliqr, delta, eccf);
1090 if (fixed_total_solar_irradiance >= 0){
1091 eccf = fixed_total_solar_irradiance/
Real(1360.9);
1099 Vector<real2d_k> vmr_full_vec(
m_ngas);
1100 for (
int igas(0); igas <
m_ngas; ++igas) {
1102 vmr_full_vec[igas] =
real2d_k(
"vmr_full_" + name, ncol, nlay);
1103 auto tmp2d = vmr_full_vec[igas];
1105 if (name ==
"H2O") {
1107 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1108 KOKKOS_LAMBDA (
int icol,
int ilay)
1110 tmp2d(icol,ilay) = qv_lay_d(icol,ilay) *
mwdair/gas_mol_weight;
1112 }
else if (name ==
"CO2") {
1113 Kokkos::deep_copy(tmp2d,
m_co2vmr);
1114 }
else if (name ==
"O3") {
1116 Kokkos::deep_copy(tmp2d,
m_o3vmr[0] );
1119 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1120 KOKKOS_LAMBDA (
int icol,
int ilay)
1122 tmp2d(icol,ilay) = o3_lay_d(ilay);
1125 }
else if (name ==
"N2O") {
1126 Kokkos::deep_copy(tmp2d,
m_n2ovmr);
1127 }
else if (name ==
"CO") {
1128 Kokkos::deep_copy(tmp2d,
m_covmr );
1129 }
else if (name ==
"CH4") {
1130 Kokkos::deep_copy(tmp2d,
m_ch4vmr);
1131 }
else if (name ==
"O2") {
1132 Kokkos::deep_copy(tmp2d,
m_o2vmr );
1133 }
else if (name ==
"N2") {
1134 Kokkos::deep_copy(tmp2d,
m_n2vmr );
1136 Abort(
"Radiation: Unknown gas component.");
1146 auto h_mu0 = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
mu0);
1150 auto h_lat = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
lat);
1151 auto h_lon = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
lon);
1152 double dt = double(
m_dt);
1154 Kokkos::parallel_for(Kokkos::RangePolicy<Kokkos::Serial>(0, ncol),
1158 double lat_col = h_lat(icol)*
PI/
Real(180.0);
1159 double lon_col = h_lon(icol)*
PI/
Real(180.0);
1160 double lcalday = calday;
1161 double ldelta = delta;
1162 double dt_avg =
static_cast<double>(rad_freq_in_steps) * dt;
1166 Kokkos::deep_copy(
mu0, h_mu0);
1173 Table2D<Real,Order::C> lwp_tab(
lwp.data(), {0,0}, {static_cast<int>(lwp.extent(0)),static_cast<int>(lwp.extent(1))});
1174 Table2D<Real,Order::C> iwp_tab(
iwp.data(), {0,0}, {static_cast<int>(iwp.extent(0)),static_cast<int>(iwp.extent(1))});
1175 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1176 KOKKOS_LAMBDA (
int icol,
int ilay)
1178 lwp_tab(icol,ilay) *=
Real(1.e3);
1179 iwp_tab(icol,ilay) *=
Real(1.e3);
1190 for (
int col_s = 0; col_s < ncol; col_s += ncol_chunk) {
1191 const int ncol_c = std::min(ncol_chunk, ncol - col_s);
1192 const int col_e = col_s + ncol_c;
1193 auto cr = std::make_pair(col_s, col_e);
1210 const int stride2_nlay = nlay;
1211 const int stride2_nlayp1 = nlay + 1;
1212 real2d_k p_lay_c (
p_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1213 real2d_k t_lay_c (
t_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1214 real2d_k r_lay_c (
r_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1215 real2d_k z_del_c (
z_del.data() + col_s*stride2_nlay, ncol_c, nlay);
1216 real2d_k lwp_c (
lwp.data() + col_s*stride2_nlay, ncol_c, nlay);
1217 real2d_k iwp_c (
iwp.data() + col_s*stride2_nlay, ncol_c, nlay);
1225 real2d_k p_lev_c (
p_lev.data() + col_s*stride2_nlayp1, ncol_c, nlay+1);
1226 real2d_k t_lev_c (
t_lev.data() + col_s*stride2_nlayp1, ncol_c, nlay+1);
1240 real2d_k sw_clnclrsky_flux_up_c, sw_clnclrsky_flux_dn_c, sw_clnclrsky_flux_dn_dir_c;
1241 real2d_k lw_clnclrsky_flux_up_c, lw_clnclrsky_flux_dn_c;
1249 sw_clnclrsky_flux_up_c =
real2d_k(
"sw_clnclrsky_flux_up_c" , 1, 1);
1250 sw_clnclrsky_flux_dn_c =
real2d_k(
"sw_clnclrsky_flux_dn_c" , 1, 1);
1251 sw_clnclrsky_flux_dn_dir_c =
real2d_k(
"sw_clnclrsky_flux_dn_dir_c", 1, 1);
1252 lw_clnclrsky_flux_up_c =
real2d_k(
"lw_clnclrsky_flux_up_c" , 1, 1);
1253 lw_clnclrsky_flux_dn_c =
real2d_k(
"lw_clnclrsky_flux_dn_c" , 1, 1);
1256 real2d_k sw_clnsky_flux_up_c, sw_clnsky_flux_dn_c, sw_clnsky_flux_dn_dir_c;
1257 real2d_k lw_clnsky_flux_up_c, lw_clnsky_flux_dn_c;
1265 sw_clnsky_flux_up_c =
real2d_k(
"sw_clnsky_flux_up_c" , 1, 1);
1266 sw_clnsky_flux_dn_c =
real2d_k(
"sw_clnsky_flux_dn_c" , 1, 1);
1267 sw_clnsky_flux_dn_dir_c =
real2d_k(
"sw_clnsky_flux_dn_dir_c", 1, 1);
1268 lw_clnsky_flux_up_c =
real2d_k(
"lw_clnsky_flux_up_c" , 1, 1);
1269 lw_clnsky_flux_dn_c =
real2d_k(
"lw_clnsky_flux_dn_c" , 1, 1);
1277 const int stride3_sw = stride2_nlayp1 * nswbands;
1278 const int stride3_lw = stride2_nlayp1 *
m_nlwbands;
1289 for (
int igas = 0; igas <
m_ngas; ++igas) {
1290 real2d_k vmr_c(
"vmr_c", ncol_c, nlay);
1291 auto vmr_full = vmr_full_vec[igas];
1293 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol_c, nlay}),
1294 KOKKOS_LAMBDA (
int i,
int j) {
1295 vmr_c(i, j) = vmr_full(
cs + i, j);
1302 sfc_alb_dir_vis_c, sfc_alb_dir_nir_c,
1303 sfc_alb_dif_vis_c, sfc_alb_dif_nir_c,
1304 sfc_alb_dir_c , sfc_alb_dif_c);
1311 sfc_alb_dir_c, sfc_alb_dif_c, mu0_c,
1312 t_sfc_c, sfc_emis_c, lw_src_c,
1313 lwp_c, iwp_c, eff_radius_qc_c, eff_radius_qi_c, cldfrac_tot_c,
1314 sw_flux_up_c, sw_flux_dn_c, sw_flux_dn_dir_c,
1315 lw_flux_up_c, lw_flux_dn_c,
1316 sw_clnclrsky_flux_up_c, sw_clnclrsky_flux_dn_c, sw_clnclrsky_flux_dn_dir_c,
1317 sw_clrsky_flux_up_c, sw_clrsky_flux_dn_c, sw_clrsky_flux_dn_dir_c,
1318 sw_clnsky_flux_up_c, sw_clnsky_flux_dn_c, sw_clnsky_flux_dn_dir_c,
1319 lw_clnclrsky_flux_up_c, lw_clnclrsky_flux_dn_c,
1320 lw_clrsky_flux_up_c, lw_clrsky_flux_dn_c,
1321 lw_clnsky_flux_up_c, lw_clnsky_flux_dn_c,
1322 sw_bnd_flux_up_c, sw_bnd_flux_dn_c, sw_bnd_flux_dir_c,
1323 lw_bnd_flux_up_c, lw_bnd_flux_dn_c,
1331 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<3>>({0, 0, 0}, {ncol_c, nlay+1, nswbands}),
1332 KOKKOS_LAMBDA (
int icol,
int ilay,
int ibnd)
1334 sw_bnd_flux_dif_c(icol,ilay,ibnd) = sw_bnd_flux_dn_c(icol,ilay,ibnd) - sw_bnd_flux_dir_c(icol,ilay,ibnd);
1337 sw_bnd_flux_dir_c , sw_bnd_flux_dif_c ,
1338 sfc_flux_dir_vis_c, sfc_flux_dir_nir_c,
1339 sfc_flux_dif_vis_c, sfc_flux_dif_nir_c);
1341 gas_concs_c.reset();
static constexpr int ORB_UNDEF_INT
Definition: ERF_Constants.H:115
constexpr amrex::Real mwdair
Definition: ERF_Constants.H:83
constexpr amrex::Real PI
Definition: ERF_Constants.H:24
AMREX_GPU_HOST AMREX_FORCE_INLINE real orbital_cos_zenith(real &jday, real &lat, real &lon, real &declin, real dt_avg=-one, real uniform_angle=-one, real constant_zenith_angle_deg=-one)
Definition: ERF_OrbCosZenith.H:562
AMREX_GPU_HOST AMREX_FORCE_INLINE void orbital_decl(real &calday, real &eccen, real &mvelpp, real &lambm0, real &obliqr, real &delta, real &eccf)
Definition: ERF_OrbCosZenith.H:15
AMREX_GPU_HOST AMREX_FORCE_INLINE void orbital_params(int &iyear_AD, real &eccen, real &obliq, real &mvelp, real &obliqr, real &lambm0, real &mvelpp)
Definition: ERF_OrbCosZenith.H:81
amrex::Real m_dt
Definition: ERF_Radiation.H:226
real(c_double), private cs
Definition: ERF_module_mp_morr_two_moment.F90:203
void rrtmgp_main(const int ncol, const int nlay, real2d_k &p_lay, real2d_k &t_lay, real2d_k &p_lev, real2d_k &t_lev, gas_concs_t &gas_concs, real2d_k &sfc_alb_dir, real2d_k &sfc_alb_dif, real1d_k &mu0, real1d_k &t_sfc, real1d_k &sfc_emis, real1d_k &lw_src, real2d_k &lwp, real2d_k &iwp, real2d_k &rel, real2d_k &rei, real2d_k &cldfrac, real2d_k &sw_flux_up, real2d_k &sw_flux_dn, real2d_k &sw_flux_dn_dir, real2d_k &lw_flux_up, real2d_k &lw_flux_dn, real2d_k &sw_clnclrsky_flux_up, real2d_k &sw_clnclrsky_flux_dn, real2d_k &sw_clnclrsky_flux_dn_dir, real2d_k &sw_clrsky_flux_up, real2d_k &sw_clrsky_flux_dn, real2d_k &sw_clrsky_flux_dn_dir, real2d_k &sw_clnsky_flux_up, real2d_k &sw_clnsky_flux_dn, real2d_k &sw_clnsky_flux_dn_dir, real2d_k &lw_clnclrsky_flux_up, real2d_k &lw_clnclrsky_flux_dn, real2d_k &lw_clrsky_flux_up, real2d_k &lw_clrsky_flux_dn, real2d_k &lw_clnsky_flux_up, real2d_k &lw_clnsky_flux_dn, real3d_k &sw_bnd_flux_up, real3d_k &sw_bnd_flux_dn, real3d_k &sw_bnd_flux_dn_dir, real3d_k &lw_bnd_flux_up, real3d_k &lw_bnd_flux_dn, const RealT tsi_scaling, const bool extra_clnclrsky_diag, const bool extra_clnsky_diag)
Definition: ERF_RRTMGP_Interface.cpp:384
void compute_band_by_band_surface_albedos(const int ncol, const int nswbands, real1d_k &sfc_alb_dir_vis, real1d_k &sfc_alb_dir_nir, real1d_k &sfc_alb_dif_vis, real1d_k &sfc_alb_dif_nir, real2d_k &sfc_alb_dir, real2d_k &sfc_alb_dif)
Definition: ERF_RRTMGP_Interface.cpp:282
void compute_broadband_surface_fluxes(const int ncol, const int kbot, const int nswbands, real3d_k &sw_bnd_flux_dir, real3d_k &sw_bnd_flux_dif, real1d_k &sfc_flux_dir_vis, real1d_k &sfc_flux_dir_nir, real1d_k &sfc_flux_dif_vis, real1d_k &sfc_flux_dif_nir)
Definition: ERF_RRTMGP_Interface.cpp:326
void mixing_ratio_to_cloud_mass(View1 const &mixing_ratio, View2 const &cloud_fraction, View3 const &rho, View4 const &dz, View5 const &cloud_mass)
Definition: ERF_RRTMGP_Utils.H:12