Salome HOME
100ce2bf968b934c681a52caeb40237ecf461c4a
[modules/shaper.git] / src / FeaturesPlugin / Test / Test2636.py
1 ## Copyright (C) 2019-2023  CEA/DEN, EDF R&D
2 ##
3 ## This library is free software; you can redistribute it and/or
4 ## modify it under the terms of the GNU Lesser General Public
5 ## License as published by the Free Software Foundation; either
6 ## version 2.1 of the License, or (at your option) any later version.
7 ##
8 ## This library is distributed in the hope that it will be useful,
9 ## but WITHOUT ANY WARRANTY; without even the implied warranty of
10 ## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 ## Lesser General Public License for more details.
12 ##
13 ## You should have received a copy of the GNU Lesser General Public
14 ## License along with this library; if not, write to the Free Software
15 ## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 ##
17 ## See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 ##
19
20 from SketchAPI import *
21
22 from salome.shaper import model
23
24 model.begin()
25 partSet = model.moduleDocument()
26 model.addParameter(partSet, "epsilon", "0.1")
27 Part_1 = model.addPart(partSet)
28 Part_1_doc = Part_1.document()
29 Sketch_1 = model.addSketch(Part_1_doc, model.defaultPlane("XOY"))
30 SketchProjection_1 = Sketch_1.addProjection(model.selection("EDGE", "PartSet/OX"), False)
31 SketchLine_1 = SketchProjection_1.createdFeature()
32 SketchLine_1.setName("SketchLine_2")
33 SketchLine_1.result().setName("SketchLine_2")
34 SketchProjection_2 = Sketch_1.addProjection(model.selection("EDGE", "PartSet/OY"), False)
35 SketchLine_2 = SketchProjection_2.createdFeature()
36 SketchLine_2.setName("SketchLine_3")
37 SketchLine_2.result().setName("SketchLine_3")
38 SketchLine_3 = Sketch_1.addLine(0, 0, 0, -21)
39 SketchLine_3.setName("SketchLine_4")
40 SketchLine_3.result().setName("SketchLine_4")
41 SketchConstraintCoincidence_1 = Sketch_1.setCoincident(SketchAPI_Line(SketchLine_1).startPoint(), SketchLine_3.startPoint())
42 SketchLine_4 = Sketch_1.addLine(0, -21, 54, -21)
43 SketchLine_4.setName("SketchLine_5")
44 SketchLine_4.result().setName("SketchLine_5")
45 SketchConstraintCoincidence_2 = Sketch_1.setCoincident(SketchLine_3.endPoint(), SketchLine_4.startPoint())
46 SketchLine_5 = Sketch_1.addLine(54, -21, 57, -18)
47 SketchLine_5.setName("SketchLine_6")
48 SketchLine_5.result().setName("SketchLine_6")
49 SketchConstraintCoincidence_3 = Sketch_1.setCoincident(SketchLine_4.endPoint(), SketchLine_5.startPoint())
50 SketchConstraintVertical_1 = Sketch_1.setVertical(SketchLine_3.result())
51 SketchConstraintHorizontal_1 = Sketch_1.setHorizontal(SketchLine_4.result())
52 SketchConstraintLength_1 = Sketch_1.setLength(SketchLine_3.result(), "42/2")
53 SketchConstraintAngle_1 = Sketch_1.setAngleComplementary(SketchLine_4.result(), SketchLine_5.result(), 45)
54 SketchConstraintDistanceHorizontal_1 = Sketch_1.setHorizontalDistance(SketchLine_5.endPoint(), SketchLine_3.endPoint(), 57)
55 SketchLine_6 = Sketch_1.addLine(57, -18, 159.1, -18)
56 SketchLine_6.setName("SketchLine_7")
57 SketchLine_6.result().setName("SketchLine_7")
58 SketchConstraintCoincidence_4 = Sketch_1.setCoincident(SketchLine_5.endPoint(), SketchLine_6.startPoint())
59 SketchConstraintHorizontal_2 = Sketch_1.setHorizontal(SketchLine_6.result())
60 SketchConstraintDistance_1 = Sketch_1.setDistance(SketchLine_5.endPoint(), SketchLine_1.result(), "36/2", True)
61 SketchLine_7 = Sketch_1.addLine(162.1, -21, 162.1, -31.5)
62 SketchLine_7.setName("SketchLine_8")
63 SketchLine_7.result().setName("SketchLine_8")
64 SketchLine_8 = Sketch_1.addLine(162.1, -31.5, 204.1, -31.5)
65 SketchLine_8.setName("SketchLine_9")
66 SketchLine_8.result().setName("SketchLine_9")
67 SketchConstraintCoincidence_5 = Sketch_1.setCoincident(SketchLine_7.endPoint(), SketchLine_8.startPoint())
68 SketchLine_9 = Sketch_1.addLine(204.1, -31.5, 204.1, -21)
69 SketchLine_9.setName("SketchLine_10")
70 SketchLine_9.result().setName("SketchLine_10")
71 SketchConstraintCoincidence_6 = Sketch_1.setCoincident(SketchLine_8.endPoint(), SketchLine_9.startPoint())
72 SketchLine_10 = Sketch_1.addLine(204.1, -21, 181.1, -21)
73 SketchLine_10.setName("SketchLine_11")
74 SketchLine_10.result().setName("SketchLine_11")
75 SketchConstraintCoincidence_7 = Sketch_1.setCoincident(SketchLine_9.endPoint(), SketchLine_10.startPoint())
76 SketchLine_11 = Sketch_1.addLine(181.1, -21, 168.9756443470179, 0)
77 SketchLine_11.setName("SketchLine_12")
78 SketchLine_11.result().setName("SketchLine_12")
79 SketchConstraintCoincidence_8 = Sketch_1.setCoincident(SketchLine_10.endPoint(), SketchLine_11.startPoint())
80 SketchLine_12 = Sketch_1.addLine(168.9756443470179, 0, 0, 0)
81 SketchLine_12.setName("SketchLine_13")
82 SketchLine_12.result().setName("SketchLine_13")
83 SketchConstraintCoincidence_9 = Sketch_1.setCoincident(SketchLine_11.endPoint(), SketchLine_12.startPoint())
84 SketchConstraintCoincidence_10 = Sketch_1.setCoincident(SketchAPI_Line(SketchLine_1).startPoint(), SketchLine_12.endPoint())
85 SketchConstraintHorizontal_3 = Sketch_1.setHorizontal(SketchLine_12.result())
86 SketchConstraintHorizontal_4 = Sketch_1.setHorizontal(SketchLine_10.result())
87 SketchConstraintHorizontal_5 = Sketch_1.setHorizontal(SketchLine_8.result())
88 SketchConstraintVertical_2 = Sketch_1.setVertical(SketchLine_7.result())
89 SketchConstraintVertical_3 = Sketch_1.setVertical(SketchLine_9.result())
90 SketchConstraintDistanceVertical_1 = Sketch_1.setVerticalDistance(SketchLine_12.startPoint(), SketchLine_8.endPoint(), "63/2")
91 SketchConstraintDistanceVertical_2 = Sketch_1.setVerticalDistance(SketchLine_12.startPoint(), SketchLine_10.startPoint(), "42/2")
92 SketchConstraintAngle_2 = Sketch_1.setAngleComplementary(SketchLine_12.result(), SketchLine_11.result(), 60)
93 SketchConstraintLength_2 = Sketch_1.setLength(SketchLine_10.result(), 23)
94 SketchConstraintLength_3 = Sketch_1.setLength(SketchLine_8.result(), 42)
95 SketchLine_13 = Sketch_1.addLine(54, -21, 54, 0)
96 SketchLine_13.setName("SketchLine_14")
97 SketchLine_13.result().setName("SketchLine_14")
98 SketchConstraintCoincidence_11 = Sketch_1.setCoincident(SketchLine_4.endPoint(), SketchLine_13.startPoint())
99 SketchConstraintCoincidence_12 = Sketch_1.setCoincident(SketchLine_13.endPoint(), SketchLine_1.result())
100 SketchLine_14 = Sketch_1.addLine(57, -18, 57, 0)
101 SketchLine_14.setName("SketchLine_15")
102 SketchLine_14.result().setName("SketchLine_15")
103 SketchConstraintCoincidence_13 = Sketch_1.setCoincident(SketchLine_5.endPoint(), SketchLine_14.startPoint())
104 SketchConstraintCoincidence_14 = Sketch_1.setCoincident(SketchLine_14.endPoint(), SketchLine_1.result())
105 SketchConstraintVertical_4 = Sketch_1.setVertical(SketchLine_14.result())
106 SketchConstraintVertical_5 = Sketch_1.setVertical(SketchLine_13.result())
107 SketchLine_15 = Sketch_1.addLine(181.1, -21, 181.1, -31.5)
108 SketchLine_15.setName("SketchLine_18")
109 SketchLine_15.result().setName("SketchLine_18")
110 SketchConstraintCoincidence_15 = Sketch_1.setCoincident(SketchLine_10.endPoint(), SketchLine_15.startPoint())
111 SketchConstraintCoincidence_16 = Sketch_1.setCoincident(SketchLine_15.endPoint(), SketchLine_8.result())
112 SketchConstraintVertical_6 = Sketch_1.setVertical(SketchLine_15.result())
113 SketchArc_1 = Sketch_1.addArc(159.1, -21, 162.1, -21, 159.1, -18, False)
114 SketchPoint_1 = Sketch_1.addPoint(162.1, -18)
115 SketchPoint_1.setName("SketchPoint_2")
116 SketchPoint_1.result().setName("SketchPoint_2")
117 SketchPoint_1.setAuxiliary(True)
118 SketchConstraintCoincidence_17 = Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchLine_6.result())
119 SketchConstraintCoincidence_18 = Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchLine_7.result())
120 SketchConstraintDistance_2 = Sketch_1.setDistance(SketchLine_6.startPoint(), SketchPoint_1.coordinates(), "105+epsilon", False)
121 SketchConstraintCoincidence_19 = Sketch_1.setCoincident(SketchArc_1.startPoint(), SketchLine_7.startPoint())
122 SketchConstraintCoincidence_20 = Sketch_1.setCoincident(SketchArc_1.endPoint(), SketchLine_6.endPoint())
123 SketchConstraintTangent_1 = Sketch_1.setTangent(SketchArc_1.results()[1], SketchLine_6.result())
124 SketchConstraintTangent_2 = Sketch_1.setTangent(SketchArc_1.results()[1], SketchLine_7.result())
125 SketchConstraintRadius_1 = Sketch_1.setRadius(SketchArc_1.results()[1], 3)
126 SketchLine_16 = Sketch_1.addLine(162.1, -21, 181.1, -21)
127 SketchLine_16.setName("SketchLine_36")
128 SketchLine_16.result().setName("SketchLine_36")
129 SketchConstraintCoincidence_21 = Sketch_1.setCoincident(SketchLine_16.endPoint(), SketchLine_11.result())
130 SketchConstraintCoincidence_22 = Sketch_1.setCoincident(SketchLine_16.startPoint(), SketchLine_7.startPoint())
131 SketchConstraintCoincidence_23 = Sketch_1.setCoincident(SketchLine_16.endPoint(), SketchLine_15.startPoint())
132 SketchLine_17 = Sketch_1.addLine(159.1, -18, 159.1, 0)
133 SketchLine_17.setName("SketchLine_35")
134 SketchLine_17.result().setName("SketchLine_35")
135 SketchConstraintCoincidence_24 = Sketch_1.setCoincident(SketchLine_6.endPoint(), SketchLine_17.startPoint())
136 SketchConstraintCoincidence_25 = Sketch_1.setCoincident(SketchLine_17.endPoint(), SketchLine_12.result())
137 SketchConstraintVertical_7 = Sketch_1.setVertical(SketchLine_17.result())
138 SketchLine_18 = Sketch_1.addLine(159.1, -18, 175.3264973081038, -11)
139 SketchLine_18.setName("SketchLine_37")
140 SketchLine_18.result().setName("SketchLine_37")
141 SketchConstraintCoincidence_26 = Sketch_1.setCoincident(SketchLine_18.endPoint(), SketchLine_11.result())
142 SketchConstraintCoincidence_27 = Sketch_1.setCoincident(SketchLine_18.startPoint(), SketchLine_6.endPoint())
143 SketchLine_19 = Sketch_1.addLine(168.9756443470179, 0, 168.9756443470179, -5)
144 SketchLine_19.setName("SketchLine_38")
145 SketchLine_19.result().setName("SketchLine_38")
146 SketchLine_19.setAuxiliary(True)
147 SketchConstraintCoincidence_28 = Sketch_1.setCoincident(SketchLine_11.endPoint(), SketchLine_19.startPoint())
148 SketchConstraintVertical_8 = Sketch_1.setVertical(SketchLine_19.result())
149 SketchConstraintLength_4 = Sketch_1.setLength(SketchLine_19.result(), 5)
150 SketchConstraintDistanceVertical_3 = Sketch_1.setVerticalDistance(SketchLine_18.endPoint(), SketchLine_12.startPoint(), 11)
151 model.do()
152 Revolution_1 = model.addRevolution(Part_1_doc, [model.selection("COMPOUND", "Sketch_1")], model.selection("EDGE", "Sketch_1/SketchLine_13"), 360, 0)
153 Sketch_2 = model.addSketch(Part_1_doc, model.selection("FACE", "Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_4"))
154 SketchPoint_2 = Sketch_2.addPoint(0, 0)
155 SketchPoint_2.setName("SketchPoint_3")
156 SketchPoint_2.result().setName("SketchPoint_3")
157 SketchProjection_3 = Sketch_2.addProjection(model.selection("VERTEX", "[Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_4][Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_5]__cc"), False)
158 SketchProjection_3.setName("SketchProjection_4")
159 SketchProjection_3.result().setName("SketchProjection_4")
160 SketchPoint_3 = SketchProjection_3.createdFeature()
161 SketchPoint_3.setName("SketchPoint_4")
162 SketchPoint_3.result().setName("SketchPoint_4")
163 SketchConstraintCoincidence_29 = Sketch_2.setCoincident(SketchPoint_2.coordinates(), SketchPoint_3.result())
164 model.do()
165 Sketch_2.setName("Sketch_3")
166 Sketch_2.result().setName("Sketch_3")
167 model.do()
168 Part_2 = model.addPart(partSet)
169 Part_2_doc = Part_2.document()
170 Sketch_3 = model.addSketch(Part_2_doc, model.defaultPlane("XOY"))
171 SketchProjection_4 = Sketch_3.addProjection(model.selection("EDGE", "PartSet/OX"), False)
172 SketchLine_20 = SketchProjection_4.createdFeature()
173 SketchLine_20.setName("SketchLine_2")
174 SketchLine_20.result().setName("SketchLine_2")
175 SketchProjection_5 = Sketch_3.addProjection(model.selection("EDGE", "PartSet/OY"), False)
176 SketchLine_21 = SketchProjection_5.createdFeature()
177 SketchLine_21.setName("SketchLine_3")
178 SketchLine_21.result().setName("SketchLine_3")
179 SketchLine_22 = Sketch_3.addLine(0, 0, 0, -21)
180 SketchLine_22.setName("SketchLine_4")
181 SketchLine_22.result().setName("SketchLine_4")
182 SketchConstraintCoincidence_30 = Sketch_3.setCoincident(SketchAPI_Line(SketchLine_20).startPoint(), SketchLine_22.startPoint())
183 SketchLine_23 = Sketch_3.addLine(0, -21, 54, -21)
184 SketchLine_23.setName("SketchLine_5")
185 SketchLine_23.result().setName("SketchLine_5")
186 SketchConstraintCoincidence_31 = Sketch_3.setCoincident(SketchLine_22.endPoint(), SketchLine_23.startPoint())
187 SketchLine_24 = Sketch_3.addLine(54, -21, 57, -18)
188 SketchLine_24.setName("SketchLine_6")
189 SketchLine_24.result().setName("SketchLine_6")
190 SketchConstraintCoincidence_32 = Sketch_3.setCoincident(SketchLine_23.endPoint(), SketchLine_24.startPoint())
191 SketchConstraintVertical_9 = Sketch_3.setVertical(SketchLine_22.result())
192 SketchConstraintHorizontal_6 = Sketch_3.setHorizontal(SketchLine_23.result())
193 SketchConstraintLength_5 = Sketch_3.setLength(SketchLine_22.result(), "42/2")
194 SketchConstraintAngle_3 = Sketch_3.setAngleComplementary(SketchLine_23.result(), SketchLine_24.result(), 45)
195 SketchConstraintDistanceHorizontal_2 = Sketch_3.setHorizontalDistance(SketchLine_24.endPoint(), SketchLine_22.endPoint(), 57)
196 SketchLine_25 = Sketch_3.addLine(57, -18, 159.1, -18)
197 SketchLine_25.setName("SketchLine_7")
198 SketchLine_25.result().setName("SketchLine_7")
199 SketchConstraintCoincidence_33 = Sketch_3.setCoincident(SketchLine_24.endPoint(), SketchLine_25.startPoint())
200 SketchConstraintHorizontal_7 = Sketch_3.setHorizontal(SketchLine_25.result())
201 SketchConstraintDistance_3 = Sketch_3.setDistance(SketchLine_24.endPoint(), SketchLine_20.result(), "36/2", True)
202 SketchLine_26 = Sketch_3.addLine(162.1, -21, 162.1, -31.5)
203 SketchLine_26.setName("SketchLine_8")
204 SketchLine_26.result().setName("SketchLine_8")
205 SketchLine_27 = Sketch_3.addLine(162.1, -31.5, 204.1, -31.5)
206 SketchLine_27.setName("SketchLine_9")
207 SketchLine_27.result().setName("SketchLine_9")
208 SketchConstraintCoincidence_34 = Sketch_3.setCoincident(SketchLine_26.endPoint(), SketchLine_27.startPoint())
209 SketchLine_28 = Sketch_3.addLine(204.1, -31.5, 204.1, -21)
210 SketchLine_28.setName("SketchLine_10")
211 SketchLine_28.result().setName("SketchLine_10")
212 SketchConstraintCoincidence_35 = Sketch_3.setCoincident(SketchLine_27.endPoint(), SketchLine_28.startPoint())
213 SketchLine_29 = Sketch_3.addLine(204.1, -21, 181.1, -21)
214 SketchLine_29.setName("SketchLine_11")
215 SketchLine_29.result().setName("SketchLine_11")
216 SketchConstraintCoincidence_36 = Sketch_3.setCoincident(SketchLine_28.endPoint(), SketchLine_29.startPoint())
217 SketchLine_30 = Sketch_3.addLine(181.1, -21, 168.9756443470179, 0)
218 SketchLine_30.setName("SketchLine_12")
219 SketchLine_30.result().setName("SketchLine_12")
220 SketchConstraintCoincidence_37 = Sketch_3.setCoincident(SketchLine_29.endPoint(), SketchLine_30.startPoint())
221 SketchLine_31 = Sketch_3.addLine(168.9756443470179, 0, 0, 0)
222 SketchLine_31.setName("SketchLine_13")
223 SketchLine_31.result().setName("SketchLine_13")
224 SketchConstraintCoincidence_38 = Sketch_3.setCoincident(SketchLine_30.endPoint(), SketchLine_31.startPoint())
225 SketchConstraintCoincidence_39 = Sketch_3.setCoincident(SketchAPI_Line(SketchLine_20).startPoint(), SketchLine_31.endPoint())
226 SketchConstraintHorizontal_8 = Sketch_3.setHorizontal(SketchLine_31.result())
227 SketchConstraintHorizontal_9 = Sketch_3.setHorizontal(SketchLine_29.result())
228 SketchConstraintHorizontal_10 = Sketch_3.setHorizontal(SketchLine_27.result())
229 SketchConstraintVertical_10 = Sketch_3.setVertical(SketchLine_26.result())
230 SketchConstraintVertical_11 = Sketch_3.setVertical(SketchLine_28.result())
231 SketchConstraintDistanceVertical_4 = Sketch_3.setVerticalDistance(SketchLine_31.startPoint(), SketchLine_27.endPoint(), "63/2")
232 SketchConstraintDistanceVertical_5 = Sketch_3.setVerticalDistance(SketchLine_31.startPoint(), SketchLine_29.startPoint(), "42/2")
233 SketchConstraintAngle_4 = Sketch_3.setAngleComplementary(SketchLine_31.result(), SketchLine_30.result(), 60)
234 SketchConstraintLength_6 = Sketch_3.setLength(SketchLine_29.result(), 23)
235 SketchConstraintLength_7 = Sketch_3.setLength(SketchLine_27.result(), 42)
236 SketchLine_32 = Sketch_3.addLine(54, -21, 54, 0)
237 SketchLine_32.setName("SketchLine_14")
238 SketchLine_32.result().setName("SketchLine_14")
239 SketchConstraintCoincidence_40 = Sketch_3.setCoincident(SketchLine_23.endPoint(), SketchLine_32.startPoint())
240 SketchConstraintCoincidence_41 = Sketch_3.setCoincident(SketchLine_32.endPoint(), SketchLine_20.result())
241 SketchLine_33 = Sketch_3.addLine(57, -18, 57, 0)
242 SketchLine_33.setName("SketchLine_15")
243 SketchLine_33.result().setName("SketchLine_15")
244 SketchConstraintCoincidence_42 = Sketch_3.setCoincident(SketchLine_24.endPoint(), SketchLine_33.startPoint())
245 SketchConstraintCoincidence_43 = Sketch_3.setCoincident(SketchLine_33.endPoint(), SketchLine_20.result())
246 SketchConstraintVertical_12 = Sketch_3.setVertical(SketchLine_33.result())
247 SketchConstraintVertical_13 = Sketch_3.setVertical(SketchLine_32.result())
248 SketchLine_34 = Sketch_3.addLine(181.1, -21, 181.1, -31.5)
249 SketchLine_34.setName("SketchLine_18")
250 SketchLine_34.result().setName("SketchLine_18")
251 SketchConstraintCoincidence_44 = Sketch_3.setCoincident(SketchLine_29.endPoint(), SketchLine_34.startPoint())
252 SketchConstraintCoincidence_45 = Sketch_3.setCoincident(SketchLine_34.endPoint(), SketchLine_27.result())
253 SketchConstraintVertical_14 = Sketch_3.setVertical(SketchLine_34.result())
254 SketchArc_2 = Sketch_3.addArc(159.1, -21, 162.1, -21, 159.1, -18, False)
255 SketchPoint_4 = Sketch_3.addPoint(162.1, -18)
256 SketchPoint_4.setName("SketchPoint_2")
257 SketchPoint_4.result().setName("SketchPoint_2")
258 SketchPoint_4.setAuxiliary(True)
259 SketchConstraintCoincidence_46 = Sketch_3.setCoincident(SketchPoint_4.coordinates(), SketchLine_25.result())
260 SketchConstraintCoincidence_47 = Sketch_3.setCoincident(SketchPoint_4.coordinates(), SketchLine_26.result())
261 SketchConstraintDistance_4 = Sketch_3.setDistance(SketchLine_25.startPoint(), SketchPoint_4.coordinates(), "105+epsilon", False)
262 SketchConstraintCoincidence_48 = Sketch_3.setCoincident(SketchArc_2.startPoint(), SketchLine_26.startPoint())
263 SketchConstraintCoincidence_49 = Sketch_3.setCoincident(SketchArc_2.endPoint(), SketchLine_25.endPoint())
264 SketchConstraintTangent_3 = Sketch_3.setTangent(SketchArc_2.results()[1], SketchLine_25.result())
265 SketchConstraintTangent_4 = Sketch_3.setTangent(SketchArc_2.results()[1], SketchLine_26.result())
266 SketchConstraintRadius_2 = Sketch_3.setRadius(SketchArc_2.results()[1], 3)
267 SketchLine_35 = Sketch_3.addLine(162.1, -21, 181.1, -21)
268 SketchLine_35.setName("SketchLine_36")
269 SketchLine_35.result().setName("SketchLine_36")
270 SketchConstraintCoincidence_50 = Sketch_3.setCoincident(SketchLine_35.endPoint(), SketchLine_30.result())
271 SketchConstraintCoincidence_51 = Sketch_3.setCoincident(SketchLine_35.startPoint(), SketchLine_26.startPoint())
272 SketchConstraintCoincidence_52 = Sketch_3.setCoincident(SketchLine_35.endPoint(), SketchLine_34.startPoint())
273 SketchLine_36 = Sketch_3.addLine(159.1, -18, 159.1, 0)
274 SketchLine_36.setName("SketchLine_35")
275 SketchLine_36.result().setName("SketchLine_35")
276 SketchConstraintCoincidence_53 = Sketch_3.setCoincident(SketchLine_25.endPoint(), SketchLine_36.startPoint())
277 SketchConstraintCoincidence_54 = Sketch_3.setCoincident(SketchLine_36.endPoint(), SketchLine_31.result())
278 SketchConstraintVertical_15 = Sketch_3.setVertical(SketchLine_36.result())
279 SketchLine_37 = Sketch_3.addLine(159.1, -18, 175.3264973081038, -11)
280 SketchLine_37.setName("SketchLine_37")
281 SketchLine_37.result().setName("SketchLine_37")
282 SketchConstraintCoincidence_55 = Sketch_3.setCoincident(SketchLine_37.endPoint(), SketchLine_30.result())
283 SketchConstraintCoincidence_56 = Sketch_3.setCoincident(SketchLine_37.startPoint(), SketchLine_25.endPoint())
284 SketchLine_38 = Sketch_3.addLine(168.9756443470179, 0, 168.9756443470179, -5)
285 SketchLine_38.setName("SketchLine_38")
286 SketchLine_38.result().setName("SketchLine_38")
287 SketchLine_38.setAuxiliary(True)
288 SketchConstraintCoincidence_57 = Sketch_3.setCoincident(SketchLine_30.endPoint(), SketchLine_38.startPoint())
289 SketchConstraintVertical_16 = Sketch_3.setVertical(SketchLine_38.result())
290 SketchConstraintLength_8 = Sketch_3.setLength(SketchLine_38.result(), 5)
291 SketchConstraintDistanceVertical_6 = Sketch_3.setVerticalDistance(SketchLine_37.endPoint(), SketchLine_31.startPoint(), 11)
292 model.do()
293 Revolution_2 = model.addRevolution(Part_2_doc, [model.selection("COMPOUND", "Sketch_1")], model.selection("EDGE", "Sketch_1/SketchLine_13"), 360, 0)
294 Sketch_4 = model.addSketch(Part_2_doc, model.selection("FACE", "Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_4"))
295 SketchLine_39 = Sketch_4.addLine(50, 0, -50, 0)
296 SketchLine_39.setName("SketchLine_19")
297 SketchLine_39.result().setName("SketchLine_19")
298 SketchConstraintHorizontal_11 = Sketch_4.setHorizontal(SketchLine_39.result())
299 SketchProjection_6 = Sketch_4.addProjection(model.selection("VERTEX", "[Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_4][Revolution_1_1_1/Generated_Face&Sketch_1/SketchLine_5]__cc"), False)
300 SketchPoint_5 = SketchProjection_6.createdFeature()
301 SketchPoint_5.setName("SketchPoint_1")
302 SketchPoint_5.result().setName("SketchPoint_1")
303 SketchConstraintLength_9 = Sketch_4.setLength(SketchLine_39.result(), 100)
304 SketchLine_40 = Sketch_4.addLine(0, -50, 0, 50)
305 SketchLine_40.setName("SketchLine_20")
306 SketchLine_40.result().setName("SketchLine_20")
307 SketchProjection_7 = Sketch_4.addProjection(model.selection("EDGE", "PartSet/OZ"), False)
308 SketchLine_41 = SketchProjection_7.createdFeature()
309 SketchLine_41.setName("SketchLine_21")
310 SketchLine_41.result().setName("SketchLine_21")
311 SketchConstraintCoincidence_58 = Sketch_4.setCoincident(SketchLine_40.startPoint(), SketchLine_41.result())
312 SketchConstraintVertical_17 = Sketch_4.setVertical(SketchLine_40.result())
313 SketchConstraintLength_10 = Sketch_4.setLength(SketchLine_40.result(), 100)
314 SketchCircle_1 = Sketch_4.addCircle(0, 0, 7)
315 SketchCircle_1.setAuxiliary(True)
316 SketchConstraintCoincidence_59 = Sketch_4.setCoincident(SketchAPI_Point(SketchPoint_5).coordinates(), SketchCircle_1.center())
317 SketchConstraintRadius_3 = Sketch_4.setRadius(SketchCircle_1.results()[1], 7)
318 SketchLine_42 = Sketch_4.addLine(0, 0, -4.949747468305834, -4.949747468305832)
319 SketchLine_42.setName("SketchLine_22")
320 SketchLine_42.result().setName("SketchLine_22")
321 SketchLine_42.setAuxiliary(True)
322 SketchConstraintCoincidence_60 = Sketch_4.setCoincident(SketchAPI_Point(SketchPoint_5).coordinates(), SketchLine_42.startPoint())
323 SketchConstraintCoincidence_61 = Sketch_4.setCoincident(SketchLine_42.endPoint(), SketchCircle_1.results()[1])
324 SketchConstraintAngle_5 = Sketch_4.setAngleComplementary(SketchLine_42.result(), SketchLine_39.result(), 45)
325 SketchLine_43 = Sketch_4.addLine(0, -7, -4.949747468305834, -4.949747468305832)
326 SketchLine_43.setName("SketchLine_23")
327 SketchLine_43.result().setName("SketchLine_23")
328 SketchConstraintCoincidence_62 = Sketch_4.setCoincident(SketchLine_43.startPoint(), SketchLine_41.result())
329 SketchConstraintCoincidence_63 = Sketch_4.setCoincident(SketchLine_42.endPoint(), SketchLine_43.endPoint())
330 SketchLine_44 = Sketch_4.addLine(-4.949747468305834, -4.949747468305832, -7, 0)
331 SketchLine_44.setName("SketchLine_24")
332 SketchLine_44.result().setName("SketchLine_24")
333 SketchConstraintCoincidence_64 = Sketch_4.setCoincident(SketchLine_42.endPoint(), SketchLine_44.startPoint())
334 SketchConstraintCoincidence_65 = Sketch_4.setCoincident(SketchLine_44.endPoint(), SketchLine_39.result())
335 SketchLine_45 = Sketch_4.addLine(-4.949747468305834, -4.949747468305832, -33.23401871576774, -33.23401871576773)
336 SketchLine_45.setName("SketchLine_25")
337 SketchLine_45.result().setName("SketchLine_25")
338 SketchConstraintCoincidence_66 = Sketch_4.setCoincident(SketchLine_42.endPoint(), SketchLine_45.startPoint())
339 SketchConstraintCollinear_1 = Sketch_4.setCollinear(SketchLine_45.result(), SketchLine_42.result())
340 SketchConstraintCoincidence_67 = Sketch_4.setCoincident(SketchLine_43.startPoint(), SketchCircle_1.results()[1])
341 SketchConstraintCoincidence_68 = Sketch_4.setCoincident(SketchLine_44.endPoint(), SketchCircle_1.results()[1])
342 SketchConstraintLength_11 = Sketch_4.setLength(SketchLine_45.result(), 40)
343 SketchMultiRotation_1_objects = [SketchLine_43.result(), SketchLine_45.result(), SketchLine_44.result()]
344 SketchMultiRotation_1 = Sketch_4.addRotation(SketchMultiRotation_1_objects, SketchAPI_Line(SketchLine_41).startPoint(), 90, 4)
345 [SketchLine_46, SketchLine_47, SketchLine_48, SketchLine_49, SketchLine_50, SketchLine_51, SketchLine_52, SketchLine_53, SketchLine_54] = SketchMultiRotation_1.rotated()
346 SketchLine_54.setName("SketchLine_34")
347 SketchLine_54.result().setName("SketchLine_34")
348 SketchLine_53.setName("SketchLine_33")
349 SketchLine_53.result().setName("SketchLine_33")
350 SketchLine_52.setName("SketchLine_28")
351 SketchLine_52.result().setName("SketchLine_28")
352 SketchLine_51.setName("SketchLine_32")
353 SketchLine_51.result().setName("SketchLine_32")
354 SketchLine_50.setName("SketchLine_31")
355 SketchLine_50.result().setName("SketchLine_31")
356 SketchLine_49.setName("SketchLine_27")
357 SketchLine_49.result().setName("SketchLine_27")
358 SketchLine_48.setName("SketchLine_30")
359 SketchLine_48.result().setName("SketchLine_30")
360 SketchLine_47.setName("SketchLine_29")
361 SketchLine_47.result().setName("SketchLine_29")
362 SketchLine_46.setName("SketchLine_26")
363 SketchLine_46.result().setName("SketchLine_26")
364 model.do()
365 Edge_1_objects = [model.selection("EDGE", "Sketch_2/SketchLine_27"), model.selection("EDGE", "Sketch_2/SketchLine_26"), model.selection("EDGE", "Sketch_2/SketchLine_28"), model.selection("EDGE", "Sketch_2/SketchLine_19"), model.selection("EDGE", "Sketch_2/SketchLine_25"), model.selection("EDGE", "Sketch_2/SketchLine_23"), model.selection("EDGE", "Sketch_2/SketchLine_24"), model.selection("EDGE", "Sketch_2/SketchLine_30"), model.selection("EDGE", "Sketch_2/SketchLine_34"), model.selection("EDGE", "Sketch_2/SketchLine_29"), model.selection("EDGE", "Sketch_2/SketchLine_33"), model.selection("EDGE", "Sketch_2/SketchLine_31"), model.selection("EDGE", "Sketch_2/SketchLine_20"), model.selection("EDGE", "Sketch_2/SketchLine_32")]
366 Edge_1 = model.addEdge(Part_2_doc, Edge_1_objects)
367 Extrusion_1_objects = [model.selection("EDGE", "Edge_1_1"), model.selection("EDGE", "Edge_1_2"), model.selection("EDGE", "Edge_1_3"), model.selection("EDGE", "Edge_1_4"), model.selection("EDGE", "Edge_1_5"), model.selection("EDGE", "Edge_1_6"), model.selection("EDGE", "Edge_1_7"), model.selection("EDGE", "Edge_1_8"), model.selection("EDGE", "Edge_1_9"), model.selection("EDGE", "Edge_1_10"), model.selection("EDGE", "Edge_1_11"), model.selection("EDGE", "Edge_1_12"), model.selection("EDGE", "Edge_1_13"), model.selection("EDGE", "Edge_1_14")]
368 Extrusion_1 = model.addExtrusion(Part_2_doc, Extrusion_1_objects, model.selection("EDGE", "PartSet/OX"), 300, 0)
369 Split_1_objects_2 = [model.selection("FACE", "Extrusion_1_1"), model.selection("FACE", "Extrusion_1_2"), model.selection("FACE", "Extrusion_1_3"), model.selection("FACE", "Extrusion_1_4"), model.selection("FACE", "Extrusion_1_5"), model.selection("FACE", "Extrusion_1_6"), model.selection("FACE", "Extrusion_1_7"), model.selection("FACE", "Extrusion_1_8"), model.selection("FACE", "Extrusion_1_9"), model.selection("FACE", "Extrusion_1_10"), model.selection("FACE", "Extrusion_1_11"), model.selection("FACE", "Extrusion_1_12"), model.selection("FACE", "Extrusion_1_13"), model.selection("FACE", "Extrusion_1_14")]
370 Split_1 = model.addSplit(Part_2_doc, [model.selection("COMPSOLID", "Revolution_1_1")], Split_1_objects_2)
371 Group_1_objects = [model.selection("SOLID", "Split_1_1_25"), model.selection("SOLID", "Split_1_1_28"), model.selection("SOLID", "Split_1_1_26"), model.selection("SOLID", "Split_1_1_27"), model.selection("SOLID", "Split_1_1_31"), model.selection("SOLID", "Split_1_1_35"), model.selection("SOLID", "Split_1_1_36"), model.selection("SOLID", "Split_1_1_32"), model.selection("SOLID", "Split_1_1_34"), model.selection("SOLID", "Split_1_1_30"), model.selection("SOLID", "Split_1_1_33"), model.selection("SOLID", "Split_1_1_29")]
372 Group_1 = model.addGroup(Part_2_doc, Group_1_objects)
373 Group_1.setName("CORPS")
374 Group_1.result().setName("CORPS")
375 Group_2_objects = [model.selection("SOLID", "Split_1_1_41"), model.selection("SOLID", "Split_1_1_49"), model.selection("SOLID", "Split_1_1_69"), model.selection("SOLID", "Split_1_1_71"), model.selection("SOLID", "Split_1_1_51"), model.selection("SOLID", "Split_1_1_43"), model.selection("SOLID", "Split_1_1_44"), model.selection("SOLID", "Split_1_1_67"), model.selection("SOLID", "Split_1_1_39"), model.selection("SOLID", "Split_1_1_47"), model.selection("SOLID", "Split_1_1_45"), model.selection("SOLID", "Split_1_1_37"), model.selection("SOLID", "Split_1_1_65"), model.selection("SOLID", "Split_1_1_66"), model.selection("SOLID", "Split_1_1_38"), model.selection("SOLID", "Split_1_1_46"), model.selection("SOLID", "Split_1_1_48"), model.selection("SOLID", "Split_1_1_40"), model.selection("SOLID", "Split_1_1_68"), model.selection("SOLID", "Split_1_1_42"), model.selection("SOLID", "Split_1_1_70"), model.selection("SOLID", "Split_1_1_50"), model.selection("SOLID", "Split_1_1_52"), model.selection("SOLID", "Split_1_1_72"), model.selection("SOLID", "Split_1_1_63"), model.selection("SOLID", "Split_1_1_64"), model.selection("SOLID", "Split_1_1_61"), model.selection("SOLID", "Split_1_1_62"), model.selection("SOLID", "Split_1_1_58"), model.selection("SOLID", "Split_1_1_57"), model.selection("SOLID", "Split_1_1_54"), model.selection("SOLID", "Split_1_1_53"), model.selection("SOLID", "Split_1_1_55"), model.selection("SOLID", "Split_1_1_56"), model.selection("SOLID", "Split_1_1_60"), model.selection("SOLID", "Split_1_1_59")]
376 Group_2 = model.addGroup(Part_2_doc, Group_2_objects)
377 Group_2.setName("TETE")
378 Group_2.result().setName("TETE")
379 Group_3_objects = [model.selection("SOLID", "Split_1_1_2"), model.selection("SOLID", "Split_1_1_1"), model.selection("SOLID", "Split_1_1_5"), model.selection("SOLID", "Split_1_1_9"), model.selection("SOLID", "Split_1_1_13"), model.selection("SOLID", "Split_1_1_14"), model.selection("SOLID", "Split_1_1_15"), model.selection("SOLID", "Split_1_1_19"), model.selection("SOLID", "Split_1_1_11"), model.selection("SOLID", "Split_1_1_12"), model.selection("SOLID", "Split_1_1_24"), model.selection("SOLID", "Split_1_1_23"), model.selection("SOLID", "Split_1_1_16"), model.selection("SOLID", "Split_1_1_8"), model.selection("SOLID", "Split_1_1_20"), model.selection("SOLID", "Split_1_1_4"), model.selection("SOLID", "Split_1_1_3"), model.selection("SOLID", "Split_1_1_7"), model.selection("SOLID", "Split_1_1_10"), model.selection("SOLID", "Split_1_1_6")]
380 Group_3 = model.addGroup(Part_2_doc, Group_3_objects)
381 Group_3.setName("PIED")
382 Group_3.result().setName("PIED")
383 Group_4 = model.addGroup(Part_2_doc, [model.selection("EDGE", "Split_1_1_36/Generated_Edge&Sketch_2/SketchLine_31&Sketch_1/SketchLine_7")])
384 Group_4.setName("corps_hauteur")
385 Group_4.result().setName("corps_hauteur")
386 Group_5 = model.addGroup(Part_2_doc, [model.selection("EDGE", "Split_1_1_11/Generated_Edge&Sketch_2/SketchLine_31&Sketch_1/SketchLine_5")])
387 Group_5.setName("pied_hauteur")
388 Group_5.result().setName("pied_hauteur")
389 Group_6 = model.addGroup(Part_2_doc, [model.selection("EDGE", "Split_1_1_24/Generated_Edge&Sketch_2/SketchLine_31&Sketch_1/SketchLine_6")])
390 Group_6.setName("chanfrein")
391 Group_6.result().setName("chanfrein")
392 Group_7 = model.addGroup(Part_2_doc, [model.selection("EDGE", "Split_1_1_72/Generated_Edge&Sketch_2/SketchLine_31&Sketch_1/SketchArc_1_2")])
393 Group_7.setName("filet")
394 Group_7.result().setName("filet")
395 Group_8 = model.addGroup(Part_2_doc, [model.selection("EDGE", "Split_1_1_42/Generated_Edge&Sketch_2/SketchLine_31&Sketch_1/SketchLine_9")])
396 Group_8.setName("tete_bas")
397 Group_8.result().setName("tete_bas")
398 Group_9_objects = [model.selection("FACE", "Split_1_1_12/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_11/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_9/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_8/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_4/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_1/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_2/Modified_Face&Sketch_1/SketchLine_5"), model.selection("FACE", "Split_1_1_5/Modified_Face&Sketch_1/SketchLine_5")]
399 Group_9 = model.addGroup(Part_2_doc, Group_9_objects)
400 Group_9.setName("ADH_PIEDS")
401 Group_9.result().setName("ADH_PIEDS")
402 Group_10_objects = [model.selection("FACE", "Split_1_1_13/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_14/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_25/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_26/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_15/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_27/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_19/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_31/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_23/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_35/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_24/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_36/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_32/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_20/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_16/Modified_Face&Sketch_1/SketchLine_6"), model.selection("FACE", "Split_1_1_28/Modified_Face&Sketch_1/SketchLine_7"), model.selection("FACE", "Split_1_1_70/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_42/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_68/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_40/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_66/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_38/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_37/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_65/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_39/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_67/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_69/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_41/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_43/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_71/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_44/Modified_Face&Sketch_1/SketchLine_8"), model.selection("FACE", "Split_1_1_72/Modified_Face&Sketch_1/SketchArc_1_2"), model.selection("FACE", "Split_1_1_52/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_44/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_43/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_51/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_50/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_42/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_40/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_48/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_46/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_38/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_37/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_45/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_39/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_47/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_49/Modified_Face&Sketch_1/SketchLine_9"), model.selection("FACE", "Split_1_1_41/Modified_Face&Sketch_1/SketchLine_9")]
403 Group_10 = model.addGroup(Part_2_doc, Group_10_objects)
404 Group_10.setName("CONTACT_VIS")
405 Group_10.result().setName("CONTACT_VIS")
406 Translation_1 = model.addTranslation(Part_2_doc, [model.selection("COMPSOLID", "Split_1_1")], 0, 100, 0)
407 AngularCopy_1 = model.addMultiRotation(Part_2_doc, [model.selection("COMPSOLID", "Translation_1_1")], model.selection("EDGE", "PartSet/OX"), 4)
408 model.do()
409
410 # move groups to the end
411 Part_2_doc.moveFeature(Group_1.feature(), AngularCopy_1.feature())
412 Part_2_doc.moveFeature(Group_2.feature(), Group_1.feature())
413 Part_2_doc.moveFeature(Group_3.feature(), Group_2.feature())
414 Part_2_doc.moveFeature(Group_4.feature(), Group_3.feature())
415 Part_2_doc.moveFeature(Group_5.feature(), Group_4.feature())
416 Part_2_doc.moveFeature(Group_6.feature(), Group_5.feature())
417 Part_2_doc.moveFeature(Group_7.feature(), Group_6.feature())
418 Part_2_doc.moveFeature(Group_8.feature(), Group_7.feature())
419 Part_2_doc.moveFeature(Group_9.feature(), Group_8.feature())
420 Part_2_doc.moveFeature(Group_10.feature(), Group_9.feature())
421 model.end()
422
423 from ModelAPI import *
424
425 aFactory = ModelAPI_Session.get().validators()
426
427 # Check groups
428 a = 0
429 num_in_groups = [48, 144, 80, 4, 4, 4, 4, 4, 32, 192]
430 for i in range(Part_2_doc.size("Groups")):
431   GroupFeature = Part_2_doc.feature(objectToResult(Part_2_doc.object("Groups", i)))
432   assert(aFactory.validate(GroupFeature))
433   assert(GroupFeature.selectionList("group_list").size() == num_in_groups[a])
434   a = a + 1
435
436 assert(model.checkPythonDump())