summaryrefslogtreecommitdiff
path: root/src/FairCurve/FairCurve_DistributionOfEnergy.cxx
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; 
}