PISM, A Parallel Ice Sheet Model  stable v2.1-1-g6902d5502 committed by Ed Bueler on 2023-12-20 08:38:27 -0800
PatersonBuddWarm.cc
Go to the documentation of this file.
1 /* Copyright (C) 2015, 2023 PISM Authors
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 
20 #include <cmath>
21 
22 #include "pism/rheology/PatersonBuddWarm.hh"
23 
24 namespace pism {
25 namespace rheology {
26 
27 PatersonBuddWarm::PatersonBuddWarm(const std::string &prefix,
28  const Config &config, EnthalpyConverter::Ptr ec)
29  : PatersonBudd(prefix, config, ec) {
30  m_name = "Paterson-Budd (warm case)";
31 }
32 
33 double PatersonBuddWarm::tempFromSoftness(double A) const {
34  return - m_Q_warm / (m_ideal_gas_constant * (log(A) - log(m_A_warm)));
35 }
36 
37 // takes care of hardness...
38 double PatersonBuddWarm::softness_from_temp(double T_pa) const {
39  return m_A_warm * exp(-m_Q_warm / (m_ideal_gas_constant * T_pa));
40 }
41 
42 // ignores pressure and uses non-pressure-adjusted temperature
43 double PatersonBuddWarm::flow_from_temp(double stress, double temp,
44  double , double) const {
45  return softness_from_temp(temp) * pow(stress,m_n-1);
46 }
47 
48 
49 } // end of namespace rheology
50 } // end of namespace pism
A class for storing and accessing PISM configuration flags and parameters.
std::shared_ptr< EnthalpyConverter > Ptr
double m_A_warm
Paterson-Budd softness, warm case.
Definition: FlowLaw.hh:141
std::string m_name
Definition: FlowLaw.hh:117
double m_ideal_gas_constant
ideal gas constant
Definition: FlowLaw.hh:152
double m_Q_warm
Activation energy, warm case.
Definition: FlowLaw.hh:145
double m_n
power law exponent
Definition: FlowLaw.hh:154
double flow_from_temp(double stress, double temp, double, double) const
The flow law (temperature-dependent version).
double softness_from_temp(double T_pa) const
PatersonBuddWarm(const std::string &prefix, const Config &config, EnthalpyConverter::Ptr EC)
double tempFromSoftness(double A) const
Return the temperature T corresponding to a given value A=A(T).
Derived class of FlowLaw for Paterson-Budd (1982)-Glen ice.
Definition: PatersonBudd.hh:32