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

#include <ERF_MOSTStress.H>

Collaboration diagram for similarity_funs:

Public Member Functions

AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_m2 (amrex::Real zeta) const
 
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_h2 (amrex::Real zeta) const
 
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_m (amrex::Real zeta) const
 
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real calc_psi_h (amrex::Real zeta) const
 

Private Attributes

amrex::Real beta_m {5.0}
 Constants from Dyer, BLM, 1974. More...
 
amrex::Real beta_h {5.0}
 https://doi.org/10.1007/BF00240838 More...
 
amrex::Real gamma_m {16.0}
 
amrex::Real gamma_h {16.0}
 

Detailed Description

Structure of similarity functions for Moeng formulation

Member Function Documentation

◆ calc_psi_h()

AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real similarity_funs::calc_psi_h ( amrex::Real  zeta) const
inline
102  {
103  if (zeta > 0) {
104  return -beta_h * zeta;
105  } else {
106  amrex::Real x = std::sqrt(1.0 - gamma_h * zeta);
107  return 2.0 * std::log(0.5 * (1.0 + x));
108  }
109  }
amrex::Real Real
Definition: ERF_ShocInterface.H:16
amrex::Real beta_h
https://doi.org/10.1007/BF00240838
Definition: ERF_MOSTStress.H:113
amrex::Real gamma_h
Definition: ERF_MOSTStress.H:115

Referenced by surface_flux_charnock::iterate_flux(), surface_flux_mod_charnock::iterate_flux(), surface_flux_donelan::iterate_flux(), surface_temp_donelan::iterate_flux(), surface_flux_wave_coupled::iterate_flux(), surface_temp_wave_coupled::iterate_flux(), and surface_flux::iterate_flux().

Here is the caller graph for this function:

◆ calc_psi_h2()

AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real similarity_funs::calc_psi_h2 ( amrex::Real  zeta) const
inline
65  {
66  if (zeta > 0) {
67  amrex::Real x = std::pow(1.0 + std::pow(zeta, 1.1), 1.0/1.1);
68  return ( -6.1*std::log(zeta + x) );
69  } else {
70  amrex::Real x = std::sqrt(1.0 - 16.0*zeta);
71  amrex::Real psi_k_h = 2.0 * std::log(0.5 * (1.0 + x));
72  amrex::Real y = std::pow(1.0 - 34.0*zeta, 1.0/3.0);
73  amrex::Real psi_c_h = (3.0/2.0)*std::log((y*y + y + 1.0)/3.0)
74  - std::sqrt(3.0)*std::atan((2.0*y + 1.0)/std::sqrt(3.0))
75  + PI/std::sqrt(3.0);
76  return ( (psi_k_h + zeta*zeta*psi_c_h) / (1. + zeta*zeta) );
77  }
78  }
constexpr amrex::Real PI
Definition: ERF_Constants.H:6

Referenced by surface_temp_charnock::iterate_flux(), surface_temp_mod_charnock::iterate_flux(), and surface_temp::iterate_flux().

Here is the caller graph for this function:

◆ calc_psi_m()

AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real similarity_funs::calc_psi_m ( amrex::Real  zeta) const
inline
88  {
89  if (zeta > 0) {
90  return -beta_m * zeta;
91  } else {
92  amrex::Real x = std::sqrt(std::sqrt(1.0 - gamma_m * zeta));
93  return 2.0 * std::log(0.5 * (1.0 + x)) + log(0.5 * (1.0 + x * x)) -
94  2.0 * std::atan(x) + PIoTwo;
95  }
96  }
constexpr amrex::Real PIoTwo
Definition: ERF_Constants.H:7
amrex::Real beta_m
Constants from Dyer, BLM, 1974.
Definition: ERF_MOSTStress.H:112
amrex::Real gamma_m
Definition: ERF_MOSTStress.H:114

Referenced by surface_flux_charnock::iterate_flux(), surface_flux_mod_charnock::iterate_flux(), surface_flux_donelan::iterate_flux(), surface_temp_donelan::iterate_flux(), surface_flux_wave_coupled::iterate_flux(), surface_temp_wave_coupled::iterate_flux(), and surface_flux::iterate_flux().

Here is the caller graph for this function:

◆ calc_psi_m2()

AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real similarity_funs::calc_psi_m2 ( amrex::Real  zeta) const
inline
45  {
46  if (zeta > 0) {
47  amrex::Real x = std::pow(1.0 + std::pow(zeta, 2.5), 1.0/2.5);
48  return ( -6.1*std::log(zeta + x) );
49  } else {
50  amrex::Real x = std::pow(1.0 - 16.0*zeta, 0.25);
51  amrex::Real psi_k_m = 2.0 * std::log(0.5 * (1.0 + x)) + log(0.5 * (1.0 + x * x)) -
52  2.0 * std::atan(x) + PIoTwo;
53  amrex::Real y = std::pow(1.0 - 10.0*zeta, 1.0/3.0);
54  amrex::Real psi_c_m = (3.0/2.0)*std::log((y*y + y + 1.0)/3.0)
55  - std::sqrt(3.0)*std::atan((2.0*y + 1.0)/std::sqrt(3.0))
56  + PI/std::sqrt(3.0);
57  return ( (psi_k_m + zeta*zeta*psi_c_m) / (1. + zeta*zeta) );
58  }
59  }

Referenced by surface_temp_charnock::iterate_flux(), surface_temp_mod_charnock::iterate_flux(), and surface_temp::iterate_flux().

Here is the caller graph for this function:

Member Data Documentation

◆ beta_h

amrex::Real similarity_funs::beta_h {5.0}
private

◆ beta_m

amrex::Real similarity_funs::beta_m {5.0}
private

Constants from Dyer, BLM, 1974.

Referenced by calc_psi_m().

◆ gamma_h

amrex::Real similarity_funs::gamma_h {16.0}
private

Referenced by calc_psi_h().

◆ gamma_m

amrex::Real similarity_funs::gamma_m {16.0}
private

Referenced by calc_psi_m().


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