Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add functions for computing and plotting transects #144

Merged
merged 14 commits into from
Nov 13, 2023
2 changes: 1 addition & 1 deletion deploy/default.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ geometric_features = 1.2.0
jigsaw = 0.9.14
jigsawpy = 0.3.3
mache = 1.16.0
mpas_tools = 0.25.0
mpas_tools = 0.27.0
otps = 2021.10
parallelio = 2.6.0

Expand Down
19 changes: 19 additions & 0 deletions docs/developers_guide/ocean/api.md
Original file line number Diff line number Diff line change
Expand Up @@ -314,3 +314,22 @@
vertical.zlevel.compute_z_level_resting_thickness
vertical.zstar.init_z_star_vertical_coord
```

### Visualization

```{eval-rst}
.. currentmodule:: polaris.ocean.viz
.. autosummary::
:toctree: generated/
compute_transect
plot_transect
transect.horiz.find_spherical_transect_cells_and_weights
transect.horiz.find_planar_transect_cells_and_weights
transect.horiz.make_triangle_tree
transect.horiz.mesh_to_triangles
transect.vert.find_transect_levels_and_weights
transect.vert.interp_mpas_to_transect_cells
transect.vert.interp_mpas_to_transect_nodes
12 changes: 12 additions & 0 deletions docs/developers_guide/ocean/framework.md
Original file line number Diff line number Diff line change
Expand Up @@ -422,3 +422,15 @@ density, which is horizontally constant and increases with depth.
The {py:func}`polaris.ocean.rpe.compute_rpe()` is used to compute the RPE as
a function of time in a series of one or more output files. The RPE is stored
in `rpe.csv` and also returned as a numpy array for plotting and analysis.

## Visualization
xylar marked this conversation as resolved.
Show resolved Hide resolved

The `polaris.ocean.viz` module provides functions for making plots that are
specific to the ocean component.

The `polaris.ocean.viz.transect` modules includes functions for computing
({py:func}`polaris.ocean.viz.compute_transect()`) and plotting
({py:func}`polaris.ocean.viz.plot_transect()`) transects through the ocean
from a sequence of x-y or latitude-longitude coordinates. Currently, only
transects on xarray data arrays with dimensions `nCells` by `nVertLevels` are
supported.
31 changes: 29 additions & 2 deletions polaris/ocean/tasks/baroclinic_channel/init.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
from polaris import Step
from polaris.mesh.planar import compute_planar_hex_nx_ny
from polaris.ocean.vertical import init_vertical_coord
from polaris.ocean.viz import compute_transect, plot_transect
from polaris.viz import plot_horiz_field


Expand Down Expand Up @@ -162,8 +163,34 @@ def run(self):
write_netcdf(ds, 'initial_state.nc')

cell_mask = ds.maxLevelCell >= 1
plot_horiz_field(ds, ds_mesh, 'temperature',
'initial_temperature.png', cell_mask=cell_mask)

plot_horiz_field(ds, ds_mesh, 'normalVelocity',
'initial_normal_velocity.png', cmap='cmo.balance',
show_patch_edges=True, cell_mask=cell_mask)

y_min = ds_mesh.yVertex.min().values
y_max = ds_mesh.yVertex.max().values
x_mid = ds_mesh.xCell.median().values

y = xr.DataArray(data=np.linspace(y_min, y_max, 2), dims=('nPoints',))
x = x_mid * xr.ones_like(y)

ds_transect = compute_transect(
x=x, y=y, ds_horiz_mesh=ds_mesh,
layer_thickness=ds.layerThickness.isel(Time=0),
bottom_depth=ds.bottomDepth, min_level_cell=ds.minLevelCell - 1,
max_level_cell=ds.maxLevelCell - 1, spherical=False)

field_name = 'temperature'
vmin = ds[field_name].min().values
vmax = ds[field_name].max().values
plot_transect(ds_transect=ds_transect,
mpas_field=ds[field_name].isel(Time=0),
title=f'{field_name} at x={1e-3 * x_mid:.1f} km',
out_filename=f'initial_{field_name}_section.png',
vmin=vmin, vmax=vmax, cmap='cmo.thermal',
colorbar_label=r'$^\circ$C', color_start_and_end=True)

plot_horiz_field(ds, ds_mesh, 'temperature', 'initial_temperature.png',
vmin=vmin, vmax=vmax, cmap='cmo.thermal',
cell_mask=cell_mask, transect_x=x, transect_y=y)
34 changes: 31 additions & 3 deletions polaris/ocean/tasks/baroclinic_channel/viz.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import xarray as xr

from polaris import Step
from polaris.ocean.viz import compute_transect, plot_transect
from polaris.viz import plot_horiz_field


Expand Down Expand Up @@ -42,13 +43,40 @@ def run(self):
ds = xr.load_dataset('output.nc')
t_index = ds.sizes['Time'] - 1
cell_mask = ds_init.maxLevelCell >= 1
plot_horiz_field(ds, ds_mesh, 'temperature',
'final_temperature.png', t_index=t_index,
cell_mask=cell_mask)
max_velocity = np.max(np.abs(ds.normalVelocity.values))
plot_horiz_field(ds, ds_mesh, 'normalVelocity',
'final_normalVelocity.png',
t_index=t_index,
vmin=-max_velocity, vmax=max_velocity,
cmap='cmo.balance', show_patch_edges=True,
cell_mask=cell_mask)

y_min = ds_mesh.yVertex.min().values
y_max = ds_mesh.yVertex.max().values
x_mid = ds_mesh.xCell.median().values

y = xr.DataArray(data=np.linspace(y_min, y_max, 2), dims=('nPoints',))
x = x_mid * xr.ones_like(y)

ds_transect = compute_transect(
x=x, y=y, ds_horiz_mesh=ds_mesh,
layer_thickness=ds.layerThickness.isel(Time=t_index),
bottom_depth=ds_init.bottomDepth,
min_level_cell=ds_init.minLevelCell - 1,
max_level_cell=ds_init.maxLevelCell - 1,
spherical=False)

field_name = 'temperature'
vmin = ds[field_name].min().values
vmax = ds[field_name].max().values
mpas_field = ds[field_name].isel(Time=t_index)
plot_transect(ds_transect=ds_transect, mpas_field=mpas_field,
title=f'{field_name} at x={1e-3 * x_mid:.1f} km',
out_filename=f'final_{field_name}_section.png',
vmin=vmin, vmax=vmax, cmap='cmo.thermal',
colorbar_label=r'$^\circ$C', color_start_and_end=True)

plot_horiz_field(ds, ds_mesh, 'temperature', 'final_temperature.png',
t_index=t_index, vmin=vmin, vmax=vmax,
cmap='cmo.thermal', cell_mask=cell_mask, transect_x=x,
transect_y=y)
2 changes: 2 additions & 0 deletions polaris/ocean/viz/__init__.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
from polaris.ocean.viz.transect.plot import plot_transect
from polaris.ocean.viz.transect.vert import compute_transect
Empty file.
Loading