2013-08-08 21:17:00 +06:00
|
|
|
# Basic Properties
|
|
|
|
|
|
|
|
|
|
|
|
import salome
|
|
|
|
salome.salome_init()
|
|
|
|
import GEOM
|
|
|
|
from salome.geom import geomBuilder
|
2017-06-13 15:01:10 +05:00
|
|
|
geompy = geomBuilder.New()
|
2013-08-08 21:17:00 +06:00
|
|
|
|
|
|
|
import SMESH, SALOMEDS
|
|
|
|
from salome.smesh import smeshBuilder
|
2017-06-13 15:01:10 +05:00
|
|
|
smesh = smeshBuilder.New()
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2013-08-20 20:25:57 +06:00
|
|
|
# create a box
|
|
|
|
box = geompy.MakeBoxDXDYDZ(100,100,100)
|
|
|
|
face = geompy.SubShapeAllSorted(box, geompy.ShapeType['FACE'])[0]
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2013-08-20 20:25:57 +06:00
|
|
|
# mesh a box
|
|
|
|
mesh = smesh.Mesh(box)
|
|
|
|
submesh_1d = mesh.Segment().NumberOfSegments(5)
|
|
|
|
submesh_2d = mesh.Quadrangle()
|
|
|
|
submesh_3d = mesh.Hexahedron()
|
|
|
|
submesh_2d_face = mesh.Triangle(face)
|
|
|
|
mesh.Compute()
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2013-08-20 20:25:57 +06:00
|
|
|
# create a group
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2013-08-20 20:25:57 +06:00
|
|
|
group_2d = mesh.Group(face)
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2013-08-20 20:25:57 +06:00
|
|
|
# compute basic properties
|
2013-08-08 21:17:00 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("Get basic properties: approach 1 (via measurements tool) ----")
|
2013-08-20 20:25:57 +06:00
|
|
|
|
|
|
|
measure = smesh.CreateMeasurements()
|
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for mesh:")
|
|
|
|
print(" length:", measure.Length(mesh.mesh))
|
|
|
|
print(" area:", measure.Area(mesh.mesh))
|
|
|
|
print(" volume:", measure.Volume(mesh.mesh))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for group (2d):")
|
|
|
|
print(" length:", measure.Length(group_2d))
|
|
|
|
print(" area:", measure.Area(group_2d))
|
|
|
|
print(" volume:", measure.Volume(group_2d))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for submesh (2d):")
|
|
|
|
print(" length:", measure.Length(submesh_2d_face.GetSubMesh()))
|
|
|
|
print(" area:", measure.Area(submesh_2d_face.GetSubMesh()))
|
|
|
|
print(" volume:", measure.Volume(submesh_2d_face.GetSubMesh()))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
|
|
|
measure.UnRegister()
|
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("Get basic properties: approach 2 (via smeshBuilder) ----")
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for mesh:")
|
|
|
|
print(" length:", smesh.GetLength(mesh))
|
|
|
|
print(" area:", smesh.GetArea(mesh))
|
|
|
|
print(" volume:", smesh.GetVolume(mesh))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for group (2d):")
|
|
|
|
print(" length:", smesh.GetLength(group_2d))
|
|
|
|
print(" area:", smesh.GetArea(group_2d))
|
|
|
|
print(" volume:", smesh.GetVolume(group_2d))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for submesh (2d):")
|
|
|
|
print(" length:", smesh.GetLength(submesh_2d_face))
|
|
|
|
print(" area:", smesh.GetArea(submesh_2d_face))
|
|
|
|
print(" volume:", smesh.GetVolume(submesh_2d_face))
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("Get basic properties: approach 3 (via smeshBuilder.Mesh) ----")
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for mesh:")
|
|
|
|
print(" length:", mesh.GetLength())
|
|
|
|
print(" area:", mesh.GetArea())
|
|
|
|
print(" volume:", mesh.GetVolume())
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for group (2d): unsupported")
|
2013-08-20 20:25:57 +06:00
|
|
|
|
2017-03-20 17:27:30 +05:00
|
|
|
print("* for submesh (2d): unsupported")
|