Note
Go to the end to download the full example code.
Stress analysis#
Section author: Florian Zill (Helmholtz Centre for Environmental Research GmbH - UFZ)
The following example from the ogs benchmark collection is used for the stress analysis:
<https://www.opengeosys.org/docs/benchmarks/thermo-mechanics/creepafterexcavation/>
import ogstools as ot
from ogstools import examples
mesh = examples.load_mesh_mechanics_2D()
fig = mesh.plot_contourf(ot.variables.displacement)
data:image/s3,"s3://crabby-images/d0490/d04900a52e21c11d416fd518d5bf67d2b42f1e04" alt="plot solid mechanics"
Tensor components#
We can inspect the stress (or strain) tensor components by indexing.
fig = mesh.plot_contourf(ot.variables.stress["xx"])
fig = mesh.plot_contourf(ot.variables.stress["xy"])
Principal stresses#
Let’s plot the the principal stress components and also overlay the direction of the corresponding eigenvector in the plot. Note: the eigenvalues are sorted by increasing order, i.e. eigenvalue[0] is the most negative / largest compressive principal stress.
eigvecs = ot.variables.stress.eigenvectors
fig = mesh.plot_contourf(variable=ot.variables.stress.eigenvalues[0])
mesh.plot_quiver(ax=fig.axes[0], variable=eigvecs[0], glyph_type="line")
data:image/s3,"s3://crabby-images/a7704/a77044618b38892c9711702e695d466ab93a4b1d" alt="plot solid mechanics"
fig = mesh.plot_contourf(variable=ot.variables.stress.eigenvalues[1])
mesh.plot_quiver(ax=fig.axes[0], variable=eigvecs[1], glyph_type="line")
data:image/s3,"s3://crabby-images/02911/029113e7c727dae2d4e4b1b1162709dc06954864" alt="plot solid mechanics"
fig = mesh.plot_contourf(variable=ot.variables.stress.eigenvalues[2])
mesh.plot_quiver(ax=fig.axes[0], variable=eigvecs[2], glyph_type="line")
data:image/s3,"s3://crabby-images/e0a78/e0a7887b902875cc25d0626fd2ac736f7ede099c" alt="plot solid mechanics"
We can also plot the mean of the principal stress, i.e. the magnitude of the
hydrostatic component of the stress tensor.
see: ogstools.variables.tensor_math.mean()
fig = mesh.plot_contourf(ot.variables.stress.mean)
data:image/s3,"s3://crabby-images/08ebb/08ebb8c30395902c13d4bf205549710d19e62227" alt="plot solid mechanics"
Von Mises stress#
see: ogstools.variables.tensor_math.von_mises()
fig = mesh.plot_contourf(ot.variables.stress.von_Mises)
data:image/s3,"s3://crabby-images/a8ba5/a8ba5b56ec34d542e3890bdf643147d80fd109e6" alt="plot solid mechanics"
octahedral shear stress#
see: ogstools.variables.tensor_math.octahedral_shear()
fig = mesh.plot_contourf(ot.variables.stress.octahedral_shear)
data:image/s3,"s3://crabby-images/031d3/031d357f6ee84aceea0cf9cef1d62042f06cd70a" alt="plot solid mechanics"
Integrity criteria#
Evaluating models regarding their integrity is often dependent on the
geometry, e.g. for a hypothetical water column proportional to the depth.
Presets which fall under this category make use of
ogstools.variables.mesh_dependent
.
The hypothetical water column used in the integrity criteria would initially use existing “pressure” data in the mesh, otherwise it is automatically calculated as the following:
mesh["pressure"] = mesh.p_fluid()
fig = mesh.plot_contourf(ot.variables.pressure)
data:image/s3,"s3://crabby-images/205fb/205fba675a4c0faba3e08a3d18540ae69973de2d" alt="plot solid mechanics"
/builds/ogs/tools/ogstools/.venv-devcontainer/lib/python3.10/site-packages/pyvista/core/dataset.py:2020: UnitStrippedWarning: The unit of the quantity is stripped when downcasting to ndarray.
scalars = np.asanyarray(scalars)
But since this assumes that the top of the model is equal to the ground surface, the resulting pressure is underestimated. In this case we have to correct the depth manually. Then the pressure is calculated correctly:
mesh["depth"] = mesh.depth(use_coords=True)
fig = mesh.plot_contourf("depth")
mesh["pressure"] = mesh.p_fluid()
fig = mesh.plot_contourf(ot.variables.pressure)
/builds/ogs/tools/ogstools/.venv-devcontainer/lib/python3.10/site-packages/pyvista/core/dataset.py:2020: UnitStrippedWarning: The unit of the quantity is stripped when downcasting to ndarray.
scalars = np.asanyarray(scalars)
Dilantancy criterion#
see: ogstools.variables.mesh_dependent.dilatancy_critescu()
fig = mesh.plot_contourf(ot.variables.dilatancy_critescu_tot)
fig = mesh.plot_contourf(ot.variables.dilatancy_critescu_eff)
Fluid pressure criterion#
see: ogstools.variables.mesh_dependent.fluid_pressure_criterion()
fig = mesh.plot_contourf(ot.variables.fluid_pressure_crit)
data:image/s3,"s3://crabby-images/fe67a/fe67ac9ec58d9beb96d9f8f24b5e82226faa96f4" alt="plot solid mechanics"
Total running time of the script: (0 minutes 3.971 seconds)