Skip to content

Commit

Permalink
Use land-ice pressure to determine ice draft
Browse files Browse the repository at this point in the history
This was previously only the case for thin-film cases.

To accommodate this, we make the minimum ocean column thickness
10 m for non-thin-film cases.  To make the different values for
thin-film and non-thin-film cases more obvious, we use separate
config options for the two.
  • Loading branch information
xylar committed Sep 24, 2024
1 parent f3206eb commit 2a6c103
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 28 deletions.
43 changes: 21 additions & 22 deletions polaris/ocean/tasks/isomip_plus/init/init.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@
from polaris.ocean.ice_shelf import (
compute_freezing_temperature,
compute_land_ice_draft_from_pressure,
compute_land_ice_pressure_from_draft,
)
from polaris.ocean.vertical import init_vertical_coord
from polaris.ocean.viz import compute_transect, plot_transect
Expand Down Expand Up @@ -98,7 +97,12 @@ def _compute_init_topo(self):
section = config['isomip_plus_init']
min_levels = section.getint('minimum_levels')
min_layer_thickness = section.getfloat('min_layer_thickness')
min_column_thickness = section.getfloat('min_column_thickness')
if thin_film:
min_column_thickness = (
section.getfloat('min_column_thickness_thin_film'))
else:
min_column_thickness = (
section.getfloat('min_column_thickness_no_thin_film'))
min_land_ice_fraction = section.getfloat('min_land_ice_fraction')

ds_topo = xr.open_dataset('topo.nc')
Expand Down Expand Up @@ -130,28 +134,17 @@ def _compute_init_topo(self):

ds_init['landIceGroundedFraction'] = ds_topo['landIceGroundedFraction']

if thin_film:
# start from landIcePressure and compute landIceDraft
ds_init['landIcePressure'] = ds_topo['landIcePressure']

land_ice_draft = compute_land_ice_draft_from_pressure(
land_ice_pressure=ds_topo.landIcePressure,
modify_mask=ds_topo.landIcePressure > 0.)

land_ice_draft = np.maximum(ds_topo.bedrockTopography,
land_ice_draft)
# start from landIcePressure and compute landIceDraft
ds_init['landIcePressure'] = ds_topo['landIcePressure']

ds_init['landIceDraft'] = land_ice_draft
land_ice_draft = compute_land_ice_draft_from_pressure(
land_ice_pressure=ds_topo.landIcePressure,
modify_mask=ds_topo.landIcePressure > 0.)

else:
# start form landIceDraft and compute landIcePressure
ds_init['landIceDraft'] = ds_topo['landIceDraft']

land_ice_pressure = compute_land_ice_pressure_from_draft(
land_ice_draft=ds_topo.landIceDraft,
modify_mask=ds_topo.landIceDraft < 0.)
land_ice_draft = np.maximum(ds_topo.bedrockTopography,
land_ice_draft)

ds_init['landIcePressure'] = land_ice_pressure
ds_init['landIceDraft'] = land_ice_draft

ds_init['ssh'] = ds_init.landIceDraft

Expand Down Expand Up @@ -274,7 +267,13 @@ def _plot(self):
Plot several fields from the initial condition
"""
section = self.config['isomip_plus_init']
min_column_thickness = section.getfloat('min_column_thickness')
thin_film = self.thin_film
if thin_film:
min_column_thickness = (
section.getfloat('min_column_thickness_thin_film'))
else:
min_column_thickness = (
section.getfloat('min_column_thickness_no_thin_film'))
min_layer_thickness = section.getfloat('min_layer_thickness')

tol = 1e-10
Expand Down
6 changes: 4 additions & 2 deletions polaris/ocean/tasks/isomip_plus/isomip_plus_init.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,10 @@ minimum_levels = 3
# The minimum allowable layer thickness
min_layer_thickness = 0.0

# Minimum thickness of the initial ocean column (to prevent 'drying')
min_column_thickness = 1e-3
# Minimum thickness of the initial ocean column (to prevent 'drying') without
# and with a thin film region
min_column_thickness_no_thin_film = 10.0
min_column_thickness_thin_film = 1e-3

# Minimum fraction of a cell that contains land ice in order for it to be
# considered a land-ice cell by MPAS-Ocean (landIceMask == 1).
Expand Down
4 changes: 0 additions & 4 deletions polaris/ocean/tasks/isomip_plus/isomip_plus_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -112,12 +112,8 @@ def configure(self):
config.add_from_package('polaris.ocean.tasks.isomip_plus',
'isomip_plus_init.cfg')
vertical_coordinate = self.vertical_coordinate
thin_film = self.thin_film
experiment = self.experiment

if thin_film:
config.set('isomip_plus', 'min_column_thickness', '1e-3')

# for most coordinates, use the config options, which is 36 layers
levels = None
if vertical_coordinate == 'single-layer':
Expand Down

0 comments on commit 2a6c103

Please sign in to comment.