Visualizing 2D model data#

Section author: Florian Zill (Helmholtz Centre for Environmental Research GmbH - UFZ)

For this example we load a 2D meshseries dataset from within the meshplotlib examples. In the meshplotlib.setup we can provide a dictionary to map names to material ids. First, let’s plot the material ids (cell_data). Per default in the setup, this will automatically show the element edges.

import ogstools.meshplotlib as mpl
from ogstools.meshplotlib.examples import meshseries_THM_2D
from ogstools.propertylib import presets

mpl.setup.reset()
mpl.setup.length.output_unit = "km"
mpl.setup.material_names = {i + 1: f"Layer {i+1}" for i in range(26)}
mesh = meshseries_THM_2D.read(1)
fig = mpl.plot(mesh, presets.material_id)
plot meshplotlib 2d

Now, let’s plot the temperature field (point_data) at the first timestep. The default temperature property from the propertylib reads the temperature data as Kelvin and converts them to degrees Celsius.

fig = mpl.plot(mesh, presets.temperature)
plot meshplotlib 2d

This example has hydraulically deactivated subdomains:

fig = mpl.plot(mesh, presets.pressure.get_mask())
plot meshplotlib 2d

Let’s plot the fluid velocity field.

fig = mpl.plot(mesh, presets.velocity)
plot meshplotlib 2d

It is also possible to plot a shape on top, e.g. to display an overburden.

mpl.plot_on_top(fig.axes[0], mesh, lambda x: min(max(0, 0.1 * (x - 3)), 100))
fig  # noqa: B018
<Figure size 3531.52x1080 with 2 Axes>

We can also plot components of vector property:

fig = mpl.plot(mesh, presets.displacement[0])
plot meshplotlib 2d
fig = mpl.plot(mesh, presets.displacement[1])
plot meshplotlib 2d

Total running time of the script: (0 minutes 4.199 seconds)