Back to home page

EIC code displayed by LXR

 
 

    


Warning, /include/opencascade/IntImpParGen_ImpParTool.gxx is written in an unsupported language. File is not indexed.

0001 // Copyright (c) 1995-1999 Matra Datavision
0002 // Copyright (c) 1999-2014 OPEN CASCADE SAS
0003 //
0004 // This file is part of Open CASCADE Technology software library.
0005 //
0006 // This library is free software; you can redistribute it and/or modify it under
0007 // the terms of the GNU Lesser General Public License version 2.1 as published
0008 // by the Free Software Foundation, with special exception defined in the file
0009 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
0010 // distribution for complete text of the license and disclaimer of any warranty.
0011 //
0012 // Alternatively, this file may be used under the terms of Open CASCADE
0013 // commercial license or contractual agreement.
0014 
0015 #include <gp_Vec2d.hxx>
0016 
0017 
0018 
0019 IntImpParGen_ImpParTool::IntImpParGen_ImpParTool(const ImpTool& ITool,
0020                                                  const ParCurve& PC):
0021          TheImpTool(ITool) 
0022 {  
0023   TheParCurve = (Standard_Address)(&PC);
0024 }
0025 
0026 
0027 Standard_Boolean IntImpParGen_ImpParTool::Value(const Standard_Real Param,
0028                                    Standard_Real& ApproxDistance) {
0029   
0030   ApproxDistance = TheImpTool.Distance(ParTool::Value((*((ParCurve *)(TheParCurve))),Param));
0031   return(Standard_True);
0032 }
0033 
0034 Standard_Boolean IntImpParGen_ImpParTool::Derivative(const Standard_Real Param,
0035                                         Standard_Real& D_ApproxDistance_DV) {
0036   
0037   gp_Pnt2d Pt;
0038   gp_Vec2d TanParCurve;
0039   gp_Vec2d Grad=TheImpTool.GradDistance(ParTool::Value((*((ParCurve *)(TheParCurve))),Param));
0040   ParTool::D1((*((ParCurve *)(TheParCurve))),Param,Pt,TanParCurve);
0041   D_ApproxDistance_DV = Grad.Dot(TanParCurve);
0042   return(Standard_True);
0043 }
0044 
0045 
0046 Standard_Boolean IntImpParGen_ImpParTool::Values(const Standard_Real Param,
0047                                     Standard_Real& ApproxDistance,
0048                                     Standard_Real& Deriv) {
0049   
0050   this->Value(Param,ApproxDistance);
0051   this->Derivative(Param,Deriv);
0052   return(Standard_True);
0053 }
0054 
0055 
0056