ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
moeng_flux Struct Reference

#include <ERF_MOSTStress.H>

Collaboration diagram for moeng_flux:

Public Member Functions

 moeng_flux ()
 
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real compute_q_flux (const int &i, const int &j, const int &k, const amrex::Array4< const amrex::Real > &cons_arr, const amrex::Array4< const amrex::Real > &velx_arr, const amrex::Array4< const amrex::Real > &vely_arr, const amrex::Array4< const amrex::Real > &umm_arr, const amrex::Array4< const amrex::Real > &qvm_arr, const amrex::Array4< const amrex::Real > &u_star_arr, const amrex::Array4< const amrex::Real > &q_star_arr, const amrex::Array4< const amrex::Real > &q_surf_arr) const
 
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real compute_t_flux (const int &i, const int &j, const int &k, const amrex::Array4< const amrex::Real > &cons_arr, const amrex::Array4< const amrex::Real > &velx_arr, const amrex::Array4< const amrex::Real > &vely_arr, const amrex::Array4< const amrex::Real > &umm_arr, const amrex::Array4< const amrex::Real > &tm_arr, const amrex::Array4< const amrex::Real > &u_star_arr, const amrex::Array4< const amrex::Real > &t_star_arr, const amrex::Array4< const amrex::Real > &t_surf_arr) const
 
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real compute_u_flux (const int &i, const int &j, const int &k, const amrex::Array4< const amrex::Real > &cons_arr, const amrex::Array4< const amrex::Real > &velx_arr, const amrex::Array4< const amrex::Real > &vely_arr, const amrex::Array4< const amrex::Real > &umm_arr, const amrex::Array4< const amrex::Real > &um_arr, const amrex::Array4< const amrex::Real > &u_star_arr) const
 
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real compute_v_flux (const int &i, const int &j, const int &k, const amrex::Array4< const amrex::Real > &cons_arr, const amrex::Array4< const amrex::Real > &velx_arr, const amrex::Array4< const amrex::Real > &vely_arr, const amrex::Array4< const amrex::Real > &umm_arr, const amrex::Array4< const amrex::Real > &vm_arr, const amrex::Array4< const amrex::Real > &u_star_arr) const
 

Private Attributes

const amrex::Real eps = amrex::Real(1e-15)
 
const amrex::Real WSMIN = amrex::Real(0.1)
 

Detailed Description

Moeng flux formulation

Constructor & Destructor Documentation

◆ moeng_flux()

moeng_flux::moeng_flux ( )
inline
1797 {}

Member Function Documentation

◆ compute_q_flux()

AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real moeng_flux::compute_q_flux ( const int &  i,
const int &  j,
const int &  k,
const amrex::Array4< const amrex::Real > &  cons_arr,
const amrex::Array4< const amrex::Real > &  velx_arr,
const amrex::Array4< const amrex::Real > &  vely_arr,
const amrex::Array4< const amrex::Real > &  umm_arr,
const amrex::Array4< const amrex::Real > &  qvm_arr,
const amrex::Array4< const amrex::Real > &  u_star_arr,
const amrex::Array4< const amrex::Real > &  q_star_arr,
const amrex::Array4< const amrex::Real > &  q_surf_arr 
) const
inline
1813  {
1814  amrex::Real rho = cons_arr(i,j,k,Rho_comp);
1815  amrex::Real qv = cons_arr(i,j,k,RhoQ1_comp) / rho;
1816  amrex::Real velx = myhalf * ( velx_arr(i,j,k) + velx_arr(i+1,j ,k) );
1817  amrex::Real vely = myhalf * ( vely_arr(i,j,k) + vely_arr(i ,j+1,k) );
1818 
1819  amrex::Real qv_mean = qvm_arr(i,j,0);
1820  amrex::Real ustar = u_star_arr(i,j,0);
1821  amrex::Real qstar = q_star_arr(i,j,0);
1822  amrex::Real qv_surf = q_surf_arr(i,j,0);
1823  amrex::Real wsp_mean = umm_arr(i,j,0);
1824  wsp_mean = std::max(wsp_mean, WSMIN);
1825 
1826  amrex::Real wsp = std::sqrt(velx*velx+vely*vely);
1827  amrex::Real num1 = wsp * (qv_mean-qv_surf);
1828  amrex::Real num2 = wsp_mean * (qv-qv_mean);
1829 
1830  // NOTE: this is rho*<Qv'w'> = -K dQvdz
1831  amrex::Real moflux = (std::abs(qstar) > eps) ?
1832  -rho*qstar*ustar*(num1+num2)/((qv_mean-qv_surf)*wsp_mean) : zero;
1833 
1834  return moflux;
1835  }
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:11
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
rho
Definition: ERF_InitCustomPert_Bubble.H:106
amrex::Real Real
Definition: ERF_ShocInterface.H:19
@ qv
Definition: ERF_Kessler.H:29
const amrex::Real eps
Definition: ERF_MOSTStress.H:1953
const amrex::Real WSMIN
Definition: ERF_MOSTStress.H:1955

◆ compute_t_flux()

AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real moeng_flux::compute_t_flux ( const int &  i,
const int &  j,
const int &  k,
const amrex::Array4< const amrex::Real > &  cons_arr,
const amrex::Array4< const amrex::Real > &  velx_arr,
const amrex::Array4< const amrex::Real > &  vely_arr,
const amrex::Array4< const amrex::Real > &  umm_arr,
const amrex::Array4< const amrex::Real > &  tm_arr,
const amrex::Array4< const amrex::Real > &  u_star_arr,
const amrex::Array4< const amrex::Real > &  t_star_arr,
const amrex::Array4< const amrex::Real > &  t_surf_arr 
) const
inline
1851  {
1852  amrex::Real rho = cons_arr(i,j,k,Rho_comp);
1853  amrex::Real theta = cons_arr(i,j,k,RhoTheta_comp) / rho;
1854  amrex::Real velx = myhalf * ( velx_arr(i,j,k) + velx_arr(i+1,j ,k) );
1855  amrex::Real vely = myhalf * ( vely_arr(i,j,k) + vely_arr(i ,j+1,k) );
1856 
1857  amrex::Real theta_mean = tm_arr(i,j,0);
1858  amrex::Real ustar = u_star_arr(i,j,0);
1859  amrex::Real tstar = t_star_arr(i,j,0);
1860  amrex::Real theta_surf = t_surf_arr(i,j,0);
1861  amrex::Real wsp_mean = umm_arr(i,j,0);
1862  wsp_mean = std::max(wsp_mean, WSMIN);
1863 
1864  amrex::Real wsp = std::sqrt(velx*velx+vely*vely);
1865  amrex::Real num1 = wsp * (theta_mean-theta_surf);
1866  amrex::Real num2 = wsp_mean * (theta-theta_mean);
1867 
1868  // NOTE: this is rho*<T'w'> = -K dTdz
1869  amrex::Real moflux = (std::abs(tstar) > eps) ?
1870  -rho*tstar*ustar*(num1+num2)/((theta_mean-theta_surf)*wsp_mean) : zero;
1871 
1872  return moflux;
1873  }
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
@ theta
Definition: ERF_MM5.H:20

◆ compute_u_flux()

AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real moeng_flux::compute_u_flux ( const int &  i,
const int &  j,
const int &  k,
const amrex::Array4< const amrex::Real > &  cons_arr,
const amrex::Array4< const amrex::Real > &  velx_arr,
const amrex::Array4< const amrex::Real > &  vely_arr,
const amrex::Array4< const amrex::Real > &  umm_arr,
const amrex::Array4< const amrex::Real > &  um_arr,
const amrex::Array4< const amrex::Real > &  u_star_arr 
) const
inline
1887  {
1888  amrex::Real velx = velx_arr(i,j,k);
1889  amrex::Real vely = fourth * ( vely_arr(i ,j,k) + vely_arr(i ,j+1,k)
1890  + vely_arr(i-1,j,k) + vely_arr(i-1,j+1,k) );
1891  amrex::Real rho = myhalf * ( cons_arr(i-1,j,k,Rho_comp) + cons_arr(i,j,k,Rho_comp) );
1892 
1893  amrex::Real umean = um_arr(i,j,0);
1894  amrex::Real ustar = myhalf * ( u_star_arr(i-1,j,0) + u_star_arr(i,j,0) );
1895  amrex::Real wsp_mean = myhalf * ( umm_arr(i-1,j,0) + umm_arr(i,j,0) );
1896  wsp_mean = std::max(wsp_mean, WSMIN);
1897 
1898  // Note: The surface mean shear stress is decomposed into tau_xz by
1899  // multiplying the modeled shear stress (rho*ustar^2) with
1900  // a factor of umean/wsp_mean for directionality; this factor
1901  // modifies the denominator from what is in Moeng amrex::Real(1984.)
1902  amrex::Real wsp = std::sqrt(velx*velx+vely*vely);
1903  amrex::Real num1 = wsp * umean;
1904  amrex::Real num2 = wsp_mean * (velx-umean);
1905 
1906  // NOTE: this is rho*<u'w'> = -K dudz
1907  amrex::Real stressx = -rho*ustar*ustar * (num1+num2)/(wsp_mean*wsp_mean);
1908 
1909  return stressx;
1910  }
constexpr amrex::Real fourth
Definition: ERF_Constants.H:12

◆ compute_v_flux()

AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real moeng_flux::compute_v_flux ( const int &  i,
const int &  j,
const int &  k,
const amrex::Array4< const amrex::Real > &  cons_arr,
const amrex::Array4< const amrex::Real > &  velx_arr,
const amrex::Array4< const amrex::Real > &  vely_arr,
const amrex::Array4< const amrex::Real > &  umm_arr,
const amrex::Array4< const amrex::Real > &  vm_arr,
const amrex::Array4< const amrex::Real > &  u_star_arr 
) const
inline
1924  {
1925  amrex::Real velx = fourth * ( velx_arr(i,j ,k) + velx_arr(i+1,j ,k)
1926  + velx_arr(i,j-1,k) + velx_arr(i+1,j-1,k) );
1927  amrex::Real vely = vely_arr(i,j,k);
1928  amrex::Real rho = myhalf * ( cons_arr(i,j-1,k,Rho_comp) + cons_arr(i,j,k,Rho_comp) );
1929 
1930  amrex::Real vmean = vm_arr(i,j,0);
1931  amrex::Real ustar = myhalf * ( u_star_arr(i,j-1,0) + u_star_arr(i,j,0) );
1932  amrex::Real wsp_mean = myhalf * ( umm_arr(i,j-1,0) + umm_arr(i,j,0) );
1933  wsp_mean = std::max(wsp_mean, WSMIN);
1934 
1935  // Note: The surface mean shear stress is decomposed into tau_yz by
1936  // multiplying the modeled shear stress (rho*ustar^2) with
1937  // a factor of vmean/wsp_mean for directionality; this factor
1938  // modifies the denominator from what is in Moeng amrex::Real(1984.)
1939  amrex::Real wsp = std::sqrt(velx*velx+vely*vely);
1940  amrex::Real num1 = wsp * vmean;
1941  amrex::Real num2 = wsp_mean * (vely-vmean);
1942 
1943  // NOTE: this is rho*<v'w'> = -K dvdz
1944  amrex::Real stressy = -rho*ustar*ustar * (num1+num2)/(wsp_mean*wsp_mean);
1945 
1946  return stressy;
1947  }

Member Data Documentation

◆ eps

const amrex::Real moeng_flux::eps = amrex::Real(1e-15)
private

Referenced by compute_q_flux(), and compute_t_flux().

◆ WSMIN

const amrex::Real moeng_flux::WSMIN = amrex::Real(0.1)
private

The documentation for this struct was generated from the following file: