mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-22 16:10:36 +05:00
48 lines
1.0 KiB
Python
48 lines
1.0 KiB
Python
# Using SALOME NoteBook
|
|
|
|
|
|
import salome
|
|
salome.salome_init()
|
|
import GEOM
|
|
from salome.geom import geomBuilder
|
|
geompy = geomBuilder.New(salome.myStudy)
|
|
|
|
import SMESH, SALOMEDS
|
|
from salome.smesh import smeshBuilder
|
|
smesh = smeshBuilder.New(salome.myStudy)
|
|
import salome_notebook
|
|
|
|
# set variables
|
|
notebook = salome_notebook.notebook
|
|
notebook.set("Length", 100)
|
|
notebook.set("Width", 200)
|
|
notebook.set("Offset", 50)
|
|
|
|
notebook.set("NbSegments", 7)
|
|
notebook.set("MaxElementArea", 800)
|
|
notebook.set("MaxElementVolume", 900)
|
|
|
|
# create a box
|
|
box = geompy.MakeBoxDXDYDZ("Length", "Width", 300)
|
|
idbox = geompy.addToStudy(box, "Box")
|
|
|
|
# create a mesh
|
|
tetra = smesh.Mesh(box, "MeshBox")
|
|
|
|
algo1D = tetra.Segment()
|
|
algo1D.NumberOfSegments("NbSegments")
|
|
|
|
algo2D = tetra.Triangle()
|
|
algo2D.MaxElementArea("MaxElementArea")
|
|
|
|
algo3D = tetra.Tetrahedron()
|
|
algo3D.MaxElementVolume("MaxElementVolume")
|
|
|
|
# compute the mesh
|
|
ret = tetra.Compute()
|
|
|
|
# translate the mesh
|
|
point = SMESH.PointStruct("Offset", 0., 0.)
|
|
vector = SMESH.DirStruct(point)
|
|
tetra.TranslateObject(tetra, vector, 0)
|