ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_MaterialProperties.H
Go to the documentation of this file.
1 #ifndef MATERIALPROPERTIES_H
2 #define MATERIALPROPERTIES_H
3 
4 #include <AMReX_Enum.H>
5 #include <AMReX_REAL.H>
6 #include <AMReX_Gpu.H>
7 #include <AMReX_MultiFab.H>
8 #include "ERF_Constants.H"
9 
10 /*! Materials */
11 namespace Species
12 {
13  AMREX_ENUM(Name,
14  H2O,
15  NaCl,
16  NH42SO4,
17  NH4HSO4,
18  soil,
19  water, // same as H2O, to test multispecies SDM
20  agua, // same as H2O, to test multispecies SDM
21  none
22  );
23 }
24 
25 /*! Functions for computing saturation pressure and vapour fraction */
26 namespace saturation_funcs
27 {
28  /*! \brief Null function for saturation pressure */
29  AMREX_GPU_HOST
30  void compute_saturation_pressure_null ( amrex::MultiFab&, const amrex::MultiFab& );
31  /*! \brief Compute saturation pressure for moist air */
32  AMREX_GPU_HOST
33  void compute_saturation_pressure_H2O ( amrex::MultiFab&, const amrex::MultiFab& );
34 
35  /*! \brief Null function for saturation vapour fraction */
36  AMREX_GPU_HOST
37  void compute_saturation_vapfrac_null ( amrex::MultiFab&,
38  const amrex::MultiFab&,
39  const amrex::MultiFab& );
40  /*! \brief Compute saturation vapour fraction for moist air */
41  AMREX_GPU_HOST
42  void compute_saturation_vapfrac_H2O ( amrex::MultiFab&,
43  const amrex::MultiFab&,
44  const amrex::MultiFab& );
45 }
46 
47 /*! Class for material properties */
49 
50  static constexpr amrex::Real s_N_av = 6.02214076e23; /*!< Avogadro's number */
51  static constexpr amrex::Real s_kb = 1.380649e-23; /*!< Boltzmann constant [J K^{-1}] */
52 
53  /*! Molecular weight of air [kg mol^{-1}] */
54  static constexpr amrex::Real s_mol_weight_air = 0.0289647;
55  /*! Molecular length scale of air [m] */
56  static constexpr amrex::Real s_sigma_air = 3.62e-10;
57  /*! Temperature parameter for air [K] */
58  static constexpr amrex::Real s_eps_air_k = 97;
59 
60  Species::Name m_name = Species::Name::none; /*!< name */
61  amrex::Real m_density = DBL_MAX; /*!< density */
62  amrex::Real m_ionization = DBL_MAX; /*!< ionization */
63  amrex::Real m_mol_weight = DBL_MAX; /*!< molecular weight (condensate) */
64  amrex::Real m_lat_vap = DBL_MAX; /*!< latent heat of vaporization */
65  amrex::Real m_Rv = DBL_MAX; /*!< gas constant for vapour of this material */
66  amrex::Real m_Tc = DBL_MAX; /*!< critical temperature for surface tension */
67  amrex::Real m_Tb = DBL_MAX; /*!< boiling temperature */
68  amrex::Real m_Nav_by_molweight = DBL_MAX; /*!< Avogadro number by vapour mol. weight */
69  /*! vector of molar heat capacity polynomial coeffs */
71  amrex::Real(DBL_MAX),
72  amrex::Real(DBL_MAX),
73  amrex::Real(DBL_MAX),
74  amrex::Real(DBL_MAX),
75  amrex::Real(DBL_MAX),
76  amrex::Real(DBL_MAX) };
77  bool m_is_soluble = false; /*!< is soluble in water? */
78  bool m_is_water = false; /*!< is this water? */
79  /*! pointer to function to compute saturation pressure */
81  /*! pointer to function to compute vapour fraction */
83 
84  /*! \brief Constructor */
85  AMREX_GPU_HOST_DEVICE
86  MaterialProperties ( const Species::Name& a_name );
87 
88  /*! \brief Copy constructor */
89  AMREX_GPU_HOST_DEVICE
90  MaterialProperties ( const MaterialProperties& a_matprop );
91 
92  /*! \brief Default destructor */
93  AMREX_GPU_HOST_DEVICE
94  ~MaterialProperties () = default;
95 
96  /*! \brief Print parameters */
97  AMREX_GPU_HOST
98  void print() const {
99  amrex::Print() << "Material properties of " << amrex::getEnumNameString(m_name) << ":\n";
100  amrex::Print() << " density: " << m_density << "\n";
101  amrex::Print() << " ionization: " << m_ionization << "\n";
102  amrex::Print() << " mol. weight: " << m_mol_weight << "\n";
103  amrex::Print() << " latent heat (vap.): " << m_lat_vap << "\n";
104  amrex::Print() << " Rv: " << m_Rv << "\n";
105  amrex::Print() << " Tc: " << m_Tc << "\n";
106  amrex::Print() << " Tb: " << m_Tb << "\n";
107  amrex::Print() << " N_av/mol.weight: " << m_Nav_by_molweight << "\n";
108  amrex::Print() << " mol. Cp coeffs: ";
109  for (int i = 0; i < 7; i++) { amrex::Print() << m_mol_Cp_coeffs[i] << ", "; }
110  amrex::Print() << "\n";
111  }
112 
113  /*! \brief Set this material to H20 */
114  AMREX_GPU_HOST_DEVICE
115  void setProperties_H2O();
116  /*! \brief Set this material to water */
117  AMREX_GPU_HOST_DEVICE
118  void setProperties_water();
119  /*! \brief Set this material to agua */
120  AMREX_GPU_HOST_DEVICE
121  void setProperties_agua();
122  /*! \brief Set this material to NaCl */
123  AMREX_GPU_HOST_DEVICE
124  void setProperties_NaCl();
125  /*! \brief Set this material to ammonium sulfate */
126  AMREX_GPU_HOST_DEVICE
127  void setProperties_NH42SO4();
128  /*! \brief Set this material to ammonium bisulfate */
129  AMREX_GPU_HOST_DEVICE
130  void setProperties_NH4HSO4();
131  /*! \brief Set this material to soil */
132  AMREX_GPU_HOST_DEVICE
133  void setProperties_soil();
134 
135  /*! \brief Return the molar heat capacity */
136  AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
138  {
139  auto retval = 0.0;
140  auto term = 1.0;
141  for (auto i = 0; i < 7; i++) {
142  retval += (m_mol_Cp_coeffs[i] * term);
143  term *= a_T;
144  }
145  return retval;
146  }
147 
148  /*! \brief Compute the surface tension coeff given temperature */
149  AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
151  {
152  if (m_is_water) {
153  return amrex::Real(0.076148325); // N m^{-1}
154  } else {
155  auto term1 = 6.0 * std::cbrt(s_N_av);
156  auto term2 = std::cbrt((m_density/m_mol_weight)*(m_density/m_mol_weight));
157  auto retval = molarHeatCapacity(a_T)*(term2/term1)*(m_Tc - a_T);
158  return retval;
159  }
160  }
161 
162  /*! \brief Return the coeff of curvature given the temperature */
163  AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
164  amrex::Real coeffCurv( const amrex::Real a_T ) const
165  {
166  auto surf_tens = surfaceTension(a_T);
167  auto retval = 2 * surf_tens / (m_Rv * m_density);
168  return retval;
169  }
170 
171  /*! \brief Return the vapour pressure coefficient */
172  AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
174  {
175  auto retval = (0.75/PI)*(m_mol_weight/m_density);
176  if (m_is_water) {
177  retval = 4.3e-06;
178  }
179  return retval;
180  }
181 
182  /*! \brief Return the molecular diffusion coefficient given temperature and pressure */
183  AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
185  {
186  if (m_is_water) {
187 
188  return diffelq; // from ERF_Constants.H (2.21e-05 [m^2 s^{-1}])
189 
190  } else {
191 
192  auto mol_weight_v = s_N_av/m_Nav_by_molweight;
193  auto sigma = 1.18e-8 * std::cbrt(mol_weight_v/m_density);
194  auto sigma_v_air = 0.5 * (sigma + s_sigma_air);
195 
196  auto eps_v = 1.15 * m_Tb * s_kb;
197  auto eps_v_air = std::sqrt( eps_v * s_eps_air_k * s_kb);
198  auto T_star = a_T / (eps_v_air/s_kb);
199 
200  auto omegaD = 1.06036 / std::pow(T_star, 0.1561)
201  + 0.193 / std::exp(0.47635*T_star)
202  + 1.03587 / std::exp(1.52996*T_star)
203  + 1.76474 / std::exp(3.89411*T_star);
204 
205  auto term1 = 3 * std::sqrt( s_kb*a_T * s_kb*a_T * s_kb*a_T);
206  auto term2 = 8.0 * std::sqrt(2*PI) * a_P * sigma_v_air*sigma_v_air * omegaD;
207  auto term3 = std::sqrt( m_Nav_by_molweight + s_N_av/s_mol_weight_air );
208 
209  auto retval = term1*term3/term2;
210  return retval;
211  }
212  }
213 
214  /*! \brief Compute saturation pressure */
215  AMREX_GPU_HOST AMREX_FORCE_INLINE
216  void computeSaturationPressure ( amrex::MultiFab& a_e, const amrex::MultiFab& a_T) const
217  {
218  m_saturation_pressure_func(a_e, a_T);
219  }
220 
221  /*! \brief Compute saturation vapour fraction */
222  AMREX_GPU_HOST AMREX_FORCE_INLINE
223  void computeSaturationVapFrac ( amrex::MultiFab& a_S,
224  const amrex::MultiFab& a_T,
225  const amrex::MultiFab& a_p ) const
226  {
227  m_saturation_vapfrac_func(a_S, a_T, a_p);
228  }
229 
230 };
231 
232 #endif
constexpr amrex::Real diffelq
Definition: ERF_Constants.H:73
constexpr amrex::Real PI
Definition: ERF_Constants.H:6
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_MaterialProperties.H:12
AMREX_ENUM(Name, H2O, NaCl, NH42SO4, NH4HSO4, soil, water, agua, none)
Definition: ERF_MaterialProperties.cpp:7
AMREX_GPU_HOST void compute_saturation_pressure_null(MultiFab &, const MultiFab &)
Definition: ERF_MaterialProperties.cpp:9
AMREX_GPU_HOST void compute_saturation_vapfrac_H2O(MultiFab &a_mf_sat_vapfrac, const MultiFab &a_mf_temperature, const MultiFab &a_mf_pressure)
Definition: ERF_MaterialProperties.cpp:32
AMREX_GPU_HOST void compute_saturation_vapfrac_null(MultiFab &, const MultiFab &)
Definition: ERF_MaterialProperties.cpp:29
AMREX_GPU_HOST void compute_saturation_pressure_H2O(MultiFab &a_mf_sat_pressure, const MultiFab &a_mf_temperature)
Definition: ERF_MaterialProperties.cpp:12
Definition: ERF_MaterialProperties.H:48
static constexpr amrex::Real s_mol_weight_air
Definition: ERF_MaterialProperties.H:54
AMREX_GPU_HOST_DEVICE ~MaterialProperties()=default
Default destructor.
amrex::Real m_mol_weight
Definition: ERF_MaterialProperties.H:63
static constexpr amrex::Real s_sigma_air
Definition: ERF_MaterialProperties.H:56
amrex::Real m_Tb
Definition: ERF_MaterialProperties.H:67
amrex::Real m_Nav_by_molweight
Definition: ERF_MaterialProperties.H:68
AMREX_GPU_HOST_DEVICE void setProperties_water()
Set this material to water.
Definition: ERF_MaterialProperties.cpp:122
AMREX_GPU_HOST AMREX_FORCE_INLINE void computeSaturationVapFrac(amrex::MultiFab &a_S, const amrex::MultiFab &a_T, const amrex::MultiFab &a_p) const
Compute saturation vapour fraction.
Definition: ERF_MaterialProperties.H:223
static constexpr amrex::Real s_eps_air_k
Definition: ERF_MaterialProperties.H:58
decltype(saturation_funcs::compute_saturation_pressure_null) * m_saturation_pressure_func
Definition: ERF_MaterialProperties.H:80
AMREX_GPU_HOST AMREX_FORCE_INLINE void computeSaturationPressure(amrex::MultiFab &a_e, const amrex::MultiFab &a_T) const
Compute saturation pressure.
Definition: ERF_MaterialProperties.H:216
AMREX_GPU_HOST_DEVICE void setProperties_NH4HSO4()
Set this material to ammonium bisulfate.
Definition: ERF_MaterialProperties.cpp:158
amrex::Real m_mol_Cp_coeffs[7]
Definition: ERF_MaterialProperties.H:70
amrex::Real m_Tc
Definition: ERF_MaterialProperties.H:66
AMREX_GPU_HOST_DEVICE void setProperties_soil()
Set this material to soil.
Definition: ERF_MaterialProperties.cpp:170
amrex::Real m_Rv
Definition: ERF_MaterialProperties.H:65
AMREX_GPU_HOST_DEVICE void setProperties_NH42SO4()
Set this material to ammonium sulfate.
Definition: ERF_MaterialProperties.cpp:146
AMREX_GPU_HOST_DEVICE MaterialProperties(const Species::Name &a_name)
Constructor.
Definition: ERF_MaterialProperties.cpp:56
AMREX_GPU_HOST void print() const
Print parameters.
Definition: ERF_MaterialProperties.H:98
AMREX_GPU_HOST_DEVICE void setProperties_NaCl()
Set this material to NaCl.
Definition: ERF_MaterialProperties.cpp:134
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real coeffMolecularDiffusion(const amrex::Real a_T, const amrex::Real a_P) const
Return the molecular diffusion coefficient given temperature and pressure.
Definition: ERF_MaterialProperties.H:184
amrex::Real m_ionization
Definition: ERF_MaterialProperties.H:62
bool m_is_water
Definition: ERF_MaterialProperties.H:78
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real coeffCurv(const amrex::Real a_T) const
Return the coeff of curvature given the temperature.
Definition: ERF_MaterialProperties.H:164
AMREX_GPU_HOST_DEVICE void setProperties_H2O()
Set this material to H20.
Definition: ERF_MaterialProperties.cpp:102
AMREX_GPU_HOST_DEVICE void setProperties_agua()
Set this material to agua.
Definition: ERF_MaterialProperties.cpp:128
static constexpr amrex::Real s_N_av
Definition: ERF_MaterialProperties.H:50
bool m_is_soluble
Definition: ERF_MaterialProperties.H:77
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real surfaceTension(const amrex::Real a_T) const
Compute the surface tension coeff given temperature.
Definition: ERF_MaterialProperties.H:150
amrex::Real m_density
Definition: ERF_MaterialProperties.H:61
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real molarHeatCapacity(const amrex::Real a_T) const
Return the molar heat capacity.
Definition: ERF_MaterialProperties.H:137
amrex::Real m_lat_vap
Definition: ERF_MaterialProperties.H:64
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real coeffVPSolute() const
Return the vapour pressure coefficient.
Definition: ERF_MaterialProperties.H:173
Species::Name m_name
Definition: ERF_MaterialProperties.H:60
decltype(saturation_funcs::compute_saturation_vapfrac_null) * m_saturation_vapfrac_func
Definition: ERF_MaterialProperties.H:82
static constexpr amrex::Real s_kb
Definition: ERF_MaterialProperties.H:51