Note
Go to the end to download the full example code.
Creating meshes from vtu surface files#
Section author: Tobias Meisel (Helmholtz Centre for Environmental Research GmbH - UFZ)
For this example we create meshes from surface layers.
from ogstools import meshlib as ml
from ogstools.examples import surface_paths
The loaded surfaces are defined within VTU files and adhere to properties such as non-intersecting boundaries with consistent x and y bounds. Alternatively, surfaces can also be created using PyVista with the same properties.
surface1 = ml.Surface(surface_paths[0], material_id=0)
surface2 = ml.Surface(surface_paths[1], material_id=5)
surface3 = ml.Surface(surface_paths[2], material_id=2)
surface4 = ml.Surface(surface_paths[3], material_id=3)
Create 3 layers from previously defined surfaces and add all layers to a layerset (ordererd from top to bottom)
layer1 = ml.Layer(top=surface1, bottom=surface2, num_subdivisions=2)
layer2 = ml.Layer(top=surface2, bottom=surface3, num_subdivisions=1)
layer3 = ml.Layer(top=surface3, bottom=surface4, num_subdivisions=0)
layer_set1 = ml.LayerSet(layers=[layer1, layer2, layer3])
From layerset creation of simplified meshes (sm), prism meshes (pm), voxel meshes (vm), tetraeder mesh (tm) is possible.
sm = ml.to_region_simplified(layer_set1, xy_resolution=200, rank=3).mesh
pm = ml.to_region_prism(layer_set1, resolution=200).mesh
vm = ml.to_region_voxel(layer_set1, resolution=[200, 200, 50]).mesh
tm = ml.to_region_tetraeder(layer_set1, resolution=200).mesh
Simplified mesh#
%%
sm["regions"] = [str(m) for m in sm["MaterialIDs"]]
sm.scale([1, 1, 5]).plot(scalars="regions", show_edges=True)
data:image/s3,"s3://crabby-images/ba465/ba4651b651646658d0a3903b21b57b962d5995d2" alt="plot meshlib vtu input"
Voxel mesh#
%%
vm["regions"] = [str(m) for m in vm["MaterialIDs"]]
vm.scale([1, 1, 5]).plot(scalars="regions", show_edges=True)
data:image/s3,"s3://crabby-images/b229c/b229ca8204834890c9084bc1996d7a269010dc1c" alt="plot meshlib vtu input"
Prism mesh#
%%
pm["regions"] = [str(m) for m in pm["MaterialIDs"]]
pm.scale([1, 1, 5]).plot(scalars="regions", show_edges=True)
data:image/s3,"s3://crabby-images/631d0/631d0dc3c298aba47aaa82cad6743e203d153607" alt="plot meshlib vtu input"
Tetraeder mesh#
%%
tm["regions"] = [str(m) for m in tm["MaterialIDs"]]
tm.scale([1, 1, 5]).plot(scalars="regions", show_edges=True)
data:image/s3,"s3://crabby-images/b589f/b589f0dcbfbc4744529f03655af4e708042c4e97" alt="plot meshlib vtu input"
Total running time of the script: (0 minutes 3.086 seconds)