mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-15 07:00:34 +05:00
Docs for Mantis issue 0020834: EDF 1362 SMESH : Add a 2D quadrangle mesher of reduced type.
This commit is contained in:
parent
5abf3879fd
commit
afac1ba0e1
BIN
doc/salome/gui/SMESH/images/hypo_quad_params_dialog.png
Normal file
BIN
doc/salome/gui/SMESH/images/hypo_quad_params_dialog.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 21 KiB |
@ -43,27 +43,58 @@ length calculated as an average edge length for a given wire.
|
|||||||
\anchor hypo_quad_params_anchor
|
\anchor hypo_quad_params_anchor
|
||||||
<h2>Quadrangle parameters</h2>
|
<h2>Quadrangle parameters</h2>
|
||||||
|
|
||||||
<b>Quadrangle parameters</b> is a hypothesis for
|
\image html hypo_quad_params_dialog.png "Quadrangle parameters creation/edition dialog"
|
||||||
Quadrangle (Mapping), which allows using this algorithm for meshing of
|
|
||||||
triangular faces.In this case it is necessary to select the <b>Base vertex</b>
|
<b>Quadrangle parameters</b> is a hypothesis for Quadrangle (Mapping).
|
||||||
used as a degenerated edge.
|
|
||||||
|
<b>Base vertex</b> parameter allows using Quadrangle (Mapping)
|
||||||
|
algorithm for meshing of triangular faces. In this case it is
|
||||||
|
necessary to select a vertex, which will be used as the fourth edge
|
||||||
|
(degenerated).
|
||||||
|
|
||||||
\image html hypo_quad_params_1.png "A face built from 3 edges"
|
\image html hypo_quad_params_1.png "A face built from 3 edges"
|
||||||
|
|
||||||
\image html hypo_quad_params_res.png "The resulting mesh"
|
\image html hypo_quad_params_res.png "The resulting mesh"
|
||||||
|
|
||||||
This hypothesis can be also used to mesh a segment of a circular face.
|
This parameter can be also used to mesh a segment of a circular face.
|
||||||
Please, consider that there is a limitation on the selectiion of the degenerated
|
Please, consider that there is a limitation on the selection of the
|
||||||
vertex for the faces built with the angle > 180 degrees (see the picture).
|
vertex for the faces built with the angle > 180 degrees (see the picture).
|
||||||
|
|
||||||
\image html hypo_quad_params_2.png "3/4 of a circular face"
|
\image html hypo_quad_params_2.png "3/4 of a circular face"
|
||||||
|
|
||||||
In this case, selection of a wrong vertex for the <b>Quadrangle parameters</b>
|
In this case, selection of a wrong vertex for the <b>Base vertex</b>
|
||||||
hypothesis will generate a wrong mesh. The picture below
|
parameter will generate a wrong mesh. The picture below
|
||||||
shows the good (left) and the bad (right) results of meshing.
|
shows the good (left) and the bad (right) results of meshing.
|
||||||
|
|
||||||
\image html hypo_quad_params_res_2.png "The resulting meshes"
|
\image html hypo_quad_params_res_2.png "The resulting meshes"
|
||||||
|
|
||||||
|
<b>Type</b> parameter has sense on faces with different number of
|
||||||
|
segments on opposite sides. The following types are available:
|
||||||
|
|
||||||
|
<ul>
|
||||||
|
<li><b>Standard</b> means the default case, triangles and quadrangles
|
||||||
|
are possible along the longest sides (in the refinement area).</li>
|
||||||
|
<li><b>Triangle preference</b> forces building only triangles in the
|
||||||
|
refinement area for transition to higher number of segments.
|
||||||
|
<i>This type corresponds to <b>Triangle Preference</b> additional
|
||||||
|
hypothesis, which is obsolete now.</i></li>
|
||||||
|
<li><b>Quadrangle preference</b> forces building only quadrangles for
|
||||||
|
transition to higher number of segments. This hypothesis has one
|
||||||
|
restriction on its work: the total quantity of segments on all
|
||||||
|
four sides of the face must be even (divisible by 2).</li>
|
||||||
|
<i>This type corresponds to <b>Quadrangle Preference</b>
|
||||||
|
additional hypothesis, which is obsolete now.</i></li>
|
||||||
|
<li><b>Quadrangle preference (reversed)</b> works like
|
||||||
|
<b>Quadrangle preference</b> (and with same restriction), but
|
||||||
|
transition is made near the sides with smaller number of
|
||||||
|
segments.</li>
|
||||||
|
<li><b>Reduced</b> type forces building only quadrangles, transition
|
||||||
|
to other number of segments is made layer by layer. This type has
|
||||||
|
a limitation on number of segments: two opposite edges must have
|
||||||
|
the same number of segments, two another must have even difference
|
||||||
|
between their numbers of segments.</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
<b>See Also</b> a sample TUI Script of a
|
<b>See Also</b> a sample TUI Script of a
|
||||||
\ref tui_quadrangle_parameters "Quadrangle Parameters" hypothesis.
|
\ref tui_quadrangle_parameters "Quadrangle Parameters" hypothesis.
|
||||||
|
|
||||||
|
@ -41,17 +41,20 @@ It allows Netgen 2D to build quadrangular meshes at any conditions.
|
|||||||
|
|
||||||
It allows Quadrangle (Mapping) to build quadrangular meshes even if the number
|
It allows Quadrangle (Mapping) to build quadrangular meshes even if the number
|
||||||
of nodes at the opposite edges of a meshed face is not equal,
|
of nodes at the opposite edges of a meshed face is not equal,
|
||||||
otherwise this mesh will contain some triangular elements.
|
otherwise this mesh will contain some triangular elements. <i>This use
|
||||||
|
case is obsolete now. Use <b>Quadrangle Parameters</b> hypothesis with
|
||||||
|
type <b>Quadrangle Preference</b> set instead.</i>
|
||||||
<br>
|
<br>
|
||||||
This hypothesis has one restriction on its work: the total quantity of
|
This hypothesis has one restriction on its work: the total quantity of
|
||||||
segments on all four sides of the face must be even (divisible by 2).
|
segments on all four sides of the face must be even (divisible by 2).
|
||||||
|
|
||||||
<h2>Triangle Preference</h2>
|
<h2>Triangle Preference <i>(obsolete)</i></h2>
|
||||||
|
|
||||||
This additional hypothesis can be used only together with Quadrangle (Mapping)
|
This additional hypothesis can be used only together with Quadrangle (Mapping)
|
||||||
algorithm. It allows to build triangular mesh faces in the refinement
|
algorithm. It allows to build triangular mesh faces in the refinement
|
||||||
area if the number of nodes at the opposite edges of a meshed face is not equal,
|
area if the number of nodes at the opposite edges of a meshed face is not equal,
|
||||||
otherwise refinement area will contain some quadrangular elements.
|
otherwise refinement area will contain some quadrangular elements.
|
||||||
|
<i>This hypothesis is obsolete now. Use <b>Quadrangle Parameters</b>
|
||||||
|
hypothesis with type <b>Triangle Preference</b> set instead.</i>
|
||||||
|
|
||||||
*/
|
*/
|
||||||
|
@ -549,7 +549,7 @@ mesh.Compute()
|
|||||||
\endcode
|
\endcode
|
||||||
|
|
||||||
\anchor tui_quadrangle_parameters
|
\anchor tui_quadrangle_parameters
|
||||||
<h2>Quadrangle Parameters example </h2>
|
<h2>Quadrangle Parameters example 1 (meshing a face with 3 edges) </h2>
|
||||||
\code
|
\code
|
||||||
import geompy
|
import geompy
|
||||||
import smesh
|
import smesh
|
||||||
@ -570,7 +570,7 @@ Mesh_1 = smesh.Mesh(Common_1)
|
|||||||
Quadrangle_Parameters_1 = smesh.CreateHypothesis('QuadrangleParams')
|
Quadrangle_Parameters_1 = smesh.CreateHypothesis('QuadrangleParams')
|
||||||
Quadrangle_Parameters_1.SetTriaVertex( 8 )
|
Quadrangle_Parameters_1.SetTriaVertex( 8 )
|
||||||
|
|
||||||
# Define 1D hypothesis and cmpute the mesh
|
# Define 1D hypothesis and compute the mesh
|
||||||
Regular_1D = Mesh_1.Segment()
|
Regular_1D = Mesh_1.Segment()
|
||||||
Nb_Segments_1 = Regular_1D.NumberOfSegments(10)
|
Nb_Segments_1 = Regular_1D.NumberOfSegments(10)
|
||||||
Nb_Segments_1.SetDistrType( 0 )
|
Nb_Segments_1.SetDistrType( 0 )
|
||||||
@ -579,6 +579,56 @@ Quadrangle_2D = Mesh_1.Quadrangle()
|
|||||||
Mesh_1.Compute()
|
Mesh_1.Compute()
|
||||||
\endcode
|
\endcode
|
||||||
|
|
||||||
|
<h2>Quadrangle Parameters example 2 (using different types) </h2>
|
||||||
|
\code
|
||||||
|
import geompy
|
||||||
|
import smesh
|
||||||
|
import StdMeshers
|
||||||
|
|
||||||
|
# Make quadrangle face and explode it on edges.
|
||||||
|
Vertex_1 = geompy.MakeVertex(0, 0, 0)
|
||||||
|
Vertex_2 = geompy.MakeVertex(40, 0, 0)
|
||||||
|
Vertex_3 = geompy.MakeVertex(40, 30, 0)
|
||||||
|
Vertex_4 = geompy.MakeVertex(0, 30, 0)
|
||||||
|
Quadrangle_Face_1 = geompy.MakeQuad4Vertices(Vertex_1, Vertex_4, Vertex_3, Vertex_2)
|
||||||
|
[Edge_1,Edge_2,Edge_3,Edge_4] = geompy.SubShapeAllSorted(Quadrangle_Face_1, geompy.ShapeType["EDGE"])
|
||||||
|
geompy.addToStudy( Vertex_1, "Vertex_1" )
|
||||||
|
geompy.addToStudy( Vertex_2, "Vertex_2" )
|
||||||
|
geompy.addToStudy( Vertex_3, "Vertex_3" )
|
||||||
|
geompy.addToStudy( Vertex_4, "Vertex_4" )
|
||||||
|
geompy.addToStudy( Quadrangle_Face_1, "Quadrangle Face_1" )
|
||||||
|
geompy.addToStudyInFather( Quadrangle_Face_1, Edge_2, "Edge_2" )
|
||||||
|
|
||||||
|
# Set the Geometry for meshing
|
||||||
|
Mesh_1 = smesh.Mesh(Quadrangle_Face_1)
|
||||||
|
|
||||||
|
# Create Quadrangle parameters and
|
||||||
|
# define the Type as Quadrangle Preference
|
||||||
|
Quadrangle_Parameters_1 = smesh.CreateHypothesis('QuadrangleParams')
|
||||||
|
Quadrangle_Parameters_1.SetQuadType( StdMeshers.QUAD_QUADRANGLE_PREF )
|
||||||
|
|
||||||
|
# Define other hypotheses and algorithms
|
||||||
|
Regular_1D = Mesh_1.Segment()
|
||||||
|
Nb_Segments_1 = Regular_1D.NumberOfSegments(4)
|
||||||
|
Nb_Segments_1.SetDistrType( 0 )
|
||||||
|
status = Mesh_1.AddHypothesis(Quadrangle_Parameters_1)
|
||||||
|
Quadrangle_2D = Mesh_1.Quadrangle()
|
||||||
|
|
||||||
|
# Define submesh on one edge to provide different number of segments
|
||||||
|
Regular_1D_1 = Mesh_1.Segment(geom=Edge_2)
|
||||||
|
Nb_Segments_2 = Regular_1D_1.NumberOfSegments(10)
|
||||||
|
Nb_Segments_2.SetDistrType( 0 )
|
||||||
|
SubMesh_1 = Regular_1D_1.GetSubMesh()
|
||||||
|
|
||||||
|
# Compute mesh (with Quadrangle Preference type)
|
||||||
|
isDone = Mesh_1.Compute()
|
||||||
|
|
||||||
|
# Change type to Reduced and compute again
|
||||||
|
Quadrangle_Parameters_1.SetQuadType( StdMeshers.QUAD_REDUCED )
|
||||||
|
isDone = Mesh_1.Compute()
|
||||||
|
\endcode
|
||||||
|
|
||||||
|
|
||||||
\n Other meshing algorithms:
|
\n Other meshing algorithms:
|
||||||
|
|
||||||
<ul>
|
<ul>
|
||||||
|
Loading…
Reference in New Issue
Block a user