Open CASCADE Technology Reference Manual 8.0.0
Loading...
Searching...
No Matches
Public Member Functions
BRepBlend_RstRstConstRad Class Reference

Copy of CSConstRad with a pcurve on surface as support. More...

#include <BRepBlend_RstRstConstRad.hxx>

Inheritance diagram for BRepBlend_RstRstConstRad:
Inheritance graph
[legend]

Public Member Functions

 BRepBlend_RstRstConstRad (const occ::handle< Adaptor3d_Surface > &Surf1, const occ::handle< Adaptor2d_Curve2d > &Rst1, const occ::handle< Adaptor3d_Surface > &Surf2, const occ::handle< Adaptor2d_Curve2d > &Rst2, const occ::handle< Adaptor3d_Curve > &CGuide)
 
int NbVariables () const override
 Returns 2.
 
int NbEquations () const override
 Returns 2.
 
bool Value (const math_Vector &X, math_Vector &F) override
 computes the values <F> of the Functions for the variable <X>. Returns True if the computation was done successfully, False otherwise.
 
bool Derivatives (const math_Vector &X, math_Matrix &D) override
 returns the values <D> of the derivatives for the variable <X>. Returns True if the computation was done successfully, False otherwise.
 
bool Values (const math_Vector &X, math_Vector &F, math_Matrix &D) override
 returns the values <F> of the functions and the derivatives <D> for the variable <X>. Returns True if the computation was done successfully, False otherwise.
 
void Set (const occ::handle< Adaptor3d_Surface > &SurfRef1, const occ::handle< Adaptor2d_Curve2d > &RstRef1, const occ::handle< Adaptor3d_Surface > &SurfRef2, const occ::handle< Adaptor2d_Curve2d > &RstRef2)
 
void Set (const double Param) override
 Sets the value of the parameter along the guide line. This determines the plane in which the solution has to be found.
 
void Set (const double First, const double Last) override
 Sets the bounds of the parametric interval on the guide line. This determines the derivatives in these values if the function is not Cn.
 
void GetTolerance (math_Vector &Tolerance, const double Tol) const override
 Returns in the vector Tolerance the parametric tolerance for each variable; Tol is the tolerance used in 3d space.
 
void GetBounds (math_Vector &InfBound, math_Vector &SupBound) const override
 Returns in the vector InfBound the lowest values allowed for each variables. Returns in the vector SupBound the greatest values allowed for each of the 3 variables.
 
bool IsSolution (const math_Vector &Sol, const double Tol) override
 Returns true if Sol is a zero of the function. Tol is the tolerance used in 3d space. The computation is made at the current value of the parameter on the guide line.
 
double GetMinimalDistance () const override
 Returns the minimal Distance between two extremities of calculated sections.
 
const gp_PntPointOnRst1 () const override
 Returns the point on the surface.
 
const gp_PntPointOnRst2 () const override
 Returns the point on the curve.
 
const gp_Pnt2dPnt2dOnRst1 () const override
 Returns U,V coordinates of the point on the surface.
 
const gp_Pnt2dPnt2dOnRst2 () const override
 Returns U,V coordinates of the point on the curve on surface.
 
double ParameterOnRst1 () const override
 Returns parameter of the point on the curve.
 
double ParameterOnRst2 () const override
 Returns parameter of the point on the curve.
 
bool IsTangencyPoint () const override
 Returns True when it is not possible to compute the tangent vectors at PointOnS and/or PointOnRst.
 
const gp_VecTangentOnRst1 () const override
 Returns the tangent vector at PointOnS, in 3d space.
 
const gp_Vec2dTangent2dOnRst1 () const override
 Returns the tangent vector at PointOnS, in the parametric space of the first surface.
 
const gp_VecTangentOnRst2 () const override
 Returns the tangent vector at PointOnC, in 3d space.
 
const gp_Vec2dTangent2dOnRst2 () const override
 Returns the tangent vector at PointOnRst, in the parametric space of the second surface.
 
Blend_DecrochStatus Decroch (const math_Vector &Sol, gp_Vec &NRst1, gp_Vec &TgRst1, gp_Vec &NRst2, gp_Vec &TgRst2) const override
 Allows implementing a specific termination criterion for the function.
 
void Set (const double Radius, const int Choix)
 
void Set (const BlendFunc_SectionShape TypeSection)
 Sets the type of section generation for the approximations.
 
bool CenterCircleRst1Rst2 (const gp_Pnt &PtRst1, const gp_Pnt &PtRst2, const gp_Vec &np, gp_Pnt &Center, gp_Vec &VdMed) const
 Give the center of circle define by PtRst1, PtRst2 and radius ray.
 
void Section (const double Param, const double U, const double V, double &Pdeb, double &Pfin, gp_Circ &C)
 
bool IsRational () const override
 Returns if the section is rational.
 
double GetSectionSize () const override
 Returns the length of the maximum section.
 
void GetMinimalWeight (NCollection_Array1< double > &Weigths) const override
 Compute the minimal value of weight for each poles of all sections.
 
int NbIntervals (const GeomAbs_Shape S) const override
 Returns the number of intervals for continuity . May be one if Continuity(me) >=
 
void Intervals (NCollection_Array1< double > &T, const GeomAbs_Shape S) const override
 Stores in <T> the parameters bounding the intervals of continuity . The array must provide enough room to accommodate for the parameters. i.e. T.Length() > NbIntervals()
 
void GetShape (int &NbPoles, int &NbKnots, int &Degree, int &NbPoles2d) override
 
void GetTolerance (const double BoundTol, const double SurfTol, const double AngleTol, math_Vector &Tol3d, math_Vector &Tol1D) const override
 Returns the tolerance to reach in approximation to respect BoundTol error at the Boundary AngleTol tangent error at the Boundary SurfTol error inside the surface.
 
void Knots (NCollection_Array1< double > &TKnots) override
 
void Mults (NCollection_Array1< int > &TMults) override
 
bool Section (const Blend_Point &P, NCollection_Array1< gp_Pnt > &Poles, NCollection_Array1< gp_Vec > &DPoles, NCollection_Array1< gp_Pnt2d > &Poles2d, NCollection_Array1< gp_Vec2d > &DPoles2d, NCollection_Array1< double > &Weigths, NCollection_Array1< double > &DWeigths) override
 Used for the first and last section.
 
void Section (const Blend_Point &P, NCollection_Array1< gp_Pnt > &Poles, NCollection_Array1< gp_Pnt2d > &Poles2d, NCollection_Array1< double > &Weigths) override
 
bool Section (const Blend_Point &P, NCollection_Array1< gp_Pnt > &Poles, NCollection_Array1< gp_Vec > &DPoles, NCollection_Array1< gp_Vec > &D2Poles, NCollection_Array1< gp_Pnt2d > &Poles2d, NCollection_Array1< gp_Vec2d > &DPoles2d, NCollection_Array1< gp_Vec2d > &D2Poles2d, NCollection_Array1< double > &Weigths, NCollection_Array1< double > &DWeigths, NCollection_Array1< double > &D2Weigths) override
 Used for the first and last section The method returns true if the derivatives are computed, otherwise it returns false.
 
void Resolution (const int IC2d, const double Tol, double &TolU, double &TolV) const override
 
- Public Member Functions inherited from Blend_RstRstFunction
const gp_PntPnt1 () const override
 Returns the point on the first support.
 
const gp_PntPnt2 () const override
 Returns the point on the second support.
 
- Public Member Functions inherited from Blend_AppFunction
double Parameter (const Blend_Point &P) const
 Returns the parameter of the point P. Used to impose the parameters in the approximation.
 
- Public Member Functions inherited from math_FunctionSet
virtual int GetStateNumber ()
 Returns the state of the function corresponding to the latestcall of any methods associated with the function. This function is called by each of the algorithms described later which define the function Integer Algorithm::StateNumber(). The algorithm has the responsibility to call this function when it has found a solution (i.e. a root or a minimum) and has to maintain the association between the solution found and this StateNumber. Byu default, this method returns 0 (which means for the algorithm: no state has been saved). It is the responsibility of the programmer to decide if he needs to save the current state of the function and to return an Integer that allows retrieval of the state.
 
virtual ~math_FunctionSet ()
 

Detailed Description

Copy of CSConstRad with a pcurve on surface as support.

Constructor & Destructor Documentation

◆ BRepBlend_RstRstConstRad()

BRepBlend_RstRstConstRad::BRepBlend_RstRstConstRad ( const occ::handle< Adaptor3d_Surface > & Surf1,
const occ::handle< Adaptor2d_Curve2d > & Rst1,
const occ::handle< Adaptor3d_Surface > & Surf2,
const occ::handle< Adaptor2d_Curve2d > & Rst2,
const occ::handle< Adaptor3d_Curve > & CGuide )

Member Function Documentation

◆ CenterCircleRst1Rst2()

bool BRepBlend_RstRstConstRad::CenterCircleRst1Rst2 ( const gp_Pnt & PtRst1,
const gp_Pnt & PtRst2,
const gp_Vec & np,
gp_Pnt & Center,
gp_Vec & VdMed ) const

Give the center of circle define by PtRst1, PtRst2 and radius ray.

◆ Decroch()

Blend_DecrochStatus BRepBlend_RstRstConstRad::Decroch ( const math_Vector & Sol,
gp_Vec & NRst1,
gp_Vec & TgRst1,
gp_Vec & NRst2,
gp_Vec & TgRst2 ) const
overridevirtual

Allows implementing a specific termination criterion for the function.

Implements Blend_RstRstFunction.

◆ Derivatives()

bool BRepBlend_RstRstConstRad::Derivatives ( const math_Vector & X,
math_Matrix & D )
overridevirtual

returns the values <D> of the derivatives for the variable <X>. Returns True if the computation was done successfully, False otherwise.

Implements Blend_RstRstFunction.

◆ GetBounds()

void BRepBlend_RstRstConstRad::GetBounds ( math_Vector & InfBound,
math_Vector & SupBound ) const
overridevirtual

Returns in the vector InfBound the lowest values allowed for each variables. Returns in the vector SupBound the greatest values allowed for each of the 3 variables.

Implements Blend_RstRstFunction.

◆ GetMinimalDistance()

double BRepBlend_RstRstConstRad::GetMinimalDistance ( ) const
overridevirtual

Returns the minimal Distance between two extremities of calculated sections.

Reimplemented from Blend_RstRstFunction.

◆ GetMinimalWeight()

void BRepBlend_RstRstConstRad::GetMinimalWeight ( NCollection_Array1< double > & Weigths) const
overridevirtual

Compute the minimal value of weight for each poles of all sections.

Implements Blend_RstRstFunction.

◆ GetSectionSize()

double BRepBlend_RstRstConstRad::GetSectionSize ( ) const
overridevirtual

Returns the length of the maximum section.

Implements Blend_RstRstFunction.

◆ GetShape()

void BRepBlend_RstRstConstRad::GetShape ( int & NbPoles,
int & NbKnots,
int & Degree,
int & NbPoles2d )
overridevirtual

Implements Blend_RstRstFunction.

◆ GetTolerance() [1/2]

void BRepBlend_RstRstConstRad::GetTolerance ( const double BoundTol,
const double SurfTol,
const double AngleTol,
math_Vector & Tol3d,
math_Vector & Tol1D ) const
overridevirtual

Returns the tolerance to reach in approximation to respect BoundTol error at the Boundary AngleTol tangent error at the Boundary SurfTol error inside the surface.

Implements Blend_RstRstFunction.

◆ GetTolerance() [2/2]

void BRepBlend_RstRstConstRad::GetTolerance ( math_Vector & Tolerance,
const double Tol ) const
overridevirtual

Returns in the vector Tolerance the parametric tolerance for each variable; Tol is the tolerance used in 3d space.

Implements Blend_RstRstFunction.

◆ Intervals()

void BRepBlend_RstRstConstRad::Intervals ( NCollection_Array1< double > & T,
const GeomAbs_Shape S ) const
overridevirtual

Stores in <T> the parameters bounding the intervals of continuity . The array must provide enough room to accommodate for the parameters. i.e. T.Length() > NbIntervals()

Implements Blend_RstRstFunction.

◆ IsRational()

bool BRepBlend_RstRstConstRad::IsRational ( ) const
overridevirtual

Returns if the section is rational.

Implements Blend_RstRstFunction.

◆ IsSolution()

bool BRepBlend_RstRstConstRad::IsSolution ( const math_Vector & Sol,
const double Tol )
overridevirtual

Returns true if Sol is a zero of the function. Tol is the tolerance used in 3d space. The computation is made at the current value of the parameter on the guide line.

Implements Blend_RstRstFunction.

◆ IsTangencyPoint()

bool BRepBlend_RstRstConstRad::IsTangencyPoint ( ) const
overridevirtual

Returns True when it is not possible to compute the tangent vectors at PointOnS and/or PointOnRst.

Implements Blend_RstRstFunction.

◆ Knots()

void BRepBlend_RstRstConstRad::Knots ( NCollection_Array1< double > & TKnots)
overridevirtual

Implements Blend_RstRstFunction.

◆ Mults()

void BRepBlend_RstRstConstRad::Mults ( NCollection_Array1< int > & TMults)
overridevirtual

Implements Blend_RstRstFunction.

◆ NbEquations()

int BRepBlend_RstRstConstRad::NbEquations ( ) const
overridevirtual

Returns 2.

Implements Blend_RstRstFunction.

◆ NbIntervals()

int BRepBlend_RstRstConstRad::NbIntervals ( const GeomAbs_Shape S) const
overridevirtual

Returns the number of intervals for continuity . May be one if Continuity(me) >=

Implements Blend_RstRstFunction.

◆ NbVariables()

int BRepBlend_RstRstConstRad::NbVariables ( ) const
overridevirtual

Returns 2.

Implements Blend_RstRstFunction.

◆ ParameterOnRst1()

double BRepBlend_RstRstConstRad::ParameterOnRst1 ( ) const
overridevirtual

Returns parameter of the point on the curve.

Implements Blend_RstRstFunction.

◆ ParameterOnRst2()

double BRepBlend_RstRstConstRad::ParameterOnRst2 ( ) const
overridevirtual

Returns parameter of the point on the curve.

Implements Blend_RstRstFunction.

◆ Pnt2dOnRst1()

const gp_Pnt2d & BRepBlend_RstRstConstRad::Pnt2dOnRst1 ( ) const
overridevirtual

Returns U,V coordinates of the point on the surface.

Implements Blend_RstRstFunction.

◆ Pnt2dOnRst2()

const gp_Pnt2d & BRepBlend_RstRstConstRad::Pnt2dOnRst2 ( ) const
overridevirtual

Returns U,V coordinates of the point on the curve on surface.

Implements Blend_RstRstFunction.

◆ PointOnRst1()

const gp_Pnt & BRepBlend_RstRstConstRad::PointOnRst1 ( ) const
overridevirtual

Returns the point on the surface.

Implements Blend_RstRstFunction.

◆ PointOnRst2()

const gp_Pnt & BRepBlend_RstRstConstRad::PointOnRst2 ( ) const
overridevirtual

Returns the point on the curve.

Implements Blend_RstRstFunction.

◆ Resolution()

void BRepBlend_RstRstConstRad::Resolution ( const int IC2d,
const double Tol,
double & TolU,
double & TolV ) const
overridevirtual

Implements Blend_AppFunction.

◆ Section() [1/4]

void BRepBlend_RstRstConstRad::Section ( const Blend_Point & P,
NCollection_Array1< gp_Pnt > & Poles,
NCollection_Array1< gp_Pnt2d > & Poles2d,
NCollection_Array1< double > & Weigths )
overridevirtual

Implements Blend_RstRstFunction.

◆ Section() [2/4]

bool BRepBlend_RstRstConstRad::Section ( const Blend_Point & P,
NCollection_Array1< gp_Pnt > & Poles,
NCollection_Array1< gp_Vec > & DPoles,
NCollection_Array1< gp_Pnt2d > & Poles2d,
NCollection_Array1< gp_Vec2d > & DPoles2d,
NCollection_Array1< double > & Weigths,
NCollection_Array1< double > & DWeigths )
overridevirtual

Used for the first and last section.

Implements Blend_RstRstFunction.

◆ Section() [3/4]

bool BRepBlend_RstRstConstRad::Section ( const Blend_Point & P,
NCollection_Array1< gp_Pnt > & Poles,
NCollection_Array1< gp_Vec > & DPoles,
NCollection_Array1< gp_Vec > & D2Poles,
NCollection_Array1< gp_Pnt2d > & Poles2d,
NCollection_Array1< gp_Vec2d > & DPoles2d,
NCollection_Array1< gp_Vec2d > & D2Poles2d,
NCollection_Array1< double > & Weigths,
NCollection_Array1< double > & DWeigths,
NCollection_Array1< double > & D2Weigths )
overridevirtual

Used for the first and last section The method returns true if the derivatives are computed, otherwise it returns false.

Implements Blend_RstRstFunction.

◆ Section() [4/4]

void BRepBlend_RstRstConstRad::Section ( const double Param,
const double U,
const double V,
double & Pdeb,
double & Pfin,
gp_Circ & C )

◆ Set() [1/5]

void BRepBlend_RstRstConstRad::Set ( const BlendFunc_SectionShape TypeSection)

Sets the type of section generation for the approximations.

◆ Set() [2/5]

void BRepBlend_RstRstConstRad::Set ( const double First,
const double Last )
overridevirtual

Sets the bounds of the parametric interval on the guide line. This determines the derivatives in these values if the function is not Cn.

Implements Blend_RstRstFunction.

◆ Set() [3/5]

void BRepBlend_RstRstConstRad::Set ( const double Param)
overridevirtual

Sets the value of the parameter along the guide line. This determines the plane in which the solution has to be found.

Implements Blend_RstRstFunction.

◆ Set() [4/5]

void BRepBlend_RstRstConstRad::Set ( const double Radius,
const int Choix )

◆ Set() [5/5]

void BRepBlend_RstRstConstRad::Set ( const occ::handle< Adaptor3d_Surface > & SurfRef1,
const occ::handle< Adaptor2d_Curve2d > & RstRef1,
const occ::handle< Adaptor3d_Surface > & SurfRef2,
const occ::handle< Adaptor2d_Curve2d > & RstRef2 )

◆ Tangent2dOnRst1()

const gp_Vec2d & BRepBlend_RstRstConstRad::Tangent2dOnRst1 ( ) const
overridevirtual

Returns the tangent vector at PointOnS, in the parametric space of the first surface.

Implements Blend_RstRstFunction.

◆ Tangent2dOnRst2()

const gp_Vec2d & BRepBlend_RstRstConstRad::Tangent2dOnRst2 ( ) const
overridevirtual

Returns the tangent vector at PointOnRst, in the parametric space of the second surface.

Implements Blend_RstRstFunction.

◆ TangentOnRst1()

const gp_Vec & BRepBlend_RstRstConstRad::TangentOnRst1 ( ) const
overridevirtual

Returns the tangent vector at PointOnS, in 3d space.

Implements Blend_RstRstFunction.

◆ TangentOnRst2()

const gp_Vec & BRepBlend_RstRstConstRad::TangentOnRst2 ( ) const
overridevirtual

Returns the tangent vector at PointOnC, in 3d space.

Implements Blend_RstRstFunction.

◆ Value()

bool BRepBlend_RstRstConstRad::Value ( const math_Vector & X,
math_Vector & F )
overridevirtual

computes the values <F> of the Functions for the variable <X>. Returns True if the computation was done successfully, False otherwise.

Implements Blend_RstRstFunction.

◆ Values()

bool BRepBlend_RstRstConstRad::Values ( const math_Vector & X,
math_Vector & F,
math_Matrix & D )
overridevirtual

returns the values <F> of the functions and the derivatives <D> for the variable <X>. Returns True if the computation was done successfully, False otherwise.

Implements Blend_RstRstFunction.


The documentation for this class was generated from the following file: