greenland
The greenland
test group (compass.landice.tests.greenland.Greenland
)
performs short (5-day) forward runs on a coarse (20-km) Greenland mesh, and creates
a variable resolution mesh based on user inputs (see greenland).
Here, we describe the shared framework for this test group and the 4 test cases.
framework
There are no shared config options for the greenland
test group.
Each of the tests and the RunModel
step require an argument for
velo_solver
that can be one of ['sia', 'FO']
. When a test is set
up to use the ‘FO’ solver, COMPASS will adjust the namelist accordingly
and add a copy of the albany_input.yaml
input file required by the FO
solver. Running with the FO solver requires building MALI with the Albany
library.
The test group has a shared namelist.landice
file with
a few common namelist options related to time step, run duration and calving,
and a shared streams.landice
file that defines input
, restart
, and
output
streams.
run_model
The class compass.landice.tests.greenland.run_model.RunModel
defines a step for running MALI an initial condition downloaded from
gis20km.210608.nc.
For the restart_test
test cases, the model will run multiple times with
different namelist and streams files. To support this functionality, this step
has an attribute suffixes
, which is a list of suffixes for the these
namelist and streams files. The model runs once for each suffix. The default
is just landice
.
mesh
The class compass.landice.tests.greenland.mesh.Mesh
defines a step for creating a variable resolution Greenland Ice Sheet mesh.
This is used by the mesh_gen
test case.
smoke_test
The compass.landice.tests.greenland.smoke_test.SmokeTest
performs a
5-day run on 4 cores. It doesn’t contain any Validation.
decomposition_test
The compass.landice.tests.greenland.decomposition_test.DecompositionTest
performs a 5-day run once on 1 core and once on 4 cores. It ensures that
thickness
and normalVelocity
are identical at the end of the two runs
(as well as with a baseline if one is provided when calling
compass setup).
restart_test
The compass.landice.tests.greenland.restart_test.RestartTest
performs a 5-day run once on 4 cores, then a sequence of a 3-day and a 2-day
run on 4 cores. It ensures that thickness
and normalVelocity
are
identical at the end of the two runs (as well as with a baseline if one is
provided when calling compass setup).
The restart step works by creating two different namelist and streams files,
one each with landice
as the suffix and one each with landice.rst
as
the suffix. The former perform a 3-day run from the initial condition, while
the latter perform a 2-day restart run beginning with the end of the first.
mesh_gen
The compass.landice.tests.greenland.mesh_gen.MeshGen
calls the compass.landice.tests.greenland.mesh.Mesh
to create
the variable resolution Greenland Ice Sheet mesh.
The mesh generation is based around 1- and 2-km reference datasets, which are updated in a number of ways directly from high resolution source data. In the future, a complete workflow from source datasets may replace this hybrid method.
Once the mesh is created, scrip files and the associated weights files are created for the mesh and observational data sets. Then, ice geometry and velocity observations are conservatively remapped from BedMachine v5 and MEaSUREs 2006-2010 data sets. Finally, there is some cleanup to set large velocity uncertainties outside the ice mask, check the sign of the basal heat flux, and set reasonable values for dH/dt and its uncertainty.