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