|
ITK
6.0.0
Insight Toolkit
|
Go to the documentation of this file.
18 #ifndef itkSymmetricSecondRankTensor_h
19 #define itkSymmetricSecondRankTensor_h
22 #ifdef SymmetricSecondRankTensor
23 # undef SymmetricSecondRankTensor
74 template <
typename TComponent,
unsigned int VDimension = 3>
83 static constexpr
unsigned int Dimension = VDimension;
84 static constexpr
unsigned int InternalDimension = VDimension * (VDimension + 1) / 2;
107 #ifdef ITK_FUTURE_LEGACY_REMOVE
117 template <
typename TCoordinateB>
130 template <
typename TCoordinateB>
134 BaseArray::operator=(pa);
141 operator=(
const ComponentType & r);
144 operator=(
const ComponentArrayType r);
155 operator+=(
const Self & r);
158 operator-=(
const Self & r);
162 operator*(
const RealValueType & r)
const;
165 operator/(
const RealValueType & r)
const;
168 operator*=(
const RealValueType & r);
171 operator/=(
const RealValueType & r);
177 return Self::InternalDimension;
184 return this->operator[](c);
191 this->operator[](c) = v;
196 operator()(
unsigned int row,
unsigned int col);
199 operator()(
unsigned int row,
unsigned int col)
const;
212 ComputeEigenValues(EigenValuesArrayType & eigenValues)
const;
217 ComputeEigenAnalysis(EigenValuesArrayType & eigenValues, EigenVectorsMatrixType & eigenVectors)
const;
222 template <
typename TMatrixValueType>
225 template <
typename TMatrixValueType>
227 Rotate(
const vnl_matrix_fixed<TMatrixValueType, VDimension, VDimension> & m)
const
231 template <
typename TMatrixValueType>
233 Rotate(
const vnl_matrix<TMatrixValueType> & m)
const
241 PreMultiply(
const MatrixType & m)
const;
245 PostMultiply(
const MatrixType & m)
const;
255 template <
typename TComponent,
unsigned int VDimension>
259 template <
typename TComponent,
unsigned int VDimension>
263 template <
typename T>
273 #ifndef ITK_MANUAL_INSTANTIATION
274 # include "itkSymmetricSecondRankTensor.hxx"
std::ostream OutputStreamType
Self Rotate(const vnl_matrix< TMatrixValueType > &m) const
CovariantVector< T, VVectorDimension > operator*(const T &scalar, const CovariantVector< T, VVectorDimension > &v)
ComponentType GetNthComponent(int c) const
ConstNeighborhoodIterator< TImage > operator-(const ConstNeighborhoodIterator< TImage > &it, const typename ConstNeighborhoodIterator< TImage >::OffsetType &ind)
ITKCommon_EXPORT std::ostream & operator<<(std::ostream &out, typename AnatomicalOrientation::CoordinateEnum value)
Self Rotate(const vnl_matrix_fixed< TMatrixValueType, VDimension, VDimension > &m) const
Represent a symmetric tensor of second rank.
void SetNthComponent(int c, const ComponentType &v)
typename NumericTraits< ValueType >::RealType RealValueType
static unsigned int GetNumberOfComponents()
ComponentType[Self::InternalDimension] ComponentArrayType
SymmetricSecondRankTensor(const ComponentType &r)
Simulate a standard C array with copy semantics.
A templated class holding a M x N size Matrix.
typename NumericTraits< ValueType >::RealType AccumulateValueType
void swap(Array< T > &a, Array< T > &b) noexcept
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
std::istream InputStreamType
ConstNeighborhoodIterator< TImage > operator+(const ConstNeighborhoodIterator< TImage > &it, const typename ConstNeighborhoodIterator< TImage >::OffsetType &ind)
SymmetricSecondRankTensor(const SymmetricSecondRankTensor< TCoordinateB, VDimension > &pa)
SymmetricSecondRankTensor(const ComponentArrayType r)
constexpr unsigned int Dimension
Self & operator=(const SymmetricSecondRankTensor< TCoordinateB, VDimension > &pa)
std::istream & operator>>(std::istream &is, Point< T, VPointDimension > &vct)