PISM, A Parallel Ice Sheet Model 2.2.2-d6b3a29ca committed by Constantine Khrulev on 2025-03-28
|
PISM bed deformation model (base class). More...
#include <BedDef.hh>
Public Member Functions | |
BedDef (std::shared_ptr< const Grid > g, const std::string &model_name) | |
virtual | ~BedDef ()=default |
void | init (const InputOptions &opts, const array::Scalar &ice_thickness, const array::Scalar &sea_level_elevation) |
void | bootstrap (const array::Scalar &bed_elevation, const array::Scalar &bed_uplift, const array::Scalar &ice_thickness, const array::Scalar &sea_level_elevation) |
Initialize using provided bed elevation and uplift. | |
void | update (const array::Scalar &ice_thickness, const array::Scalar &sea_level_elevation, double t, double dt) |
const array::Scalar & | bed_elevation () const |
const array::Scalar & | uplift () const |
![]() | |
Component (std::shared_ptr< const Grid > grid) | |
virtual | ~Component ()=default |
DiagnosticList | diagnostics () const |
TSDiagnosticList | ts_diagnostics () const |
std::shared_ptr< const Grid > | grid () const |
const Time & | time () const |
const Profiling & | profiling () const |
void | define_model_state (const File &output) const |
Define model state variables in an output file. | |
void | write_model_state (const File &output) const |
Write model state variables to an output file. | |
MaxTimestep | max_timestep (double t) const |
Reports the maximum time-step the model can take at time t. | |
Protected Member Functions | |
virtual MaxTimestep | max_timestep_impl (double t) const |
virtual void | define_model_state_impl (const File &output) const |
The default (empty implementation). | |
virtual void | write_model_state_impl (const File &output) const |
The default (empty implementation). | |
virtual DiagnosticList | diagnostics_impl () const |
virtual void | update_impl (const array::Scalar &load, double t, double dt)=0 |
virtual void | init_impl (const InputOptions &opts, const array::Scalar &ice_thickness, const array::Scalar &sea_level_elevation)=0 |
virtual void | bootstrap_impl (const array::Scalar &bed_elevation, const array::Scalar &bed_uplift, const array::Scalar &ice_thickness, const array::Scalar &sea_level_elevation)=0 |
![]() | |
virtual TSDiagnosticList | ts_diagnostics_impl () const |
void | regrid (const std::string &module_name, array::Array &variable, RegriddingFlag flag=NO_REGRID_WITHOUT_REGRID_VARS) |
Static Protected Member Functions | |
static void | apply_topg_offset (const std::string &filename, array::Scalar &bed_topography) |
Protected Attributes | |
array::Scalar2 | m_topg |
current bed elevation | |
array::Scalar | m_topg_last |
bed elevation at the time of the last update | |
array::Scalar | m_load |
array::Scalar | m_load_accumulator |
array::Scalar | m_uplift |
bed uplift rate | |
double | m_t_last |
time of the last bed deformation update | |
double | m_update_interval |
Update interval in seconds. | |
double | m_t_eps |
Temporal resolution to use when checking whether it's time to update. | |
std::string | m_time_name |
Name of the variable used to store the last update time. | |
std::string | m_model_name |
![]() | |
const std::shared_ptr< const Grid > | m_grid |
grid used by this component | |
const Config::ConstPtr | m_config |
configuration database used by this component | |
const units::System::Ptr | m_sys |
unit system used by this component | |
const Logger::ConstPtr | m_log |
logger (for easy access) | |
Additional Inherited Members | |
![]() | |
enum | RegriddingFlag { REGRID_WITHOUT_REGRID_VARS , NO_REGRID_WITHOUT_REGRID_VARS } |
This flag determines whether a variable is read from the -regrid_file file even if it is not listed among variables in -regrid_vars . More... | |