Salome HOME
bos #29171 Refactor testing procedure
[modules/smesh.git] / doc / examples / defining_hypotheses_ex15.py
1 # Quadrangle Parameters example 2 (using different types)
2
3 import salome
4 salome.salome_init_without_session()
5
6 from salome.geom import geomBuilder
7 from salome.smesh import smeshBuilder
8
9 geom_builder = geomBuilder.New()
10 smesh_builder = smeshBuilder.New()
11
12 # Make quadrangle face and explode it on edges.
13 Vertex_1 = geom_builder.MakeVertex(0, 0, 0)
14 Vertex_2 = geom_builder.MakeVertex(40, 0, 0)
15 Vertex_3 = geom_builder.MakeVertex(40, 30, 0)
16 Vertex_4 = geom_builder.MakeVertex(0, 30, 0)
17 Quadrangle_Face_1 = geom_builder.MakeQuad4Vertices(Vertex_1, Vertex_4, Vertex_3, Vertex_2)
18 [Edge_1,Edge_2,Edge_3,Edge_4] = geom_builder.SubShapeAllSorted(Quadrangle_Face_1, geom_builder.ShapeType["EDGE"])
19 geom_builder.addToStudy( Quadrangle_Face_1, "Quadrangle Face_1" )
20 geom_builder.addToStudyInFather( Quadrangle_Face_1, Edge_2, "Edge_2" )
21
22 # Set the Geometry for meshing
23 Mesh_1 = smesh_builder.Mesh(Quadrangle_Face_1)
24
25 # Create Quadrangle parameters and
26 # define the Type as Quadrangle Preference
27 Quad_algo = Mesh_1.Quadrangle()
28 Quadrangle_Parameters_1 = Quad_algo.QuadrangleParameters( smeshBuilder.QUAD_QUADRANGLE_PREF )
29
30 # Define other hypotheses and algorithms
31 Regular_1D = Mesh_1.Segment()
32 Nb_Segments_1 = Regular_1D.NumberOfSegments(4)
33
34 # Define submesh on one edge to provide different number of segments
35 Regular_1D_1 = Mesh_1.Segment(geom=Edge_2)
36 Nb_Segments_2 = Regular_1D_1.NumberOfSegments(10)
37
38 # Compute mesh (with Quadrangle Preference type)
39 isDone = Mesh_1.Compute()
40
41 # Change type to Reduced and compute again
42 Quadrangle_Parameters_1.SetQuadType( smeshBuilder.QUAD_REDUCED )
43 isDone = Mesh_1.Compute()