Note
Go to the end to download the full example code.
Aspect ratios#
Section author: Florian Zill (Helmholtz Centre for Environmental Research GmbH - UFZ)
By default, filled contour plots try to retain the true mesh proportions. If the meshes aspect ratio lies outside of predefined limits (setup.min_ax_aspect, setup.max_ax_aspect) the axes get compressed to stay inside the given limits. The following examples shall illustrate this behaviour.
import numpy as np
import pyvista as pv
import ogstools as ot
print(f"{ot.plot.setup.min_ax_aspect=}")
print(f"{ot.plot.setup.max_ax_aspect=}")
ot.plot.setup.min_ax_aspect=0.5
ot.plot.setup.max_ax_aspect=2.0
The following fits inside the defined limits and gets displayed with true proportions.
fig = ot.plot.contourf(custom_mesh(np.pi * 2, np.pi), "example")
data:image/s3,"s3://crabby-images/e11cd/e11cd5c133d8b4c632561c037f37523a686a58ac" alt="plot aspect ratios"
This one would be too wide and thus and gets compressed to fit the maximum aspect ratio.
fig = ot.plot.contourf(custom_mesh(np.pi * 4, np.pi), "example")
data:image/s3,"s3://crabby-images/3132f/3132f1477d87df17c83372c273debc92aa94838c" alt="plot aspect ratios"
When plotting multiple meshes together, this applies to each subplot. So here each subplot has true proportions again since each one fits the limits.
fig = ot.plot.contourf(
[custom_mesh(np.pi * 2, np.pi), custom_mesh(np.pi * 2, np.pi)], "example"
)
data:image/s3,"s3://crabby-images/bb8ca/bb8ca87d95a2d4d0795385e3c7dc0bd66792b4b4" alt="plot aspect ratios"
The following figure would be to tall and is clipped to the minimum aspect ratio.
fig = ot.plot.contourf(custom_mesh(np.pi, np.pi * 3), "example")
data:image/s3,"s3://crabby-images/ac06e/ac06e3cf0f80be78d3871aede2fcd492f04d1560" alt="plot aspect ratios"
The same is true here:
fig = ot.plot.contourf(
[custom_mesh(np.pi, np.pi * 3), custom_mesh(np.pi, np.pi * 3)], "example"
)
data:image/s3,"s3://crabby-images/658f7/658f7195201add31f6d47e23a9c315e72b9a276e" alt="plot aspect ratios"
You can enforce true proportions regardless of the resulting figures dimensions, by setting the limiting values to None. In this case we get a very wide figure.
ot.plot.setup.min_ax_aspect = None
ot.plot.setup.max_ax_aspect = None
fig = ot.plot.contourf(custom_mesh(np.pi * 3, np.pi), "example")
data:image/s3,"s3://crabby-images/a8089/a8089bfb17f4259589970170bd4ffbbddd02c890" alt="plot aspect ratios"
And in this case we get a very tall figure.
fig = ot.plot.contourf(custom_mesh(np.pi, np.pi * 3), "example")
data:image/s3,"s3://crabby-images/fbb66/fbb66f10906e9639f8df60a40aeabb46bc3a23ec" alt="plot aspect ratios"
Total running time of the script: (0 minutes 2.078 seconds)