smesh/doc/salome/gui/SMESH/input/smeshpy_interface.doc

145 lines
3.7 KiB
Plaintext
Raw Normal View History

/*!
2009-02-17 10:27:49 +05:00
\page smeshpy_interface_page Python interface
2009-12-08 18:11:42 +05:00
Python package smesh defines several classes, destined for easy and
2009-02-17 10:27:49 +05:00
clear mesh creation and edition.
2009-12-08 18:11:42 +05:00
Documentation for smesh package is available in two forms:
The <a href="smeshpy_doc/modules.html"> structured
documentation for smesh package</a>, where all methods and
classes are grouped by their functionality, like it is done in the GUI documentation
and the \ref smeshDC "linear documentation for smesh package"
grouped only by classes, declared in the smesh.py file.
The main page of the \ref smeshDC "linear documentation for smesh package"
contains a list of data structures and a list of
functions, provided by the package smesh.py. The first item in
the list of data structures (\ref smeshDC::smeshDC "class smesh")
also represents documentation for the methods of the package smesh.py itself.
The package smesh.py provides an interface to create and handle
meshes. Use it to create an empty mesh or to import it from the data file.
Once a mesh has been created, it is possible to manage it via its own
methods, described at \ref smeshDC::Mesh "class Mesh" documentation
(it is also accessible by the second item "class Mesh" in the list of data structures).
Class \b Mesh allows assigning algorithms to a mesh.
Please note, that some algorithms, included in the standard SALOME
distribution are always available:
- REGULAR (1D)
- COMPOSITE (1D)
- MEFISTO (2D)
- Quadrangle (2D)
- Hexa(3D)
- etc...
There are also some algorithms, which can be installed optionally,
some of them are based on open-source meshers:
- NETGEN (1D-2D, 2D, 1D-2D-3D, 3D)
... and others are based on commercial meshers:
- GHS3D (3D)
- BLSURF (2D)
To add hypotheses, use the interfaces, provided by the assigned
2009-02-17 10:27:49 +05:00
algorithms.
2009-12-08 18:11:42 +05:00
Below you can see an example of usage of the package smesh for 3d mesh generation.
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
\anchor example_3d_mesh
2009-02-17 10:27:49 +05:00
<h2>Example of 3d mesh generation with NETGEN:</h2>
2009-12-08 18:11:42 +05:00
\code
from geompy import *
import smesh
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
###
# Geometry: an assembly of a box, a cylinder and a truncated cone
# meshed with tetrahedral
###
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Define values
name = "ex21_lamp"
cote = 60
section = 20
size = 200
radius_1 = 80
radius_2 = 40
height = 100
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Build a box
box = MakeBox(-cote, -cote, -cote, +cote, +cote, +cote)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Build a cylinder
pt1 = MakeVertex(0, 0, cote/3)
di1 = MakeVectorDXDYDZ(0, 0, 1)
cyl = MakeCylinder(pt1, di1, section, size)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Build a truncated cone
pt2 = MakeVertex(0, 0, size)
cone = MakeCone(pt2, di1, radius_1, radius_2, height)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Fuse
box_cyl = MakeFuse(box, cyl)
piece = MakeFuse(box_cyl, cone)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Add to the study
addToStudy(piece, name)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Create a group of faces
group = CreateGroup(piece, ShapeType["FACE"])
group_name = name + "_grp"
addToStudy(group, group_name)
group.SetName(group_name)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Add faces to the group
faces = SubShapeAllIDs(piece, ShapeType["FACE"])
UnionIDs(group, faces)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
###
# Create a mesh
###
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Define a mesh on a geometry
tetra = smesh.Mesh(piece, name)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Define 1D hypothesis
algo1d = tetra.Segment()
algo1d.LocalLength(10)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Define 2D hypothesis
algo2d = tetra.Triangle()
algo2d.LengthFromEdges()
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Define 3D hypothesis
algo3d = tetra.Tetrahedron(smesh.NETGEN)
algo3d.MaxElementVolume(100)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Compute the mesh
tetra.Compute()
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
# Create a groupe of faces
tetra.Group(group)
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
\endcode
2009-02-17 10:27:49 +05:00
2009-12-08 18:11:42 +05:00
Examples of Python scripts for all Mesh operations are available by
the following links:
2009-12-08 18:11:42 +05:00
- \subpage tui_creating_meshes_page
- \subpage tui_viewing_meshes_page
- \subpage tui_defining_hypotheses_page
- \subpage tui_quality_controls_page
2010-11-25 17:44:43 +05:00
- \subpage tui_filters_page
2009-12-08 18:11:42 +05:00
- \subpage tui_grouping_elements_page
- \subpage tui_modifying_meshes_page
- \subpage tui_transforming_meshes_page
- \subpage tui_notebook_smesh_page
2010-11-25 17:44:43 +05:00
- \subpage tui_measurements_page
2011-06-08 12:50:21 +06:00
- \subpage tui_generate_flat_elements_page
*/