Loading [MathJax]/extensions/tex2jax.js
PISM, A Parallel Ice Sheet Model 2.2.2-d6b3a29ca committed by Constantine Khrulev on 2025-03-28
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
ShallowStressBalance.hh
Go to the documentation of this file.
1// Copyright (C) 2010--2019, 2021, 2022 Constantine Khroulev and Ed Bueler
2//
3// This file is part of PISM.
4//
5// PISM is free software; you can redistribute it and/or modify it under the
6// terms of the GNU General Public License as published by the Free Software
7// Foundation; either version 3 of the License, or (at your option) any later
8// version.
9//
10// PISM is distributed in the hope that it will be useful, but WITHOUT ANY
11// WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12// FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13// details.
14//
15// You should have received a copy of the GNU General Public License
16// along with PISM; if not, write to the Free Software
17// Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18
19#ifndef _SHALLOWSTRESSBALANCE_H_
20#define _SHALLOWSTRESSBALANCE_H_
21
22#include "pism/util/Component.hh"
23#include "pism/util/array/Vector.hh"
24#include "pism/util/EnthalpyConverter.hh"
25
26namespace pism {
27namespace rheology {
28class FlowLaw;
29}
30
31class Grid;
32class IceBasalResistancePlasticLaw;
33
34namespace stressbalance {
35
36class Inputs;
37
38//! Shallow stress balance (such as the SSA).
40public:
41 ShallowStressBalance(std::shared_ptr<const Grid> g);
42 virtual ~ShallowStressBalance();
43
44 // initialization and I/O:
45
46 void init();
47
48 virtual void update(const Inputs &inputs, bool full_update) = 0;
49
50 //! \brief Get the thickness-advective 2D velocity.
51 const array::Vector1& velocity() const;
52
53 //! \brief Get the basal frictional heating (for the adaptive energy time-stepping).
55
57 const array::Scalar &tauc,
58 const array::CellType &mask,
59 array::Scalar &result) const;
60 // helpers:
61
62 //! \brief Produce a report string for the standard output.
63 virtual std::string stdout_report() const;
64
65 std::shared_ptr<const rheology::FlowLaw> flow_law() const;
66
68
70
71 double flow_enhancement_factor() const;
72protected:
73 virtual void init_impl();
74
75 virtual DiagnosticList diagnostics_impl() const;
76
78 std::shared_ptr<rheology::FlowLaw> m_flow_law;
80
83
84 //! flow enhancement factor
85 double m_e_factor;
86};
87
88//! Returns zero velocity field, zero friction heating, and zero for D^2.
89/*!
90 This derived class is used in the non-sliding SIA approximation. This
91 implementation ignores any basal resistance fields (e.g. yield stress from
92 the IceModel or other user of this class).
93*/
95public:
96 ZeroSliding(std::shared_ptr<const Grid> g);
97 virtual ~ZeroSliding() = default;
98
99 virtual void update(const Inputs &inputs, bool full_update);
100
101protected:
102};
103
105public:
106 PrescribedSliding(std::shared_ptr<const Grid> g);
107 virtual ~PrescribedSliding() = default;
108 virtual void update(const Inputs &inputs, bool full_update);
109protected:
110 virtual void init_impl();
111};
112
113} // end of namespace stressbalance
114} // end of namespace pism
115
116#endif /* _SHALLOWSTRESSBALANCE_H_ */
A class defining a common interface for most PISM sub-models.
Definition Component.hh:118
std::shared_ptr< EnthalpyConverter > Ptr
Class containing physical constants and the constitutive relation describing till for SSA.
"Cell type" mask. Adds convenience methods to array::Scalar.
Definition CellType.hh:30
virtual void update(const Inputs &inputs, bool full_update)
Update the trivial shallow stress balance object.
const array::Vector1 & velocity() const
Get the thickness-advective 2D velocity.
void compute_basal_frictional_heating(const array::Vector &velocity, const array::Scalar &tauc, const array::CellType &mask, array::Scalar &result) const
Compute the basal frictional heating.
std::shared_ptr< const rheology::FlowLaw > flow_law() const
virtual DiagnosticList diagnostics_impl() const
std::shared_ptr< rheology::FlowLaw > m_flow_law
IceBasalResistancePlasticLaw * m_basal_sliding_law
const IceBasalResistancePlasticLaw * sliding_law() const
virtual void update(const Inputs &inputs, bool full_update)=0
virtual std::string stdout_report() const
Produce a report string for the standard output.
const array::Scalar & basal_frictional_heating()
Get the basal frictional heating (for the adaptive energy time-stepping).
EnthalpyConverter::Ptr enthalpy_converter() const
Shallow stress balance (such as the SSA).
virtual void update(const Inputs &inputs, bool full_update)
Update the trivial shallow stress balance object.
Returns zero velocity field, zero friction heating, and zero for D^2.
static const double g
Definition exactTestP.cc:36
std::map< std::string, Diagnostic::Ptr > DiagnosticList