ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
LandSurface Class Reference

#include <ERF_LandSurface.H>

Collaboration diagram for LandSurface:

Public Member Functions

 LandSurface ()
 
 ~LandSurface ()=default
 
void ReSize (const int &nlev)
 
template<class NewSurfModel >
void SetModel ()
 
void Define (const int &lev, SolverChoice &sc)
 
void Init (const int &lev, const amrex::MultiFab &cons_in, const amrex::Geometry &geom, const amrex::Real &dt_advance)
 
void Advance (const int &lev, amrex::MultiFab &cons_in, amrex::MultiFab &xvel_in, amrex::MultiFab &yvel_in, amrex::MultiFab *hfx3_out, amrex::MultiFab *qfx3_out, const amrex::Real &dt_advance, const int &nstep)
 
void Advance (const int &lev, const amrex::Real &dt_advance)
 
void Plot (const int &lev, const int &nstep)
 
void Update_Micro_Vars_Lev (const int &lev, amrex::MultiFab &cons_in)
 
void Update_State_Vars_Lev (const int &lev, amrex::MultiFab &cons_in)
 
amrex::MultiFab * Get_Data_Ptr (const int &lev, const int &varIdx)
 
amrex::MultiFab * Get_Flux_Ptr (const int &lev, const int &varIdx)
 
amrex::Geometry Get_Lsm_Geom (const int &lev)
 
int Get_Data_Size ()
 
int Get_Flux_Size ()
 
std::string Get_DataName (const int &varIdx)
 
int Get_DataIdx (const int &lev, std::string &varname)
 
std::string Get_FluxName (const int &varIdx)
 
int Get_FluxIdx (const int &lev, std::string &varname)
 
std::unordered_map< std::string, std::string > & Get_WRFInputNames ()
 
void Plot_Lsm_Data (amrex::Real time, const amrex::Vector< int > &level_steps, const amrex::Vector< amrex::IntVect > &ref_ratio)
 
template<class SurfModelType >
SurfModelType * get_model_lev (const int &lev)
 

Private Attributes

amrex::Vector< std::unique_ptr< NullSurf > > m_lsm_model
 
std::string plot_file_lsm {"plt_lsm_"}
 
amrex::Vector< amrex::Geometry > m_lsm_geom_lev
 
amrex::Vector< amrex::MultiFab > m_lsm_data_lev
 

Constructor & Destructor Documentation

◆ LandSurface()

LandSurface::LandSurface ( )
inline
20 { }

◆ ~LandSurface()

LandSurface::~LandSurface ( )
default

Member Function Documentation

◆ Advance() [1/2]

void LandSurface::Advance ( const int &  lev,
amrex::MultiFab &  cons_in,
amrex::MultiFab &  xvel_in,
amrex::MultiFab &  yvel_in,
amrex::MultiFab *  hfx3_out,
amrex::MultiFab *  qfx3_out,
const amrex::Real dt_advance,
const int &  nstep 
)
inline
61  {
62  m_lsm_model[lev]->Advance_With_State(lev, cons_in, xvel_in, yvel_in, hfx3_out, qfx3_out, dt_advance, nstep);
63  }
amrex::Vector< std::unique_ptr< NullSurf > > m_lsm_model
Definition: ERF_LandSurface.H:162

◆ Advance() [2/2]

void LandSurface::Advance ( const int &  lev,
const amrex::Real dt_advance 
)
inline
67  {
68  m_lsm_model[lev]->Advance(dt_advance);
69  }

◆ Define()

void LandSurface::Define ( const int &  lev,
SolverChoice sc 
)
inline
39  {
40  m_lsm_model[lev]->Define(sc);
41  }

◆ Get_Data_Ptr()

amrex::MultiFab* LandSurface::Get_Data_Ptr ( const int &  lev,
const int &  varIdx 
)
inline
90 { return m_lsm_model[lev]->Lsm_Data_Ptr(varIdx); }

Referenced by ERF::ApplyOceanSurfaceState(), and Plot_Lsm_Data().

Here is the caller graph for this function:

◆ Get_Data_Size()

int LandSurface::Get_Data_Size ( )
inline
99 { return m_lsm_model[0]->Lsm_Data_Size(); }

Referenced by Plot_Lsm_Data().

Here is the caller graph for this function:

◆ Get_DataIdx()

int LandSurface::Get_DataIdx ( const int &  lev,
std::string &  varname 
)
inline
108 { return m_lsm_model[lev]->Lsm_DataIndex(varname); }

◆ Get_DataName()

std::string LandSurface::Get_DataName ( const int &  varIdx)
inline
105 { return m_lsm_model[0]->Lsm_DataName(varIdx); }

Referenced by Plot_Lsm_Data().

Here is the caller graph for this function:

◆ Get_Flux_Ptr()

amrex::MultiFab* LandSurface::Get_Flux_Ptr ( const int &  lev,
const int &  varIdx 
)
inline
93 { return m_lsm_model[lev]->Lsm_Flux_Ptr(varIdx); }

◆ Get_Flux_Size()

int LandSurface::Get_Flux_Size ( )
inline
102 { return m_lsm_model[0]->Lsm_Flux_Size(); }

◆ Get_FluxIdx()

int LandSurface::Get_FluxIdx ( const int &  lev,
std::string &  varname 
)
inline
114 { return m_lsm_model[lev]->Lsm_FluxIndex(varname); }

◆ Get_FluxName()

std::string LandSurface::Get_FluxName ( const int &  varIdx)
inline
111 { return m_lsm_model[0]->Lsm_FluxName(varIdx); }

◆ Get_Lsm_Geom()

amrex::Geometry LandSurface::Get_Lsm_Geom ( const int &  lev)
inline
96 { return m_lsm_model[lev]->Lsm_Geom(); }

Referenced by Plot_Lsm_Data().

Here is the caller graph for this function:

◆ get_model_lev()

template<class SurfModelType >
SurfModelType* LandSurface::get_model_lev ( const int &  lev)
inline
156  {
157  return static_cast<SurfModelType*>(m_lsm_model[lev].get());
158  }

◆ Get_WRFInputNames()

std::unordered_map<std::string,std::string>& LandSurface::Get_WRFInputNames ( )
inline
117 { return m_lsm_model[0]->Lsm_WRFInputNames(); }

◆ Init()

void LandSurface::Init ( const int &  lev,
const amrex::MultiFab &  cons_in,
const amrex::Geometry &  geom,
const amrex::Real dt_advance 
)
inline
48  {
49  m_lsm_model[lev]->Init(lev, cons_in, geom, dt_advance);
50  }

◆ Plot()

void LandSurface::Plot ( const int &  lev,
const int &  nstep 
)
inline
73  {
74  m_lsm_model[lev]->Plot_Landfile(nstep);
75  }

Referenced by ERF::EvolveOneStep().

Here is the caller graph for this function:

◆ Plot_Lsm_Data()

void LandSurface::Plot_Lsm_Data ( amrex::Real  time,
const amrex::Vector< int > &  level_steps,
const amrex::Vector< amrex::IntVect > &  ref_ratio 
)
inline
123  {
124  int nlev = m_lsm_model.size();
125  int nvar = this->Get_Data_Size();
126  amrex::Vector<std::string> varnames;
127 
128  // Only write if we have valid pointers
129  if (this->Get_Data_Ptr(0,0)) {
130  varnames.resize(nvar);
131  m_lsm_geom_lev.resize(nlev);
132  m_lsm_data_lev.resize(nlev);
133  std::string plotfilename = amrex::Concatenate(plot_file_lsm, level_steps[0], 5);
134  for (int lev(0); lev<nlev; ++lev) {
135  m_lsm_geom_lev[lev] = this->Get_Lsm_Geom(lev);
136 
137  amrex::MultiFab* mf_lsm = this->Get_Data_Ptr(lev,0);
138  amrex::IntVect ng(0,0,0);
139  amrex::BoxArray ba = mf_lsm->boxArray();
140  amrex::DistributionMapping dm = mf_lsm->DistributionMap();
141  m_lsm_data_lev[lev].define(ba, dm, nvar, ng);
142  for (int n(0); n<nvar; ++n) {
143  mf_lsm = this->Get_Data_Ptr(lev,n);
144  amrex::MultiFab::Copy(m_lsm_data_lev[lev],*(mf_lsm),0,n,1,0);
145  if (lev==0) varnames[n] = this->Get_DataName(n);
146  }
147  }
148  WriteMultiLevelPlotfile (plotfilename, nlev, GetVecOfConstPtrs(m_lsm_data_lev),
149  varnames, m_lsm_geom_lev, time, level_steps, ref_ratio);
150  m_lsm_geom_lev.clear();
151  m_lsm_data_lev.clear();
152  }
153  }
amrex::Vector< amrex::Geometry > m_lsm_geom_lev
Definition: ERF_LandSurface.H:168
int Get_Data_Size()
Definition: ERF_LandSurface.H:99
amrex::Geometry Get_Lsm_Geom(const int &lev)
Definition: ERF_LandSurface.H:96
amrex::Vector< amrex::MultiFab > m_lsm_data_lev
Definition: ERF_LandSurface.H:171
std::string Get_DataName(const int &varIdx)
Definition: ERF_LandSurface.H:105
amrex::MultiFab * Get_Data_Ptr(const int &lev, const int &varIdx)
Definition: ERF_LandSurface.H:90
std::string plot_file_lsm
Definition: ERF_LandSurface.H:165
@ ng
Definition: ERF_Morrison.H:48
Here is the call graph for this function:

◆ ReSize()

void LandSurface::ReSize ( const int &  nlev)
inline
25 { m_lsm_model.resize(nlev); }

◆ SetModel()

template<class NewSurfModel >
void LandSurface::SetModel ( )
inline
30  {
31  for (int lev(0); lev<m_lsm_model.size(); ++lev) {
32  m_lsm_model[lev] = std::make_unique<NewSurfModel>();
33  }
34  }

◆ Update_Micro_Vars_Lev()

void LandSurface::Update_Micro_Vars_Lev ( const int &  lev,
amrex::MultiFab &  cons_in 
)
inline
79  {
80  m_lsm_model[lev]->Update_Micro_Vars(cons_in);
81  }

◆ Update_State_Vars_Lev()

void LandSurface::Update_State_Vars_Lev ( const int &  lev,
amrex::MultiFab &  cons_in 
)
inline
85  {
86  m_lsm_model[lev]->Update_State_Vars(cons_in);
87  }

Member Data Documentation

◆ m_lsm_data_lev

amrex::Vector<amrex::MultiFab> LandSurface::m_lsm_data_lev
private

Referenced by Plot_Lsm_Data().

◆ m_lsm_geom_lev

amrex::Vector<amrex::Geometry> LandSurface::m_lsm_geom_lev
private

Referenced by Plot_Lsm_Data().

◆ m_lsm_model

◆ plot_file_lsm

std::string LandSurface::plot_file_lsm {"plt_lsm_"}
private

Referenced by Plot_Lsm_Data().


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