smesh/doc/examples/transforming_meshes_ex11.py

90 lines
2.6 KiB
Python
Raw Permalink Normal View History

# Duplicate nodes or/and elements
2013-02-12 20:37:44 +06:00
import salome
salome.salome_init_without_session()
import SMESH
2022-04-11 18:28:01 +05:00
from salome.geom import geomBuilder
from salome.smesh import smeshBuilder
2022-04-11 18:28:01 +05:00
geom_builder = geomBuilder.New()
smesh_builder = smeshBuilder.New()
2013-02-12 20:37:44 +06:00
2013-02-28 21:07:35 +06:00
# Create a box
2022-04-11 18:28:01 +05:00
box = geom_builder.MakeBox(0., 0., 0., 100., 200., 300.)
2013-02-28 21:07:35 +06:00
# Define hexa mesh on a box
2022-04-11 18:28:01 +05:00
mesh = smesh_builder.Mesh(box, "Mesh")
2013-02-28 21:07:35 +06:00
mesh.Segment().NumberOfSegments(7)
mesh.Quadrangle()
mesh.Hexahedron()
2013-02-12 20:37:44 +06:00
# Compute mesh
if not mesh.Compute(): raise Exception("Error when computing Mesh")
2013-02-12 20:37:44 +06:00
# Duplicate nodes only
2013-02-12 20:37:44 +06:00
# Nodes to duplicate
nodes1 = mesh.CreateEmptyGroup( SMESH.NODE, 'nodes1' )
2013-02-28 21:07:35 +06:00
nodes1.Add( [ 119, 125, 131, 137 ] )
2013-02-12 20:37:44 +06:00
# Group of faces to replace nodes with new ones
faces1 = mesh.CreateEmptyGroup( SMESH.FACE, 'faces1' )
2013-02-28 21:07:35 +06:00
faces1.Add( [ 144, 151, 158 ] )
2013-02-12 20:37:44 +06:00
# Duplicate nodes
2017-03-20 17:27:30 +05:00
print("\nMesh before the first nodes duplication:")
print("Nodes : ", mesh.NbNodes())
print("Edges : ", mesh.NbEdges())
print("Quadrangles : ", mesh.NbQuadrangles())
2013-02-12 20:37:44 +06:00
groupOfCreatedNodes = mesh.DoubleNodeGroup(nodes1, faces1, theMakeGroup=True)
2017-03-20 17:27:30 +05:00
print("New nodes:", groupOfCreatedNodes.GetIDs())
2013-02-12 20:37:44 +06:00
2017-03-20 17:27:30 +05:00
print("\nMesh after the first nodes duplication:")
print("Nodes : ", mesh.NbNodes())
print("Edges : ", mesh.NbEdges())
print("Quadrangles : ", mesh.NbQuadrangles())
2013-02-12 20:37:44 +06:00
# Duplicate nodes and border elements
2013-02-12 20:37:44 +06:00
# Edges to duplicate
edges = mesh.CreateEmptyGroup( SMESH.EDGE, 'edges' )
2013-02-28 21:07:35 +06:00
edges.Add( [ 32, 33, 34 ] )
2013-02-12 20:37:44 +06:00
# Nodes not to duplicate
nodes2 = mesh.CreateEmptyGroup( SMESH.NODE, 'nodes2' )
2013-02-28 21:07:35 +06:00
nodes2.Add( [ 35, 38 ] )
2013-02-12 20:37:44 +06:00
# Group of faces to replace nodes with new ones
faces2 = mesh.CreateEmptyGroup( SMESH.FACE, 'faces2' )
2013-02-28 21:07:35 +06:00
faces2.Add( [ 141, 148, 155 ] )
2013-02-12 20:37:44 +06:00
# Duplicate nodes
2017-03-20 17:27:30 +05:00
print("\nMesh before the second nodes duplication:")
print("Nodes : ", mesh.NbNodes())
print("Edges : ", mesh.NbEdges())
print("Quadrangles : ", mesh.NbQuadrangles())
2013-02-12 20:37:44 +06:00
groupOfNewEdges = mesh.DoubleNodeElemGroup( edges, nodes2, faces2, theMakeGroup=True )
2017-03-20 17:27:30 +05:00
print("New edges:", groupOfNewEdges.GetIDs())
2013-02-12 20:37:44 +06:00
2017-03-20 17:27:30 +05:00
print("\nMesh after the second nodes duplication:")
print("Nodes : ", mesh.NbNodes())
print("Edges : ", mesh.NbEdges())
print("Quadrangles : ", mesh.NbQuadrangles())
2013-02-12 20:37:44 +06:00
# Duplicate elements only
# Duplicate all faces and make a group of new faces.
# If a mesh is given to DoubleElements(), all elements of the greatest dimension are duplicated
newFacesGroup = mesh.DoubleElements( mesh, "newFacesGroup" )
# Duplicate edges contained in the group "edges" and add new edges to this group
mesh.DoubleElements( edges, edges.GetName() )
# Duplicate two first edges of the mesh
mesh.DoubleElements([ 1, 2 ])