#include <itkMultivariateLegendrePolynomial.h>
2D and 3D multivariate Legendre Polynomial
In 2D,
\[ f(x_{vector}, parameter_{vector}) = \sum_i^l \left( \sum_j^{l-i} \left( parameter_ {ij} * P_i(x) *P_j(y)) \right) \right) \]
where P_i() denoting a Legendre polynomial of degree i and l it the degree of the polynomial
In 3D,
\[f(x_{vector}, parameter_{vector}) = \sum_i^l \left( \sum_j^{l-i} \left( \sum_k^{l-i-j} \left( parameter_{ijk} * P_i(x) * P_j(y) * P_k(z) \right) \right) \right) \]
The size of the parameter vector for 2D is \(\frac{(l+1)\cdot(1+2)}{2}\), and for 3D is \(\frac{(l+1)*(l+2)*(l+3)}{3!}\)
To get the size of the parameter vector, users can use one of the two GetNumberOfCoefficients() member functions
To get function result, users can use the operator() or its SimpleForwardIterator's Get() method.
This is a part of the bias correction methods and implementations that was initially developed and implemented by Martin Styner, Univ. of North Carolina at Chapel Hill, and his colleagues.
Definition at line 67 of file itkMultivariateLegendrePolynomial.h.
Collaboration diagram for itk::MultivariateLegendrePolynomial:Classes | |
| class | CoefficientVectorSizeMismatch |
| class | SimpleForwardIterator |
Public Types | |
| using | CoefficientArrayType = DoubleArrayType |
| using | DomainSizeType = ULongArrayType |
| using | DoubleArrayType = std::vector<double> |
| using | IndexType = LongArrayType |
| using | LongArrayType = std::vector<long> |
| using | ParametersType = Array<double> |
| using | Self = MultivariateLegendrePolynomial |
| using | ULongArrayType = std::vector<unsigned long> |
Protected Member Functions | |
| void | CalculateXCoef (double norm_y, const CoefficientArrayType &coef) |
| void | CalculateYCoef (double norm_z, const CoefficientArrayType &coef) |
| double | LegendreSum (const double x, int n, const CoefficientArrayType &coef, int offset=0) |
| void | PrintSelf (std::ostream &os, Indent indent) const |
Private Attributes | |
| CoefficientArrayType | m_CachedXCoef {} |
| CoefficientArrayType | m_CachedYCoef {} |
| CoefficientArrayType | m_CachedZCoef {} |
| CoefficientArrayType | m_CoefficientArray {} |
| unsigned int | m_Degree {} |
| unsigned int | m_Dimension {} |
| DomainSizeType | m_DomainSize {} |
| DoubleArrayType | m_NormFactor {} |
| unsigned int | m_NumberOfCoefficients {} |
| IndexValueType | m_PrevY {} |
| IndexValueType | m_PrevZ {} |
Internal coefficient storage type.
Definition at line 77 of file itkMultivariateLegendrePolynomial.h.
The size of the domain.
Definition at line 84 of file itkMultivariateLegendrePolynomial.h.
| using itk::MultivariateLegendrePolynomial::DoubleArrayType = std::vector<double> |
Definition at line 72 of file itkMultivariateLegendrePolynomial.h.
Definition at line 85 of file itkMultivariateLegendrePolynomial.h.
| using itk::MultivariateLegendrePolynomial::LongArrayType = std::vector<long> |
Definition at line 74 of file itkMultivariateLegendrePolynomial.h.
| using itk::MultivariateLegendrePolynomial::ParametersType = Array<double> |
Same as CoefficientArray This type definition will be used by EnergyFunction object.
Definition at line 81 of file itkMultivariateLegendrePolynomial.h.
Definition at line 70 of file itkMultivariateLegendrePolynomial.h.
| using itk::MultivariateLegendrePolynomial::ULongArrayType = std::vector<unsigned long> |
Definition at line 73 of file itkMultivariateLegendrePolynomial.h.
| itk::MultivariateLegendrePolynomial::MultivariateLegendrePolynomial | ( | unsigned int | dimension, |
| unsigned int | degree, | ||
| const DomainSizeType & | domainSize ) |
|
virtual |
Destructor.
|
default |
References MultivariateLegendrePolynomial().
|
default |
References MultivariateLegendrePolynomial().
|
protected |
Referenced by Evaluate().
|
protected |
Referenced by Evaluate().
|
inline |
In the case which the bias field is 2D, it returns bias value at the point which is specified by the index
Definition at line 167 of file itkMultivariateLegendrePolynomial.h.
References CalculateXCoef(), CalculateYCoef(), LegendreSum(), m_CachedXCoef, m_CachedYCoef, m_CoefficientArray, m_Degree, m_Dimension, m_NormFactor, m_PrevY, and m_PrevZ.
|
nodiscard |
Gets Legendre polynomials' coefficients.
|
inlinenodiscard |
Gets the degree (the degree of Legendre polynomials).
Definition at line 109 of file itkMultivariateLegendrePolynomial.h.
References m_Degree.
|
inlinenodiscard |
Gets the dimension.
Definition at line 102 of file itkMultivariateLegendrePolynomial.h.
References m_Dimension.
Referenced by itk::MultivariateLegendrePolynomial::SimpleForwardIterator::SimpleForwardIterator().
|
inlinenodiscard |
Gets each dimension's size.
Definition at line 128 of file itkMultivariateLegendrePolynomial.h.
References m_DomainSize.
Referenced by itk::MultivariateLegendrePolynomial::SimpleForwardIterator::SimpleForwardIterator().
|
inlinenodiscard |
Returns the number of coefficients of the polynomial This number is computed from the degree of the polynomial the SetCoefficients() method expects an array of this size, an exception is thrown otherwise
Definition at line 121 of file itkMultivariateLegendrePolynomial.h.
References m_NumberOfCoefficients.
| unsigned int itk::MultivariateLegendrePolynomial::GetNumberOfCoefficients | ( | unsigned int | dimension, |
| unsigned int | degree ) |
Gets the number of coefficients.
|
protected |
Referenced by Evaluate().
|
default |
References MultivariateLegendrePolynomial().
|
default |
References MultivariateLegendrePolynomial().
| void itk::MultivariateLegendrePolynomial::Print | ( | std::ostream & | os | ) | const |
|
protected |
| void itk::MultivariateLegendrePolynomial::SetCoefficients | ( | const CoefficientArrayType & | coefficients | ) |
Sets the Legendre polynomials' parameters.
| void itk::MultivariateLegendrePolynomial::SetCoefficients | ( | const ParametersType & | coefficients | ) |
|
private |
Definition at line 310 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().
|
private |
Definition at line 311 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().
|
private |
Definition at line 312 of file itkMultivariateLegendrePolynomial.h.
|
private |
Definition at line 309 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().
|
private |
Definition at line 306 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate(), and GetDegree().
|
private |
Definition at line 305 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate(), and GetDimension().
|
private |
Definition at line 304 of file itkMultivariateLegendrePolynomial.h.
Referenced by GetDomainSize().
|
private |
Definition at line 314 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().
|
private |
Definition at line 307 of file itkMultivariateLegendrePolynomial.h.
Referenced by GetNumberOfCoefficients().
|
private |
Definition at line 315 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().
|
private |
Definition at line 316 of file itkMultivariateLegendrePolynomial.h.
Referenced by Evaluate().