BOMBPROOF, PISM’s numerical scheme for conservation of energy¶
Introduction¶
One of the essential goals for any thermomechanically-coupled numerical ice sheet model is a completely bombproof numerical scheme for the advection-conduction-reaction problem for the conservation of energy within the ice. “Bombproof” means being as stable as possible in as many realistic modeling contexts as possible. PISM’s scheme is observed to be highly robust in practice, but it is also provably stable in a significant range of circumstances. The scheme is special to shallow ice sheets because it makes specific tradeoff choices with respect to vertical velocity. It is generic and low order in how it treats horizontal velocity. In this page we state the scheme, prove its stability properties, and address the basal boundary condition.
The scheme is conditionally-stable. The length of the time step is limited only by the maximum magnitude of the horizontal velocities within the ice, i.e. horizontal CFL. This condition for stability is included in the PISM adaptive time-stepping technique.
Accuracy is necessarily a second goal. Our shallow scheme has truncation error
The conservation of energy problem for the ice is in terms of an enthalpy field [22]. The current scheme supercedes the cold-ice, temperature-based scheme described in the appendices of [16] and in [10]. Compared to a cold-ice scheme, the enthalpy formulation does a better job of conserving energy, has a more-physical model for basal melt rate and drainage, and can model polythermal ice with any CTS topology [22]. The finite difference implementation of the enthalpy method is robust and avoids the CFL condition on vertical advection which was present in the older, cold-ice scheme.
The bedrock thermal problem is solved by splitting the timestep into an update of the
bedrock temperature field, assuming the ice base is as constant temperature, and an update
of the ice enthalpy field, by the BOMBPROOF scheme here, assuming the upward heat flux
from the bedrock layer is constant during the timestep. For more on the implementation,
see the BedThermalUnit
class.
The region in which the conservation of energy equation needs to be solved changes over
time. This is an essential complicating factor in ice sheet modeling. Also relevant is
that the velocity field has a complicated provenance as it comes from different stress
balance equations chosen at runtime. These stress balances, especially with transitions in
flow type, for instance at grounding lines, are incompletely understood when
thermomechanically-coupled. (The ShallowStressBalance
instance owned by
IceModel
could be the SIA, the SSA, a hybrid of these, or other stress balances in
future PISM versions.) We will therefore not make, in proving stability, assumptions about
the regularity of the velocity field in space or time other than boundedness.
Nor do we want the numerical scheme for advection to need any information about the velocity except its value at the beginning of the time step. Thus the conservation of energy timestep is assumed to be split from the mass continuity time step and its associated stress balance solve. We have not considered implementing a scheme which requires the Jacobian of the velocity field with respect to changes in enthalpy, for example. At very least such a fully-implicit scheme would require blind iteration (e.g. with no guarantee of convergence of the iteration). The scheme we propose involves no such iteration.
Conservation of energy in a shallow ice sheet¶
In an enthalpy formulation [22] (and references therein),
the ice sheet is regarded as a mixture of two phases, solid and liquid, so that both cold
and temperate ice with liquid ice matrix can be modeled. The specific enthalpy field of
the ice mixture is denoted
where
Neglecting the dependence of conductivity and heat capacity on temperature [22], the heat flux in cold ice and temperate ice is
where
where
The additive quantity
where StressBalance::compute_volumetric_strain_heating()
. (
Friction from sliding also is a source of heating. It has units of
where StressBalance::basal_frictional_heating()
. The friction heating is concentrated at
We use a shallow approximation of equation (82) which lacks horizontal conduction terms [38]. For the initial analysis of the core BOMBPROOF scheme, we specialize to cold ice. Within cold ice, the coefficient in the heat flux is constant, so
Therefore the equation we initially analyze is
We focus the analysis on the direction in which the enthalpy has largest derivative,
namely with respect to the vertical coordinate
where
We assume that the surface enthalpy energy::BedThermalUnit
object, and it may come from an evolving temperature field within the upper crust, the
bedrock layer. If a surface temperature is given then it will be converted to enthalpy by
the EnthalpyConverter
class.) The boundary conditions to problem (85)
are, therefore,
For a temperate ice base, including any ice base below which there is liquid water, the lower boundary condition is more interesting. It is addressed below in section Temperate basal boundary condition, and computing the basal melt rate.
The core BOMBPROOF scheme¶
For the discussion of the numerical scheme below, let
The scheme we use for horizontal advection is explicit first-order upwinding. There is a CFL condition for the scheme to be stable, in the absence of conduction, based on the magnitude of the horizontal velocity components. To state the upwind scheme itself, let
The approximate horizontal advection terms, and thus the approximation to the whole
term
The CFL stability condition for this part of the scheme is
The routine max_timestep_cfl_3d()
computes the maximum of velocity
magnitudes. This produces a time step restriction based on the above CFL condition. Then
IceModel::max_timestep()
implements adaptive time-stepping based on this and
other stability criteria.
In the analysis below we assume an equally-spaced grid EnthalpyModel
and AgeModel
.)
The
Equation (88), along with a determination of
while the first order upwind formula has lower accuracy,
Thus we prefer to use the centered formula when possible, but we apply (implicit) upwinding when it is needed for its added stability benefits.
We now rewrite (88) for computational purposes as one of a system of equations
for the unknowns
Now multiply equation (88) by
Here
Equation (89) has coefficients which are scaled to have no units. It is
ready to be put in the system managed by enthSystemCtx
.
One way of stating the stability of first-order upwinding is to say it satisfies
a “maximum principle” [74]. An example of a maximum principle
for this kind of finite difference scheme is that if
for nonnegative coefficients
Thus a “wiggle” cannot appear in
However, the pure implicit centered difference scheme (
is less stable than implicit first-order upwinding. It is less stable in the same sense
that Crank-Nicolson is a less stable scheme than backwards Euler for the simplest heat
equation
Stability properties of the BOMBPROOF scheme¶
We want to be precise about the phrase “unconditionally stable” for BOMBPROOF. To do so we consider somewhat simplified cases which are amenable to analysis, and we prove two stability properties. These stability properties identify the precise advantages of BOMBPROOF.
Theorem (stating the stability properties).¶
Assume, for the precise but limited assertion of this theorem, that the surface
temperature
reset at each time step
A maximum principle applies without further assumptions.
Suppose we freeze the coefficients of the problem to have constant values in time and space. (Concretely, we assume that
is chosen independently of the time step , and that is the same for each time step. We assume constant vertical velocity . We also consider a spatially-periodic or unbounded version of our problem, with no boundary conditions.) Then a von Neumann analysis of the constant coefficient problem yields a growth factor less than one for all modes on the grid.
Remarks¶
The phrases maximum principle and von Neumann analysis will be precisely illustrated in the following proof. Both approaches are in [74]. There is additional information on the von Neumann analysis of implicit finite difference methods for advection in [172].
These statements also apply in case
Proof of 1¶
In the case considered for the maximum principle, with
We claim that with choice (92) for
Therefore the only concerns are for the coefficient of
Thus all the coefficients in (93) are nonnegative. On the other hand, in equation (93), all coefficients on the right side sum to
which is exactly the coefficient on the left side of (93). It follows that
where
Proof of 2¶
As a von Neumann analysis is much more restrictive than the analysis above, we will be brief.
Let’s assume the velocity is downward,
The heart of the von Neumann analysis is the substitution of a growing or decaying
(in time index
Here
This equation reduces by standard manipulations to
Note
This positive number is less than one, so
Remark about our von Neumann stability analysis¶
The constant
Convergence: a consequence of the maximum principle¶
If we define the pointwise numerical error
where
for all
It follows that
Remark on nonzero source term¶
Now recall we assumed in Theorem 1 that the entire “source”
is stable in the general sense of numerical schemes for partial differential equations (e.g. as defined in subsection 5.5 of [74]) then the same scheme is stable in the same general sense when applied to the equation with (linear) lower order terms:
A precise statement of this general fact is hard to find in the literature, to put it
mildly, but theorem 2.2.3 of [172] is one interesting case (
Nonetheless the maximum principle is a highly-desirable form of stability because we can exclude “wiggles” from the finite difference approximations of the conductive and advective terms, even if the complete physics, with strain heating in particular, is not yet shown to be non-explosive. Because the complete physics includes the appearance of the famous “spokes” of EISMINT II, for example, a maximum principle cannot apply too literally. Indeed there is an underlying fluid instability [16], one that means the solution of the continuum equations can include growing “wiggles” which are fluid features (though not at the grid-based spatial frequency of the usual numerical wiggles). Recall that, because we use first-order upwinding on the horizontal advection terms, we can expect maximum principle-type stability behavior of the whole three-dimensional scheme.
Temperate basal boundary condition, and computing the basal melt rate¶
At the bottom of grounded ice, a certain amount of heat comes out of the earth and either
enters the ice through conduction or melts the base of the ice. On the one hand, see the
documentation for BedThermalUnit
for the model of how much comes out of the
earth. On the other hand, [22] includes a careful
analysis of the subglacial layer equation and the corresponding boundary conditions and
basal melt rate calculation, and the reader should consult that reference.
Regarding the floating case¶
The shelf base temperature OceanModel
.
Note that we make the possibly-peculiar physical choice that the shelf base temperature is
used as the temperature at the top of the bedrock, which is actually the bottom of the
ocean. This choice means that there should be no abrupt changes in top-of-bedrock heat
flux as the grounding line moves. This choice also means that the conservation of energy
code does not need to know about the bedrock topography or the elevation of sea level. (In
the future OceanModel
could have a subshelf_bed_temperature()
method.)
Previous | Up | Next |