Note
Go to the end to download the full example code.
1j. Exporting models#
Models can be exported to vtk, gocad and geoh5 formats.
from LoopStructural import GeologicalModel
from LoopStructural.datasets import load_claudius
data, bb = load_claudius()
model = GeologicalModel(bb[0, :], bb[1, :])
model.data = data
model.create_and_add_foliation("strati")
-----------------------------------------------------
strati 1
-----------------------------------------------------
0 regions
0 faults.
Fault enabled True
Export surfaces to vtk#
Isosurfaces can be extracted from a geological feature by calling the .surfaces method on the feature. The argument for this method is the value, values or number of surfaces that are extracted. This returns a list of LoopStructural.datatypes.Surface objects These objects can be interrogated to return the triangles, vertices and normals. Or can be exported into another format using the save method. The supported file formats are vtk, ts and geoh5.
surfaces = model['strati'].surfaces(value=0.0)
print(surfaces)
print(surfaces[0].vtk)
# surfaces[0].save('text.geoh5')
[Surface(vertices=array([[ 548800. , 7816600. , -8891.08479738],
[ 548875.51020408, 7816600. , -8884.92554426],
[ 548800. , 7816710.20408163, -8890.58760166],
...,
[ 552500. , 7821779.59183673, -8828.03220749],
[ 552500. , 7821889.79591837, -8817.74023533],
[ 552500. , 7822000. , -8808.09210777]]), triangles=array([[ 2, 1, 0],
[ 2, 3, 1],
[ 4, 3, 2],
...,
[2682, 2740, 2739],
[2683, 2740, 2682],
[2683, 2741, 2740]], dtype=int32), normals=array([[-0.05608582, -0.00458441, 0.9984154 ],
[-0.05699767, -0.01842402, 0.9982043 ],
[-0.0700128 , -0.00447449, 0.99753606],
...,
[-0.02240791, -0.08773828, 0.9958915 ],
[-0.02971784, -0.08390339, 0.9960306 ],
[-0.04093808, -0.06991643, 0.9967125 ]], dtype=float32), name='strati_0.0', values=array([0., 0., 0., ..., 0., 0., 0.]), properties=None, cell_properties=None)]
<bound method Surface.vtk of Surface(vertices=array([[ 548800. , 7816600. , -8891.08479738],
[ 548875.51020408, 7816600. , -8884.92554426],
[ 548800. , 7816710.20408163, -8890.58760166],
...,
[ 552500. , 7821779.59183673, -8828.03220749],
[ 552500. , 7821889.79591837, -8817.74023533],
[ 552500. , 7822000. , -8808.09210777]]), triangles=array([[ 2, 1, 0],
[ 2, 3, 1],
[ 4, 3, 2],
...,
[2682, 2740, 2739],
[2683, 2740, 2682],
[2683, 2741, 2740]], dtype=int32), normals=array([[-0.05608582, -0.00458441, 0.9984154 ],
[-0.05699767, -0.01842402, 0.9982043 ],
[-0.0700128 , -0.00447449, 0.99753606],
...,
[-0.02240791, -0.08773828, 0.9958915 ],
[-0.02971784, -0.08390339, 0.9960306 ],
[-0.04093808, -0.06991643, 0.9967125 ]], dtype=float32), name='strati_0.0', values=array([0., 0., 0., ..., 0., 0., 0.]), properties=None, cell_properties=None)>
Export the model to geoh5#
The entire model can be exported to a geoh5 file using the save_model method. This will save all the data, foliations, faults and other objects in the model to a geoh5 file. This file can be loaded into LoopStructural
# model.save('model.geoh5')
Total running time of the script: (0 minutes 0.146 seconds)