blob: bd6d5e402606e1f269f51db482c4b2a92a13d071 (
plain)
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
|
// File: FairCurve_DistributionOfEnergy.cxx
// Created: Mon Jan 22 15:11:20 1996
// Author: Philippe MANGIN
#include <FairCurve_DistributionOfEnergy.ixx>
Standard_Integer FairCurve_DistributionOfEnergy::NbVariables() const
{
return MyNbVar;
}
Standard_Integer FairCurve_DistributionOfEnergy::NbEquations() const
{
return MyNbEqua;
}
FairCurve_DistributionOfEnergy::FairCurve_DistributionOfEnergy(const Standard_Integer BSplOrder,
const Handle(TColStd_HArray1OfReal)& FlatKnots,
const Handle(TColgp_HArray1OfPnt2d)& Poles,
const Standard_Integer DerivativeOrder,
const Standard_Integer NbValAux)
: MyBSplOrder (BSplOrder),
MyFlatKnots (FlatKnots),
MyPoles (Poles),
MyDerivativeOrder (DerivativeOrder),
MyNbValAux (NbValAux)
{
MyNbVar = 1;
SetDerivativeOrder( DerivativeOrder);
}
void FairCurve_DistributionOfEnergy::SetDerivativeOrder(const Standard_Integer DerivativeOrder)
{
MyNbEqua = 1;
if (DerivativeOrder>= 1) MyNbEqua += 2*MyPoles->Length() + MyNbValAux;
if (DerivativeOrder>= 2) MyNbEqua = MyNbEqua + (MyNbEqua-1)*MyNbEqua / 2;
MyDerivativeOrder = DerivativeOrder;
}
|