1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
|
-- File: UserIntConicCurveGen.cdl
-- Created: Tue Nov 24 12:33:33 1992
-- Author: Laurent BUCHARD
-- <lbr@topsn3>
---Copyright: Matra Datavision 1992
generic class UserIntConicCurveGen from IntCurve (
TheImpTool as any; -- as ImpTool from IntImpParGen
ThePCurve as any;
ThePCurveTool as any; -- as CurveTool from IntCurve(ThePCurve)
TheIntConicCurve as any) -- as IntConicCurveGen from IntCurve (
-- TheImpTool as ImpTool from IntImpParGen
-- ThePCurve as any;
-- ThePCurveTool as ParTool from IntImpParGen(ThePCurve)
inherits Intersection from IntRes2d
---Purpose: Generic algorithm to intersect a conic from gp and
-- a parametric curve. This class uses the class
-- IConicTool from IntCurve, and Domain from
-- IntCurve.
--
-- The template class for the PCurveTool is given in
-- the package IntCurve (CurveTool).
--
-- The methods used to know the result of the
-- intersection are inherited from the class
-- Intersection from IntRes2d.
--
-- Note: The exception ConstructionError is raised in
-- constructors or in Perform methods when a domain
-- (Domain from IntRes2d) is not correct, i-e when a
-- Circle (Circ2d from gp) or an Ellipse (i-e Elips2d
-- from gp) do not have a closed domain (use the
-- SetEquivalentParameters for a domain on a circle
-- or an ellipse) or the domain of the ThePCurve is
-- not bounded (HasFirstPoint() && HasLastPoint()
-- return True.)
---Level: Internal
uses IConicTool from IntCurve,
Lin2d from gp,
Circ2d from gp,
Elips2d from gp,
Parab2d from gp,
Hypr2d from gp,
Domain from IntRes2d,
IntConicConic from IntCurve
raises ConstructionError from Standard
is
Create
---Purpose: Empty constructor.
returns UserIntConicCurveGen from IntCurve;
Create (L: Lin2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a line and a parametric curve.
returns UserIntConicCurveGen from IntCurve
raises ConstructionError from Standard;
Create (C: Circ2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a line and a parametric curve.
returns UserIntConicCurveGen from IntCurve
raises ConstructionError from Standard;
Create (E: Elips2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between an ellipse and a parametric curve.
returns UserIntConicCurveGen from IntCurve
raises ConstructionError from Standard;
Create (Prb: Parab2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a parabola and a parametric curve.
returns UserIntConicCurveGen from IntCurve
raises ConstructionError from Standard;
Create (H: Hypr2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between the main branch of an hyperbola
-- and a parametric curve.
returns UserIntConicCurveGen from IntCurve
raises ConstructionError from Standard;
Perform (me: in out;
L: Lin2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a line and a parametric curve.
raises ConstructionError from Standard
is static;
Perform (me: in out;
C: Circ2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a line and a parametric curve.
raises ConstructionError from Standard
is static;
Perform (me: in out;
E: Elips2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between an ellipse and a parametric curve.
raises ConstructionError from Standard
is static;
Perform (me: in out;
Prb: Parab2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between a parabola and a parametric curve.
raises ConstructionError from Standard
is static;
Perform (me: in out;
H: Hypr2d from gp; D1: Domain from IntRes2d;
PCurve: ThePCurve; D2: Domain from IntRes2d;
TolConf,Tol: Real from Standard)
---Purpose: Intersection between the main branch of an hyperbola
-- and a parametric curve.
raises ConstructionError from Standard
is static;
-------------------------------- p r i v a t e f u n c t i o n s
InternalPerform (me : in out;
Lin1 : Lin2d from gp;
D1 : Domain from IntRes2d;
PCurve : ThePCurve;
D2 : Domain from IntRes2d;
TolConf,Tol: Real from Standard;
Composite : Boolean from Standard)
is static private;
InternalPerform (me : in out;
Circ1 : Circ2d from gp;
D1 : Domain from IntRes2d;
PCurve : ThePCurve;
D2 : Domain from IntRes2d;
TolConf,Tol: Real from Standard;
Composite : Boolean from Standard)
is static private;
InternalPerform (me : in out;
Eli1 : Elips2d from gp;
D1 : Domain from IntRes2d;
PCurve : ThePCurve;
D2 : Domain from IntRes2d;
TolConf,Tol: Real from Standard;
Composite : Boolean from Standard)
is static private;
InternalPerform (me : in out;
Prb1 : Parab2d from gp;
D1 : Domain from IntRes2d;
PCurve : ThePCurve;
D2 : Domain from IntRes2d;
TolConf,Tol: Real from Standard;
Composite : Boolean from Standard)
is static private;
InternalPerform (me : in out;
Hpr1 : Hypr2d from gp;
D1 : Domain from IntRes2d;
PCurve : ThePCurve;
D2 : Domain from IntRes2d;
TolConf,Tol: Real from Standard;
Composite : Boolean from Standard)
is static private;
fields
param1inf : Real from Standard;
param1sup : Real from Standard;
param2inf : Real from Standard;
param2sup : Real from Standard;
intconiconi : IntConicConic from IntCurve;
intconicurv : TheIntConicCurve;
end UserIntConicCurveGen;
|