1050 const auto ncol =
m_ncol;
1051 const auto nlay =
m_nlay;
1057 double obliqr, lambm0, mvelpp;
1062 if (eccen >= 0 && obliq >= 0 && mvelp >= 0) {
1067 mvelp, obliqr, lambm0, mvelpp);
1078 orbital_decl(calday, eccen, mvelpp, lambm0, obliqr, delta, eccf);
1082 if (fixed_total_solar_irradiance >= 0){
1083 eccf = fixed_total_solar_irradiance/
Real(1360.9);
1091 for (
int igas(0); igas <
m_ngas; ++igas) {
1092 auto tmp2d = Kokkos::View<RealT**,layout_t,KokkosDefaultMem>(
"tmp2d", ncol, nlay);
1095 if (name ==
"H2O") {
1097 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1098 KOKKOS_LAMBDA (
int icol,
int ilay)
1100 tmp2d(icol,ilay) = qv_lay_d(icol,ilay) *
mwdair/gas_mol_weight;
1102 }
else if (name ==
"CO2") {
1103 Kokkos::deep_copy(tmp2d,
m_co2vmr);
1104 }
else if (name ==
"O3") {
1106 Kokkos::deep_copy(tmp2d,
m_o3vmr[0] );
1109 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1110 KOKKOS_LAMBDA (
int icol,
int ilay)
1112 tmp2d(icol,ilay) = o3_lay_d(ilay);
1115 }
else if (name ==
"N2O") {
1116 Kokkos::deep_copy(tmp2d,
m_n2ovmr);
1117 }
else if (name ==
"CO") {
1118 Kokkos::deep_copy(tmp2d,
m_covmr );
1119 }
else if (name ==
"CH4") {
1120 Kokkos::deep_copy(tmp2d,
m_ch4vmr);
1121 }
else if (name ==
"O2") {
1122 Kokkos::deep_copy(tmp2d,
m_o2vmr );
1123 }
else if (name ==
"N2") {
1124 Kokkos::deep_copy(tmp2d,
m_n2vmr );
1126 Abort(
"Radiation: Unknown gas component.");
1136 auto h_mu0 = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
mu0);
1140 auto h_lat = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
lat);
1141 auto h_lon = Kokkos::create_mirror_view_and_copy(Kokkos::HostSpace(),
lon);
1142 double dt = double(
m_dt);
1144 Kokkos::parallel_for(Kokkos::RangePolicy<Kokkos::Serial>(0, ncol),
1148 double lat_col = h_lat(icol)*
PI/
Real(180.0);
1149 double lon_col = h_lon(icol)*
PI/
Real(180.0);
1150 double lcalday = calday;
1151 double ldelta = delta;
1152 double dt_avg =
static_cast<double>(rad_freq_in_steps) * dt;
1156 Kokkos::deep_copy(
mu0, h_mu0);
1163 Table2D<Real,Order::C> lwp_tab(
lwp.data(), {0,0}, {static_cast<int>(lwp.extent(0)),static_cast<int>(lwp.extent(1))});
1164 Table2D<Real,Order::C> iwp_tab(
iwp.data(), {0,0}, {static_cast<int>(iwp.extent(0)),static_cast<int>(iwp.extent(1))});
1165 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol, nlay}),
1166 KOKKOS_LAMBDA (
int icol,
int ilay)
1168 lwp_tab(icol,ilay) *=
Real(1.e3);
1169 iwp_tab(icol,ilay) *=
Real(1.e3);
1182 Vector<real2d_k> vmr_full_vec(
m_ngas);
1183 for (
int igas = 0; igas <
m_ngas; ++igas) {
1184 vmr_full_vec[igas] =
real2d_k(
"vmr_full_" + std::to_string(igas), ncol, nlay);
1188 for (
int col_s = 0; col_s < ncol; col_s += ncol_chunk) {
1189 const int ncol_c = std::min(ncol_chunk, ncol - col_s);
1190 const int col_e = col_s + ncol_c;
1191 auto cr = std::make_pair(col_s, col_e);
1208 const int stride2_nlay = nlay;
1209 const int stride2_nlayp1 = nlay + 1;
1210 real2d_k p_lay_c (
p_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1211 real2d_k t_lay_c (
t_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1212 real2d_k r_lay_c (
r_lay.data() + col_s*stride2_nlay, ncol_c, nlay);
1213 real2d_k z_del_c (
z_del.data() + col_s*stride2_nlay, ncol_c, nlay);
1214 real2d_k lwp_c (
lwp.data() + col_s*stride2_nlay, ncol_c, nlay);
1215 real2d_k iwp_c (
iwp.data() + col_s*stride2_nlay, ncol_c, nlay);
1223 real2d_k p_lev_c (
p_lev.data() + col_s*stride2_nlayp1, ncol_c, nlay+1);
1224 real2d_k t_lev_c (
t_lev.data() + col_s*stride2_nlayp1, ncol_c, nlay+1);
1238 real2d_k sw_clnclrsky_flux_up_c, sw_clnclrsky_flux_dn_c, sw_clnclrsky_flux_dn_dir_c;
1239 real2d_k lw_clnclrsky_flux_up_c, lw_clnclrsky_flux_dn_c;
1247 sw_clnclrsky_flux_up_c =
real2d_k(
"sw_clnclrsky_flux_up_c" , 1, 1);
1248 sw_clnclrsky_flux_dn_c =
real2d_k(
"sw_clnclrsky_flux_dn_c" , 1, 1);
1249 sw_clnclrsky_flux_dn_dir_c =
real2d_k(
"sw_clnclrsky_flux_dn_dir_c", 1, 1);
1250 lw_clnclrsky_flux_up_c =
real2d_k(
"lw_clnclrsky_flux_up_c" , 1, 1);
1251 lw_clnclrsky_flux_dn_c =
real2d_k(
"lw_clnclrsky_flux_dn_c" , 1, 1);
1254 real2d_k sw_clnsky_flux_up_c, sw_clnsky_flux_dn_c, sw_clnsky_flux_dn_dir_c;
1255 real2d_k lw_clnsky_flux_up_c, lw_clnsky_flux_dn_c;
1263 sw_clnsky_flux_up_c =
real2d_k(
"sw_clnsky_flux_up_c" , 1, 1);
1264 sw_clnsky_flux_dn_c =
real2d_k(
"sw_clnsky_flux_dn_c" , 1, 1);
1265 sw_clnsky_flux_dn_dir_c =
real2d_k(
"sw_clnsky_flux_dn_dir_c", 1, 1);
1266 lw_clnsky_flux_up_c =
real2d_k(
"lw_clnsky_flux_up_c" , 1, 1);
1267 lw_clnsky_flux_dn_c =
real2d_k(
"lw_clnsky_flux_dn_c" , 1, 1);
1275 const int stride3_sw = stride2_nlayp1 * nswbands;
1276 const int stride3_lw = stride2_nlayp1 *
m_nlwbands;
1287 for (
int igas = 0; igas <
m_ngas; ++igas) {
1288 real2d_k vmr_c(
"vmr_c", ncol_c, nlay);
1289 auto vmr_full = vmr_full_vec[igas];
1291 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<2>>({0, 0}, {ncol_c, nlay}),
1292 KOKKOS_LAMBDA (
int i,
int j) {
1293 vmr_c(i, j) = vmr_full(
cs + i, j);
1300 sfc_alb_dir_vis_c, sfc_alb_dir_nir_c,
1301 sfc_alb_dif_vis_c, sfc_alb_dif_nir_c,
1302 sfc_alb_dir_c , sfc_alb_dif_c);
1309 sfc_alb_dir_c, sfc_alb_dif_c, mu0_c,
1310 t_sfc_c, sfc_emis_c, lw_src_c,
1311 lwp_c, iwp_c, eff_radius_qc_c, eff_radius_qi_c, cldfrac_tot_c,
1312 sw_flux_up_c, sw_flux_dn_c, sw_flux_dn_dir_c,
1313 lw_flux_up_c, lw_flux_dn_c,
1314 sw_clnclrsky_flux_up_c, sw_clnclrsky_flux_dn_c, sw_clnclrsky_flux_dn_dir_c,
1315 sw_clrsky_flux_up_c, sw_clrsky_flux_dn_c, sw_clrsky_flux_dn_dir_c,
1316 sw_clnsky_flux_up_c, sw_clnsky_flux_dn_c, sw_clnsky_flux_dn_dir_c,
1317 lw_clnclrsky_flux_up_c, lw_clnclrsky_flux_dn_c,
1318 lw_clrsky_flux_up_c, lw_clrsky_flux_dn_c,
1319 lw_clnsky_flux_up_c, lw_clnsky_flux_dn_c,
1320 sw_bnd_flux_up_c, sw_bnd_flux_dn_c, sw_bnd_flux_dir_c,
1321 lw_bnd_flux_up_c, lw_bnd_flux_dn_c,
1329 Kokkos::parallel_for(Kokkos::MDRangePolicy<Kokkos::Rank<3>>({0, 0, 0}, {ncol_c, nlay+1, nswbands}),
1330 KOKKOS_LAMBDA (
int icol,
int ilay,
int ibnd)
1332 sw_bnd_flux_dif_c(icol,ilay,ibnd) = sw_bnd_flux_dn_c(icol,ilay,ibnd) - sw_bnd_flux_dir_c(icol,ilay,ibnd);
1335 sw_bnd_flux_dir_c , sw_bnd_flux_dif_c ,
1336 sfc_flux_dir_vis_c, sfc_flux_dir_nir_c,
1337 sfc_flux_dif_vis_c, sfc_flux_dif_nir_c);
1339 gas_concs_c.reset();
static constexpr int ORB_UNDEF_INT
Definition: ERF_Constants.H:107
constexpr amrex::Real mwdair
Definition: ERF_Constants.H:75
constexpr amrex::Real PI
Definition: ERF_Constants.H:16
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:224
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