0023706: Cannot project point on curve
[occt.git] / src / Extrema / Extrema_FuncExtCC.lxx
1 // Copyright (c) 1999-2012 OPEN CASCADE SAS
2 //
3 // The content of this file is subject to the Open CASCADE Technology Public
4 // License Version 6.5 (the "License"). You may not use the content of this file
5 // except in compliance with the License. Please obtain a copy of the License
6 // at http://www.opencascade.org and read it completely before using this file.
7 //
8 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
9 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
10 //
11 // The Original Code and all software distributed under the License is
12 // distributed on an "AS IS" basis, without warranty of any kind, and the
13 // Initial Developer hereby disclaims all such warranties, including without
14 // limitation, any warranties of merchantability, fitness for a particular
15 // purpose or non-infringement. Please see the License for the specific terms
16 // and conditions governing the rights and limitations under the License.
17
18 //=============================================================================
19 inline void Extrema_FuncExtCC::SetTolerance (const Standard_Real theTol)
20 {
21   myTol = theTol;
22 }
23
24 //=============================================================================
25
26 inline Standard_Integer Extrema_FuncExtCC::NbVariables () const { return 2; }
27
28 //=============================================================================
29
30 inline Standard_Integer Extrema_FuncExtCC::NbEquations () const { return 2; }
31
32 //=============================================================================
33
34 inline Standard_Integer Extrema_FuncExtCC::NbExt () const { return mySqDist.Length(); }
35
36 //=============================================================================
37
38 inline Standard_Real Extrema_FuncExtCC::SquareDistance (const Standard_Integer N) const
39 {
40   return mySqDist.Value(N);
41 }
42
43 //=============================================================================
44
45 inline Standard_Address Extrema_FuncExtCC::CurvePtr (const Standard_Integer theRank) const
46 {
47   Standard_OutOfRange_Raise_if (theRank < 1 || theRank > 2, "Extrema_FuncExtCC::SetCurve()")
48   return (theRank == 1 ? myC1 : myC2);
49 }
50
51 //=============================================================================
52
53 inline Standard_Real Extrema_FuncExtCC::Tolerance() const
54 {
55   return myTol;
56 }