From 5a1d3f28c3c0bb70bec800585255f0a82d75f7d4 Mon Sep 17 00:00:00 2001 From: shimwell Date: Thu, 29 Feb 2024 22:51:50 +0000 Subject: [PATCH] allowing 3d gmsh export --- src/cad_to_dagmc/core.py | 14 ++++++++++---- tests/test_file_creation.py | 6 ++++++ 2 files changed, 16 insertions(+), 4 deletions(-) diff --git a/src/cad_to_dagmc/core.py b/src/cad_to_dagmc/core.py index f2a6b7c..1f8c26e 100644 --- a/src/cad_to_dagmc/core.py +++ b/src/cad_to_dagmc/core.py @@ -188,6 +188,7 @@ def _mesh_brep( min_mesh_size: float = 1, max_mesh_size: float = 10, mesh_algorithm: int = 1, + dimensions: int = 2 ): """Creates a conformal surface meshes of the volumes in a Brep file using Gmsh. @@ -200,6 +201,8 @@ def _mesh_brep( into gmsh.option.setNumber("Mesh.MeshSizeMax", max_mesh_size) mesh_algorithm: The Gmsh mesh algorithm number to use. Passed into gmsh.option.setNumber("Mesh.Algorithm", mesh_algorithm) + dimensions: The number of dimensions, 2 for a surface mesh 3 for a + volume mesh. Passed to gmsh.model.mesh.generate() Returns: The resulting gmsh object and volumes @@ -214,7 +217,7 @@ def _mesh_brep( gmsh.option.setNumber("Mesh.Algorithm", mesh_algorithm) gmsh.option.setNumber("Mesh.MeshSizeMin", min_mesh_size) gmsh.option.setNumber("Mesh.MeshSizeMax", max_mesh_size) - gmsh.model.mesh.generate(2) + gmsh.model.mesh.generate(dimensions) return gmsh, volumes @@ -369,14 +372,18 @@ def export_gmsh_mesh_file( min_mesh_size: float = 1, max_mesh_size: float = 5, mesh_algorithm: int = 1, + dimensions: int = 2, ): - """Saves a GMesh msh file of the geometry + """Saves a GMesh msh file of the geometry in either 2D surface mesh or + 3D volume mesh. Args: filename min_mesh_size: the minimum size of mesh elements to use. max_mesh_size: the maximum size of mesh elements to use. mesh_algorithm: the gmsh mesh algorithm to use. + dimensions: The number of dimensions, 2 for a surface mesh 3 for a + volume mesh. Passed to gmsh.model.mesh.generate() """ assembly = cq.Assembly() @@ -390,10 +397,9 @@ def export_gmsh_mesh_file( min_mesh_size=min_mesh_size, max_mesh_size=max_mesh_size, mesh_algorithm=mesh_algorithm, + dimensions=dimensions ) - _mesh_to_h5m_in_memory_method(volumes=volumes) - gmsh.write(filename) gmsh.finalize() diff --git a/tests/test_file_creation.py b/tests/test_file_creation.py index e76f61b..5f678e8 100644 --- a/tests/test_file_creation.py +++ b/tests/test_file_creation.py @@ -54,6 +54,8 @@ def test_h5m_with_single_volume_list(): my_model.export_dagmc_h5m_file(filename=h5m_file) my_model.export_gmsh_mesh_file(filename="test.msh") assert Path("test.msh").is_file() + my_model.export_gmsh_mesh_file(filename="test3d.msh", dimensions=3) + assert Path("test3d.msh").is_file() assert get_volumes_and_materials_from_h5m(h5m_file) == {1: "mat:mat1"} @@ -165,6 +167,10 @@ def test_gmsh_mesh_with_single_volume_list(): my_model.export_gmsh_mesh_file(filename=gmsh_mesh_file) my_model.export_gmsh_mesh_file(filename="test2.msh") assert Path("test2.msh").is_file() + assert Path("tests/single_cube.msh").is_file() + my_model.export_gmsh_mesh_file(filename="test2_3d.msh", dimensions=3) + assert Path("test2_3d.msh").is_file() + def test_gmsh_mesh_with_single_volume_2():