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

#include <ERF_DiffStruct.H>

Collaboration diagram for DiffChoice:

Public Member Functions

void init_params ()
 
void display ()
 

Public Attributes

std::string pp_prefix {"erf"}
 
MolecDiffType molec_diff_type = MolecDiffType::Constant
 
amrex::Real alpha_T = 0.0
 
amrex::Real alpha_C = 0.0
 
amrex::Real rho0_trans = 1.0
 
amrex::Real rhoAlpha_T = 0.0
 
amrex::Real rhoAlpha_C = 0.0
 
amrex::Real dynamic_viscosity = 0.0
 

Detailed Description

Container holding diffusion-related choices

Member Function Documentation

◆ display()

void DiffChoice::display ( )
inline
65  {
66  amrex::Print() << "Diffusion choices: " << std::endl;
67  amrex::Print() << " rho0_trans : " << rho0_trans << std::endl;
68  amrex::Print() << " alpha_T : " << alpha_T << std::endl;
69  amrex::Print() << " alpha_C : " << alpha_C << std::endl;
70  amrex::Print() << " dynamic_viscosity : " << dynamic_viscosity << std::endl;
71 
73  amrex::Print() << "Using constant molecular diffusivity (relevant for DNS)" << std::endl;
74  } else if (molec_diff_type == MolecDiffType::None) {
75  amrex::Print() << "Not using any molecular diffusivity, i.e. using the modeled turbulent diffusivity"
76  << std::endl;
77  }
78  }
amrex::Real rho0_trans
Definition: ERF_DiffStruct.H:91
amrex::Real alpha_T
Definition: ERF_DiffStruct.H:87
amrex::Real alpha_C
Definition: ERF_DiffStruct.H:88
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:84
amrex::Real dynamic_viscosity
Definition: ERF_DiffStruct.H:96

Referenced by SolverChoice::display().

Here is the caller graph for this function:

◆ init_params()

void DiffChoice::init_params ( )
inline
22  {
23  amrex::ParmParse pp(pp_prefix);
24 
25  static std::string molec_diff_type_string = "None";
26  pp.query("molec_diff_type",molec_diff_type_string);
27 
28  if (!molec_diff_type_string.compare("Constant")) {
30  } else if (!molec_diff_type_string.compare("ConstantAlpha")) {
32  } else if (!molec_diff_type_string.compare("None")) {
34  } else {
35  amrex::Error("Don't know this molec_diff_type");
36  }
37 
39  pp.query("alpha_T", alpha_T);
40  pp.query("alpha_C", alpha_C);
41  pp.query("dynamic_viscosity", dynamic_viscosity);
42  pp.query("rho0_trans", rho0_trans);
43  }
44 
45  // Compute relevant forms of diffusion parameters
48 
50  amrex::Print() << "Using constant kinematic diffusion coefficients" << std::endl;
51  amrex::Print() << " momentum : " << dynamic_viscosity/rho0_trans << " m^2/s" << std::endl;
52  amrex::Print() << " temperature : " << alpha_T << " m^2/s" << std::endl;
53  amrex::Print() << " scalar : " << alpha_C << " m^2/s" << std::endl;
54  }
56  amrex::Print() << "Using constant dynamic diffusion coefficients" << std::endl;
57  amrex::Print() << " momentum : " << dynamic_viscosity << " kg/(m-s)" << std::endl;
58  amrex::Print() << " temperature : " << rhoAlpha_T << " kg/(m-s)" << std::endl;
59  amrex::Print() << " scalar : " << rhoAlpha_C << " kg/(m-s)" << std::endl;
60  }
61 
62  }
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real pp(amrex::Real y)
Definition: ERF_MicrophysicsUtils.H:219
amrex::Real rhoAlpha_C
Definition: ERF_DiffStruct.H:95
amrex::Real rhoAlpha_T
Definition: ERF_DiffStruct.H:94
std::string pp_prefix
Definition: ERF_DiffStruct.H:81

Referenced by SolverChoice::init_params().

Here is the call graph for this function:
Here is the caller graph for this function:

Member Data Documentation

◆ alpha_C

amrex::Real DiffChoice::alpha_C = 0.0

◆ alpha_T

amrex::Real DiffChoice::alpha_T = 0.0

◆ dynamic_viscosity

amrex::Real DiffChoice::dynamic_viscosity = 0.0

◆ molec_diff_type

◆ pp_prefix

std::string DiffChoice::pp_prefix {"erf"}

Referenced by init_params().

◆ rho0_trans

amrex::Real DiffChoice::rho0_trans = 1.0

◆ rhoAlpha_C

amrex::Real DiffChoice::rhoAlpha_C = 0.0

◆ rhoAlpha_T

amrex::Real DiffChoice::rhoAlpha_T = 0.0

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