Salome HOME
Join modifications from branch OCC_debug_for_3_2_0b1
[modules/smesh.git] / src / SMESH_SWIG / ex01_cube2build.py
1 #  Copyright (C) 2005  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 #  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
3 #
4 #  This library is free software; you can redistribute it and/or
5 #  modify it under the terms of the GNU Lesser General Public
6 #  License as published by the Free Software Foundation; either
7 #  version 2.1 of the License.
8 #
9 #  This library is distributed in the hope that it will be useful,
10 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
11 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 #  Lesser General Public License for more details.
13 #
14 #  You should have received a copy of the GNU Lesser General Public
15 #  License along with this library; if not, write to the Free Software
16 #  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 #  See http://www.salome-platform.org/
19 #
20 # CEA/LGLS 2004-2005, Francis KLOSS (OCC)
21 # =======================================
22
23 from geompy import *
24
25 import smesh
26
27 # Geometry
28 # ========
29
30 # A small cube centered and put on a great cube build by points, edges, faces and solids
31
32 # Points
33 # ------
34
35 greatPoint111 = MakeVertex( 0,  0,  0)
36 greatPoint211 = MakeVertex(10,  0,  0)
37 greatPoint311 = MakeVertex(20,  0,  0)
38 greatPoint411 = MakeVertex(30,  0,  0)
39
40 greatPoint121 = MakeVertex( 0, 10,  0)
41 greatPoint221 = MakeVertex(10, 10,  0)
42 greatPoint321 = MakeVertex(20, 10,  0)
43 greatPoint421 = MakeVertex(30, 10,  0)
44
45 greatPoint112 = MakeVertex( 0,  0, 10)
46 greatPoint212 = MakeVertex(10,  0, 10)
47 greatPoint312 = MakeVertex(20,  0, 10)
48 greatPoint412 = MakeVertex(30,  0, 10)
49
50 greatPoint122 = MakeVertex( 0, 10, 10)
51 greatPoint222 = MakeVertex(10, 10, 10)
52 greatPoint322 = MakeVertex(20, 10, 10)
53 greatPoint422 = MakeVertex(30, 10, 10)
54
55 greatPoint113 = MakeVertex( 0,  0, 20)
56 greatPoint213 = MakeVertex(10,  0, 20)
57 greatPoint313 = MakeVertex(20,  0, 20)
58 greatPoint413 = MakeVertex(30,  0, 20)
59
60 greatPoint123 = MakeVertex( 0, 10, 20)
61 greatPoint223 = MakeVertex(10, 10, 20)
62 greatPoint323 = MakeVertex(20, 10, 20)
63 greatPoint423 = MakeVertex(30, 10, 20)
64
65 greatPoint114 = MakeVertex( 0,  0, 30)
66 greatPoint214 = MakeVertex(10,  0, 30)
67 greatPoint314 = MakeVertex(20,  0, 30)
68 greatPoint414 = MakeVertex(30,  0, 30)
69
70 greatPoint124 = MakeVertex( 0, 10, 30)
71 greatPoint224 = MakeVertex(10, 10, 30)
72 greatPoint324 = MakeVertex(20, 10, 30)
73 greatPoint424 = MakeVertex(30, 10, 30)
74
75
76 smallPoint111 = greatPoint222
77 smallPoint211 = greatPoint322
78 smallPoint121 = MakeVertex(10, 20, 10)
79 smallPoint221 = MakeVertex(20, 20, 10)
80
81 smallPoint112 = greatPoint223
82 smallPoint212 = greatPoint323
83 smallPoint122 = MakeVertex(10, 20, 20)
84 smallPoint222 = MakeVertex(20, 20, 20)
85
86 # Edges
87 # -----
88
89 smallEdgeX11 = MakeEdge(smallPoint111, smallPoint211)
90 smallEdgeX21 = MakeEdge(smallPoint121, smallPoint221)
91 smallEdgeX12 = MakeEdge(smallPoint112, smallPoint212)
92 smallEdgeX22 = MakeEdge(smallPoint122, smallPoint222)
93
94 smallEdgeY11 = MakeEdge(smallPoint111, smallPoint121)
95 smallEdgeY21 = MakeEdge(smallPoint211, smallPoint221)
96 smallEdgeY12 = MakeEdge(smallPoint112, smallPoint122)
97 smallEdgeY22 = MakeEdge(smallPoint212, smallPoint222)
98
99 smallEdgeZ11 = MakeEdge(smallPoint111, smallPoint112)
100 smallEdgeZ21 = MakeEdge(smallPoint211, smallPoint212)
101 smallEdgeZ12 = MakeEdge(smallPoint121, smallPoint122)
102 smallEdgeZ22 = MakeEdge(smallPoint221, smallPoint222)
103
104
105 greatEdgeX111 = MakeEdge(greatPoint111, greatPoint211)
106 greatEdgeX211 = MakeEdge(greatPoint211, greatPoint311)
107 greatEdgeX311 = MakeEdge(greatPoint311, greatPoint411)
108 greatEdgeX121 = MakeEdge(greatPoint121, greatPoint221)
109 greatEdgeX221 = MakeEdge(greatPoint221, greatPoint321)
110 greatEdgeX321 = MakeEdge(greatPoint321, greatPoint421)
111
112 greatEdgeX112 = MakeEdge(greatPoint112, greatPoint212)
113 greatEdgeX212 = MakeEdge(greatPoint212, greatPoint312)
114 greatEdgeX312 = MakeEdge(greatPoint312, greatPoint412)
115 greatEdgeX122 = MakeEdge(greatPoint122, greatPoint222)
116 greatEdgeX222 = smallEdgeX11
117 greatEdgeX322 = MakeEdge(greatPoint322, greatPoint422)
118
119 greatEdgeX113 = MakeEdge(greatPoint113, greatPoint213)
120 greatEdgeX213 = MakeEdge(greatPoint213, greatPoint313)
121 greatEdgeX313 = MakeEdge(greatPoint313, greatPoint413)
122 greatEdgeX123 = MakeEdge(greatPoint123, greatPoint223)
123 greatEdgeX223 = smallEdgeX12
124 greatEdgeX323 = MakeEdge(greatPoint323, greatPoint423)
125
126 greatEdgeX114 = MakeEdge(greatPoint114, greatPoint214)
127 greatEdgeX214 = MakeEdge(greatPoint214, greatPoint314)
128 greatEdgeX314 = MakeEdge(greatPoint314, greatPoint414)
129 greatEdgeX124 = MakeEdge(greatPoint124, greatPoint224)
130 greatEdgeX224 = MakeEdge(greatPoint224, greatPoint324)
131 greatEdgeX324 = MakeEdge(greatPoint324, greatPoint424)
132
133 greatEdgeY11 = MakeEdge(greatPoint111, greatPoint121)
134 greatEdgeY21 = MakeEdge(greatPoint211, greatPoint221)
135 greatEdgeY31 = MakeEdge(greatPoint311, greatPoint321)
136 greatEdgeY41 = MakeEdge(greatPoint411, greatPoint421)
137
138 greatEdgeY12 = MakeEdge(greatPoint112, greatPoint122)
139 greatEdgeY22 = MakeEdge(greatPoint212, greatPoint222)
140 greatEdgeY32 = MakeEdge(greatPoint312, greatPoint322)
141 greatEdgeY42 = MakeEdge(greatPoint412, greatPoint422)
142
143 greatEdgeY13 = MakeEdge(greatPoint113, greatPoint123)
144 greatEdgeY23 = MakeEdge(greatPoint213, greatPoint223)
145 greatEdgeY33 = MakeEdge(greatPoint313, greatPoint323)
146 greatEdgeY43 = MakeEdge(greatPoint413, greatPoint423)
147
148 greatEdgeY14 = MakeEdge(greatPoint114, greatPoint124)
149 greatEdgeY24 = MakeEdge(greatPoint214, greatPoint224)
150 greatEdgeY34 = MakeEdge(greatPoint314, greatPoint324)
151 greatEdgeY44 = MakeEdge(greatPoint414, greatPoint424)
152
153 greatEdgeZ111 = MakeEdge(greatPoint111, greatPoint112)
154 greatEdgeZ211 = MakeEdge(greatPoint211, greatPoint212)
155 greatEdgeZ311 = MakeEdge(greatPoint311, greatPoint312)
156 greatEdgeZ411 = MakeEdge(greatPoint411, greatPoint412)
157
158 greatEdgeZ121 = MakeEdge(greatPoint121, greatPoint122)
159 greatEdgeZ221 = MakeEdge(greatPoint221, greatPoint222)
160 greatEdgeZ321 = MakeEdge(greatPoint321, greatPoint322)
161 greatEdgeZ421 = MakeEdge(greatPoint421, greatPoint422)
162
163 greatEdgeZ112 = MakeEdge(greatPoint112, greatPoint113)
164 greatEdgeZ212 = MakeEdge(greatPoint212, greatPoint213)
165 greatEdgeZ312 = MakeEdge(greatPoint312, greatPoint313)
166 greatEdgeZ412 = MakeEdge(greatPoint412, greatPoint413)
167
168 greatEdgeZ122 = MakeEdge(greatPoint122, greatPoint123)
169 greatEdgeZ222 = smallEdgeZ11
170 greatEdgeZ322 = smallEdgeZ21
171 greatEdgeZ422 = MakeEdge(greatPoint422, greatPoint423)
172
173 greatEdgeZ113 = MakeEdge(greatPoint113, greatPoint114)
174 greatEdgeZ213 = MakeEdge(greatPoint213, greatPoint214)
175 greatEdgeZ313 = MakeEdge(greatPoint313, greatPoint314)
176 greatEdgeZ413 = MakeEdge(greatPoint413, greatPoint414)
177
178 greatEdgeZ123 = MakeEdge(greatPoint123, greatPoint124)
179 greatEdgeZ223 = MakeEdge(greatPoint223, greatPoint224)
180 greatEdgeZ323 = MakeEdge(greatPoint323, greatPoint324)
181 greatEdgeZ423 = MakeEdge(greatPoint423, greatPoint424)
182
183 # Faces
184 # -----
185
186 smallFaceX1 = MakeQuad(smallEdgeY11, smallEdgeZ11, smallEdgeY12, smallEdgeZ12)
187 smallFaceX2 = MakeQuad(smallEdgeY21, smallEdgeZ21, smallEdgeY22, smallEdgeZ22)
188 smallFaceY1 = MakeQuad(smallEdgeX11, smallEdgeZ11, smallEdgeX12, smallEdgeZ21)
189 smallFaceY2 = MakeQuad(smallEdgeX21, smallEdgeZ12, smallEdgeX22, smallEdgeZ22)
190 smallFaceZ1 = MakeQuad(smallEdgeX11, smallEdgeY11, smallEdgeX21, smallEdgeY21)
191 smallFaceZ2 = MakeQuad(smallEdgeX12, smallEdgeY12, smallEdgeX22, smallEdgeY22)
192
193
194 greatFaceX11 = MakeQuad(greatEdgeY11, greatEdgeZ111, greatEdgeY12, greatEdgeZ121)
195 greatFaceX21 = MakeQuad(greatEdgeY21, greatEdgeZ211, greatEdgeY22, greatEdgeZ221)
196 greatFaceX31 = MakeQuad(greatEdgeY31, greatEdgeZ311, greatEdgeY32, greatEdgeZ321)
197 greatFaceX41 = MakeQuad(greatEdgeY41, greatEdgeZ411, greatEdgeY42, greatEdgeZ421)
198
199 greatFaceX12 = MakeQuad(greatEdgeY12, greatEdgeZ112, greatEdgeY13, greatEdgeZ122)
200 greatFaceX22 = MakeQuad(greatEdgeY22, greatEdgeZ212, greatEdgeY23, greatEdgeZ222)
201 greatFaceX32 = MakeQuad(greatEdgeY32, greatEdgeZ312, greatEdgeY33, greatEdgeZ322)
202 greatFaceX42 = MakeQuad(greatEdgeY42, greatEdgeZ412, greatEdgeY43, greatEdgeZ422)
203
204 greatFaceX13 = MakeQuad(greatEdgeY13, greatEdgeZ113, greatEdgeY14, greatEdgeZ123)
205 greatFaceX23 = MakeQuad(greatEdgeY23, greatEdgeZ213, greatEdgeY24, greatEdgeZ223)
206 greatFaceX33 = MakeQuad(greatEdgeY33, greatEdgeZ313, greatEdgeY34, greatEdgeZ323)
207 greatFaceX43 = MakeQuad(greatEdgeY43, greatEdgeZ413, greatEdgeY44, greatEdgeZ423)
208
209 greatFaceY111 = MakeQuad(greatEdgeX111, greatEdgeZ111, greatEdgeX112, greatEdgeZ211)
210 greatFaceY211 = MakeQuad(greatEdgeX211, greatEdgeZ211, greatEdgeX212, greatEdgeZ311)
211 greatFaceY311 = MakeQuad(greatEdgeX311, greatEdgeZ311, greatEdgeX312, greatEdgeZ411)
212 greatFaceY121 = MakeQuad(greatEdgeX121, greatEdgeZ121, greatEdgeX122, greatEdgeZ221)
213 greatFaceY221 = MakeQuad(greatEdgeX221, greatEdgeZ221, greatEdgeX222, greatEdgeZ321)
214 greatFaceY321 = MakeQuad(greatEdgeX321, greatEdgeZ321, greatEdgeX322, greatEdgeZ421)
215
216 greatFaceY112 = MakeQuad(greatEdgeX112, greatEdgeZ112, greatEdgeX113, greatEdgeZ212)
217 greatFaceY212 = MakeQuad(greatEdgeX212, greatEdgeZ212, greatEdgeX213, greatEdgeZ312)
218 greatFaceY312 = MakeQuad(greatEdgeX312, greatEdgeZ312, greatEdgeX313, greatEdgeZ412)
219 greatFaceY122 = MakeQuad(greatEdgeX122, greatEdgeZ122, greatEdgeX123, greatEdgeZ222)
220 greatFaceY222 = smallFaceY1
221 greatFaceY322 = MakeQuad(greatEdgeX322, greatEdgeZ322, greatEdgeX323, greatEdgeZ422)
222
223 greatFaceY113 = MakeQuad(greatEdgeX113, greatEdgeZ113, greatEdgeX114, greatEdgeZ213)
224 greatFaceY213 = MakeQuad(greatEdgeX213, greatEdgeZ213, greatEdgeX214, greatEdgeZ313)
225 greatFaceY313 = MakeQuad(greatEdgeX313, greatEdgeZ313, greatEdgeX314, greatEdgeZ413)
226 greatFaceY123 = MakeQuad(greatEdgeX123, greatEdgeZ123, greatEdgeX124, greatEdgeZ223)
227 greatFaceY223 = MakeQuad(greatEdgeX223, greatEdgeZ223, greatEdgeX224, greatEdgeZ323)
228 greatFaceY323 = MakeQuad(greatEdgeX323, greatEdgeZ323, greatEdgeX324, greatEdgeZ423)
229
230 greatFaceZ11 = MakeQuad(greatEdgeX111, greatEdgeY11, greatEdgeX121, greatEdgeY21)
231 greatFaceZ21 = MakeQuad(greatEdgeX211, greatEdgeY21, greatEdgeX221, greatEdgeY31)
232 greatFaceZ31 = MakeQuad(greatEdgeX311, greatEdgeY31, greatEdgeX321, greatEdgeY41)
233
234 greatFaceZ12 = MakeQuad(greatEdgeX112, greatEdgeY12, greatEdgeX122, greatEdgeY22)
235 greatFaceZ22 = MakeQuad(greatEdgeX212, greatEdgeY22, greatEdgeX222, greatEdgeY32)
236 greatFaceZ32 = MakeQuad(greatEdgeX312, greatEdgeY32, greatEdgeX322, greatEdgeY42)
237
238 greatFaceZ13 = MakeQuad(greatEdgeX113, greatEdgeY13, greatEdgeX123, greatEdgeY23)
239 greatFaceZ23 = MakeQuad(greatEdgeX213, greatEdgeY23, greatEdgeX223, greatEdgeY33)
240 greatFaceZ33 = MakeQuad(greatEdgeX313, greatEdgeY33, greatEdgeX323, greatEdgeY43)
241
242 greatFaceZ14 = MakeQuad(greatEdgeX114, greatEdgeY14, greatEdgeX124, greatEdgeY24)
243 greatFaceZ24 = MakeQuad(greatEdgeX214, greatEdgeY24, greatEdgeX224, greatEdgeY34)
244 greatFaceZ34 = MakeQuad(greatEdgeX314, greatEdgeY34, greatEdgeX324, greatEdgeY44)
245
246 # Solids
247 # ------
248
249 smallBlock   = MakeHexa(smallFaceX1, smallFaceX2, smallFaceY1, smallFaceY2, smallFaceZ1, smallFaceZ2)
250
251 greatBlock11 = MakeHexa(greatFaceX11, greatFaceX21, greatFaceY111, greatFaceY121, greatFaceZ11, greatFaceZ12)
252 greatBlock21 = MakeHexa(greatFaceX21, greatFaceX31, greatFaceY211, greatFaceY221, greatFaceZ21, greatFaceZ22)
253 greatBlock31 = MakeHexa(greatFaceX31, greatFaceX41, greatFaceY311, greatFaceY321, greatFaceZ31, greatFaceZ32)
254
255 greatBlock12 = MakeHexa(greatFaceX12, greatFaceX22, greatFaceY112, greatFaceY122, greatFaceZ12, greatFaceZ13)
256 greatBlock22 = MakeHexa(greatFaceX22, greatFaceX32, greatFaceY212, greatFaceY222, greatFaceZ22, greatFaceZ23)
257 greatBlock32 = MakeHexa(greatFaceX32, greatFaceX42, greatFaceY312, greatFaceY322, greatFaceZ32, greatFaceZ33)
258
259 greatBlock13 = MakeHexa(greatFaceX13, greatFaceX23, greatFaceY113, greatFaceY123, greatFaceZ13, greatFaceZ14)
260 greatBlock23 = MakeHexa(greatFaceX23, greatFaceX33, greatFaceY213, greatFaceY223, greatFaceZ23, greatFaceZ24)
261 greatBlock33 = MakeHexa(greatFaceX33, greatFaceX43, greatFaceY313, greatFaceY323, greatFaceZ33, greatFaceZ34)
262
263 # Compound
264 # --------
265
266 c_l = []
267 c_l.append(smallBlock)
268 c_l.append(greatBlock11)
269 c_l.append(greatBlock21)
270 c_l.append(greatBlock31)
271 c_l.append(greatBlock12)
272 c_l.append(greatBlock22)
273 c_l.append(greatBlock32)
274 c_l.append(greatBlock13)
275 c_l.append(greatBlock23)
276 c_l.append(greatBlock33)
277
278 piece = MakeCompound(c_l)
279
280 # Add in study
281 # ------------
282
283 piece_id = addToStudy(piece, "ex01_cube2build")
284
285 # Meshing
286 # =======
287
288 # Create hexahedrical mesh on piece
289 # ---------------------------------
290
291 hexa = smesh.Mesh(piece, "ex01_cube2build:hexa")
292
293 algo = hexa.Segment()
294 algo.NumberOfSegments(4)
295
296 hexa.Quadrangle()
297
298 hexa.Hexahedron()
299
300 # Create local hypothesis
301 # -----------------------
302
303 algo = hexa.Segment(greatEdgeX111)
304
305 algo.Arithmetic1D(1, 4)
306
307 algo.Propagation()
308
309 # Compute the mesh
310 # ----------------
311
312 hexa.Compute()