Salome HOME
bos #29171 Refactor testing procedure
[modules/smesh.git] / doc / examples / defining_hypotheses_ex16.py
1 # "Import 2D Elements from Another Mesh" example
2
3 import salome
4 salome.salome_init_without_session()
5
6 import SMESH
7 from salome.geom import geomBuilder
8 from salome.smesh import smeshBuilder
9
10 geom_builder = geomBuilder.New()
11 smesh_builder = smeshBuilder.New()
12
13 # Make a patritioned box
14
15 box = geom_builder.MakeBoxDXDYDZ(100,100,100)
16
17 N = geom_builder.MakeVectorDXDYDZ( 1,0,0 )
18 O = geom_builder.MakeVertex( 50,0,0 )
19 plane = geom_builder.MakePlane( O, N, 200 ) # plane YOZ
20
21 shape2boxes = geom_builder.MakeHalfPartition( box, plane )
22 boxes = geom_builder.SubShapeAllSorted(shape2boxes, geom_builder.ShapeType["SOLID"])
23
24 geom_builder.addToStudy( boxes[0], "boxes[0]")
25 geom_builder.addToStudy( boxes[1], "boxes[1]")
26 midFace0 = geom_builder.SubShapeAllSorted(boxes[0], geom_builder.ShapeType["FACE"])[5]
27 geom_builder.addToStudyInFather( boxes[0], midFace0, "middle Face")
28 midFace1 = geom_builder.SubShapeAllSorted(boxes[1], geom_builder.ShapeType["FACE"])[0]
29 geom_builder.addToStudyInFather( boxes[1], midFace1, "middle Face")
30
31 # Mesh one of boxes with quadrangles. It is a source mesh
32
33 srcMesh = smesh_builder.Mesh(boxes[0], "source mesh") # box coloser to CS origin
34 nSeg1 = srcMesh.Segment().NumberOfSegments(4)
35 srcMesh.Quadrangle()
36 srcMesh.Compute()
37 srcFaceGroup = srcMesh.GroupOnGeom( midFace0, "src faces", SMESH.FACE )
38
39 # Import faces from midFace0 to the target mesh
40
41 tgtMesh = smesh_builder.Mesh(boxes[1], "target mesh")
42 importAlgo = tgtMesh.UseExisting2DElements(midFace1)
43 import2hyp = importAlgo.SourceFaces( [srcFaceGroup] )
44 tgtMesh.Segment().NumberOfSegments(3)
45 tgtMesh.Quadrangle()
46 tgtMesh.Compute()
47
48 # Import the whole source mesh with groups
49 import2hyp.SetCopySourceMesh(True,True)
50 tgtMesh.Compute()