Governing Equations
The equation set and solution procedure used by MAESTROeX has changed and improved over time. In this chapter, we outline the model equations and algorithmic options in the code. The latest published references for MAESTROeX are the multilevel paper [NonakaAlmgrenBell+10] and the more recent [FanNonakaAlmgren+19]. These two papers use the same model equations, however the more recent paper, in addition to retaining the original algorithmic capability of the previous code, includes an option to use a new, simplified temporal integration scheme. We distinguish between the two temporal integration strategies by referring to them as the “original temporal scheme” and “new temporal scheme”. In this description, we make frequent reference to papers I-IV and the multilevel paper (see § Introduction to MAESTROeX), which describe the developments of the original temporal scheme.
Summary of the MAESTROeX Equation Set
Here we summarize the equations solved by MAESTROeX. We refer the reader to papers I through IV for the derivation and motivation of the equation set. We take the standard equations of reacting, compressible flow, and recast the equation of state (EOS) as a divergence constraint on the velocity field. The resulting model is a series of evolution equations for mass, energy, and momentum, subject to an additional constraint on velocity, with a base state density and pressure linked via hydrostatic equilibrium:
We discuss each of these equations in further detail below.
Lateral Average
A key concept in the MAESTROeX equation set and algorithm is
the lateral average. The lateral average represents the average
value of a quantity at a given radius in spherical simulations
(or a given height in planar simulations). We denote the
lateral average of a quantity with an overline, e.g.,
for any quantity
For the velocity field, we can decompose the full velocity field into a base state velocity and a local velocity,
where
Mass
Conservation of mass gives the same continuity equation we have with compressible flow:
where
and
In the original temporal scheme, we need to model the evolution of a base state density,
Subtracting these two yields the evolution equation for the perturbational
density,
As first discussed in paper III and then refined in the multilevel paper, we capture
the changes that can occur due to significant convective
overturning by imposing the constraint that
where
In practice, we correct the drift by simply setting
Energy
We model the evolution of specific enthalpy,
where
When we are using thermal diffusion, there will be an additional term in the enthalpy equation (see § Thermal Diffusion Changes).
In the original temporal scheme, we utilized a base state enthlpy that effectively represents the average over a layer; its evolution equation can be found by laterally averaging Eq.27
We will often expand
where we defined
In paper III, we showed that for a plane-parallel atmosphere with
constant gravity,
At times, we will define a temperature equation by writing
Subtracting it from the full enthalpy equation gives:
Base State
The stratified atmosphere is characterized by a one-dimensional
time-dependent base state, defined by a base state density,
The gravitational acceleration,
For the time-dependence, we will define a base state velocity,
For convenience, we define a base state enthalphy,
Base State Expansion
In practice, we calculate
Then we define
once
Momentum
The compressible momentum equation (written in terms of velocity is):
Subtracting off the equation of hydrostatic equilibrium, and defining the perturbational
pressure (sometimes called the dynamic pressure) as
or
This is the form of the momentum equation that we solved in papers I–IV and in the multilevel paper.
Several authors [KP12, VLB+13] explored the idea of energy conservation in a low Mach number system and found that an additional term (which can look like a buoyancy) is needed in the low Mach number formulation, yielding:
This is the form that we enforce in MAESTROeX, and the choice is controlled
by use_alt_energy_fix
.
We decompose the full velocity field into a base state velocity,
with
where
The divergence constraint for
Velocity Constraint
The equation of state is cast into an elliptic constraint on the
velocity field by differentiating
where
and
where use_thermal_diffusion = T
). In this term,
In this constraint,
Notation
Throughout the papers describing MAESTROeX, we’ve largely kept our notation consistent. The table below defines the frequently-used quantities and provides their units.
symbol |
description |
units |
---|---|---|
specific heat at
constant pressure
( |
erg g |
|
volume discrepancy
factor
( |
– |
|
gravitational acceleration |
cm s |
|
specific enthalpy |
erg g |
|
external heating energy generation rate |
erg g |
|
nuclear energy generation rate |
erg g |
|
cm |
||
thermal conductivity |
erg cm |
|
base state pressure |
erg cm |
|
erg cm |
||
erg cm |
||
erg g |
||
specific nuclear binding energy |
erg g |
|
radial coordinate (direction of gravity) |
cm |
|
specific entropy |
erg g |
|
source term to the divergence constraint |
s |
|
time |
s |
|
temperature |
K |
|
total velocity
( |
cm s |
|
local velocity |
cm s |
|
advective velocity (edge-centered) |
cm s |
|
base state expansion velocity |
cm s |
|
mass fraction of the
species
( |
– |
|
coefficient to velocity in velocity constraint equation |
g cm |
|
first adiabatic exponent
( |
– |
|
g cm |
||
erg g |
||
dynamic pressure |
erg cm |
|
base state dynamic pressure |
erg cm |
|
mass density |
g cm |
|
base state mass density |
g cm |
|
perturbational density
( |
g cm |
|
base state enthalpy density |
erg cm |
|
perturbational enthalpy density
|
erg cm |
|
erg |
||
erg cm |
||
creation rate for species |
s |
Time Advancement Algorithm Ingredients
The full time advancement algorithm is detailed in [NonakaAlmgrenBell+10] for the original algorithm and [FanNonakaAlmgren+19] for the new, simplified algorithm. We do not repeat that here.
The overall flow of the algorithm is depicted in the following flowcharts:

Fig. 1 A flowchart of the algorithm. The thermodynamic state variables, base state variables, and local velocity are indicated in each step. Red text indicates that quantity was updated during that step. The predictor-corrector steps are outlined by the dotted box. The blue text indicates state variables that are the same in Step 6 as they are in Step 2, i.e., they are unchanged by the predictor steps. The diffusion steps (4a and 8a) are optional, depending on use_thermal_diffusion.

Fig. 2 A flowchart for Steps 4 and 8. The thermodynamic state variables
and base state variables are indicated in each step. Red text
indicates that quantity was updated during that step. Note, for
Step 4, the updated quantities should also have a
Here are some of the basic ingredients to the solver:
Definitions
Below we define operations that will be referenced in § Volume Discrepancy Changes.
React State
Here the temperature equation comes from Eq.31 with
Full details of the solution procedure can be found in Paper III. We then define:
where the enthalpy update includes external heat sources
The source code for this operation can be found in react_state.f90.
Advect Base Density
planar:
We discretize equation Eq.23 to compute the new base state density,
(50)We compute the time-centered edge states,
, by discretizing an expanded form of Eq.23:(51)where the right hand side is used as the force term.
spherical:
The base state density update now includes the area factors in the divergences:
(52)In order to compute the time-centered edge states, an additional geometric term is added to the forcing, due to the spherical discretization of Eq.23:
(53)
Enforce HSE
where
Advect Base Enthalpy
planar:
We discretize Eq.28, neglecting reaction source terms, to compute the new base state enthalpy,
(55)We compute the time-centered edge states,
, by discretizing an expanded form of Eq.28:(56)spherical:
The base state enthalpy update now includes the area factors in the divergences:
(57)In order to compute the time-centered edge states, an additional geometric term is added to the forcing, due to the spherical discretization of Eq.28:
(58)
Computing
Here we describe the process by which we compute
planar:
:In Paper III, we showed that
for planar geometries, and derived derived Eq.34 as an alternate expression for eq:eq:w0 divergence. We discretize this as:(59)with
.spherical:
:We begin with Eq.43 written in spherical coordinates:
(60)We expand the spatial derivative and recall from Paper I that
(61)giving:
(62)We solve this equation for
as described in Appendix B of the multilevel paper.
Volume Discrepancy Changes
Chapter [ch:volume] describes the reasoning behind the volume discrepancy term—a forcing term added to the constraint equation to bring us back to the equation of state. This addition of this term (enabled with dpdt_factor= T) modifies our equation set in the following way:
In Step 2B, to compute
, we need to account for the volume discrepancy term by first defining , and then using:(63)In Step 3, the MAC projection should account for the volume discrepancy term:
(64)In Step 6B, to compute
, we need to account for the volume discrepancy term by first defining , , and , and then using:(65)In Step 7, the MAC projection should account for the volume discrepancy term:
(66)where
.In Step 11, the approximate projection should account for the volume discrepancy term:
(67)
Variation Changes
The constraint we derive from requiring the pressure to be close to the background hydrostatic pressure takes the form:
The default MAESTROeX algorithm replaces
Assuming that
Grouping by order of the correction, we have
Keeping to First Order in
The base state evolution equation is the average of Eq.71 over a layer
where we see that the
These can be written more compactly as:
for plane-parallel geometries (analogous to Eq.34, and
This constraint is not in a form that can be projected. To solve this
form, we need to use a lagged
This change comes into MAESTROeX in a variety of steps, summarized here. To enable this portion of the algorithm, set use_delta_gamma1_term = T.
In Step 3, we are doing the “predictor” portion of the MAESTROeX algorithm, getting the MAC velocity that satisfies the constraint, so we do not try to incorporate the
effect. We set all the terms in Eq.75 to zero.In Step 6, we are computing the new time-centered source,
and the base state velocity, . Now we can incorporate the effect. First we construct:(76)Then we call average to construct the lateral average of this
(77)Since the average of this is needed in advancing
, we modify to include this average:(78)In Step 7, we now include the
term in the righthand side for the constraint by solving:(79)We note that this includes the average of the correction term as shown in Eq.75 because we modified
to include this already.In Step 10, we do a construction much like that done in Step 6, but with the time-centerings of some of the quantities changed. First we construct:
(80)Then we call average to construct the lateral average of this
(81)Again we modify
to include this average:(82)In Step 11, we modify the source of the constraint to include the
information. In particular, we solve:(83)
Thermal Diffusion Changes
Thermal diffusion was introduced in the XRB [MaloneNonakaAlmgren+11]. This
introduces a new term to
Immediately after Step 4H, diffuse the enthalpy through
a time interval of
We can recast this as an enthalpy-diffusion equation by applying the
chain-rule to
giving
Compute
which is numerically implemented as a diffusion equation for
Immediately after Step 8H, diffuse the enthalpy through a time interval of
which is numerically implemented as a diffusion equation for
Initialization
We start each calculation with user-specified initial values for
First, we need to construct approximations to
Initial Projection: if
do_initial_projection = T
, then we first project the velocity field with and . The initial projection does not see reactions or external heating, and thus we set in . The reason for ignoring reactions and heating is that we need some kind of time scale over which to compute the effect of reactions, but we first need an estimate of the velocity field in order to derive the time step that will be used as a time scale. The elliptic equation we solve is(91)This
is then used to correct the velocity field to obtain . If do_initial_projection = F, set .“Divu” iterations: Next we do
init_divu_iter
iterations to project the velocity field using a constraint that sees reactions and external heating. The initial timestep estimate is provided byfirstdt
and , to allow us to compute the effect of reactions over .Do
.Estimate
using andReact State
Compute
using and the initial data.Compute
Compute
as in Step 2B using and .Project
using and as the source term. This yields In this projection, again the density is set to 1, and the elliptic equation we solve is:(92)
End do.
Define
, , and
Next, we need to construct approximations to
Pressure iterations: Here we do
init_iter
iterations to get an approximation for the lagged pressure:Do
.Perform Steps 1-11 as described above, using
in Step 2 as described. The only other difference in the time advancement is that in Step 11 we define and solve(93)(The motivation for this form of the projection in the initial pressure iterations is discussed in [ABC00].) We discard the new velocity resulting from this, but keep the new value for
These steps also yield new scalar data at time which we discard, and new values for (Step 8C), (Step 8F), (Step 10A), and (Step 11), which we keep.Set
, , and .
End do.
Finally, we define
The tolerances for these elliptic solves are described in § Multigrid.
Changes from Earlier Implementations
Changes Between Paper 3 and Paper 4
We defined the mapping of data between a 1D radial array and the 3D Cartesian grid for spherical problems (which we improve upon in the multilevel paper).
We update
after the call to React State.We have created a burning_cutoff_density, where the burning does not happen below this density. It is presently set to
base_cutoff_density
.Use corner coupling in advection.
We have an option, controlled by use_tfromp, to update temperature using
rather than . The former completely decouples enthalpy from our system. For spherical problems, we useuse_tfromp = TRUE
, for planar problems, we use use_tfromp = FALSE.For spherical problems, we have changed the discretization of
in the enthalpy update to .In paper III we discretized the enthalpy evolution equation in terms of
. Since then we have discovered that discretizing the enthalpy evolution in perturbational form, , leads to better numerical properties. We useenthalpy_pred_type= 1
. This is more like paper II.We have turned off the evolution of
above the atmosphere and instead compute with the EOS usingdo_eos_h_above_cutoff = T
.
Changes Between Paper 4 and the Multilevel Paper
See the multilevel paper for the latest.
Changes Between the Multilevel Paper and Paper 5
Added rotation.
Changes Between Paper 5 and the XRB Paper
We have added thermal diffusion, controlled by
use_thermal_diffusion
,temp_diffusion_formulation
, andthermal_diffusion_type
.We added the volume discrepancy term to the velocity constraint equation, controlled by the input parameter,
dpdt_factor
.For certain problems, we need to set
do_eos_h_above_cutoff = F
to prevent large, unphysical velocities from appearing near the edge of the star.
Changes Since the XRB Paper
We switched to the new form of the momentum equation to Eq.39 to conserve the low-Mach number form of energy.
We changed the form of the volume discrepancy term to get better agreement between the two temperatures.
Future Considerations
We are still exploring the effects of
use_tfromp = F
for spherical problems. We would eventually like to run in this mode, but and drift away from each other more than we would like. Our attempts at incorporating adpdt_factor
for spherical problems have not been successful.
Numerical Methodology
We give an overview of the original MAESTRO algorithm [NonakaAlmgrenBell+10], as well as the recently introduced new temporal integration scheme [FanNonakaAlmgren+19]. These schemes share many of the same algorithmic modules, however the new scheme is significantly simpler.
To summarize, in the original scheme we integrated the base state evolution over the time step, which requires splitting the velocity equation into more complicated average and perturbational equations. In the new temporal integrator, we eliminated much of this complication by introducing a predictor-corrector approach for the base state. The key observation is that the base state density is simply the lateral average of the full density, so we simply update the base state density through averaging routines, rather than predicting the evolution with a split velocity formulation, only to have to correct it with the averaging operator in the end regardless.