18#ifndef itkCovariantVector_h
19#define itkCovariantVector_h
23#include "vnl/vnl_vector_ref.h"
69template <
typename T,
unsigned int VVectorDimension = 3>
86 static constexpr unsigned int Dimension = VVectorDimension;
98 return VVectorDimension;
124 template <
typename TVectorValueType>
134 template <
typename TCovariantVectorValueType>
138 BaseArray::operator=(r);
148 template <
typename Tt>
152 for (
unsigned int i = 0; i < VVectorDimension; ++i)
154 (*this)[i] =
static_cast<ValueType>((*this)[i] * value);
161 template <
typename Tt>
165 for (
unsigned int i = 0; i < VVectorDimension; ++i)
167 (*this)[i] =
static_cast<ValueType>((*this)[i] / value);
213 for (
unsigned int i = 0; i < VVectorDimension; ++i)
215 result[i] =
static_cast<ValueType>((*this)[i] * val);
222 template <
typename Tt>
228 for (
unsigned int i = 0; i < VVectorDimension; ++i)
230 result[i] =
static_cast<ValueType>((*this)[i] / val);
243 return VVectorDimension;
256 template <
typename TCoordinateB>
260 for (
unsigned int i = 0; i < VVectorDimension; ++i)
262 (*this)[i] =
static_cast<T
>(pa[i]);
270template <
typename T,
unsigned int VVectorDimension>
271inline CovariantVector<T, VVectorDimension>
274 return v.operator*(scalar);
279template <
typename T,
unsigned int VVectorDimension>
283 return covariant.operator*(contravariant);
296template <
typename T,
unsigned int VVectorDimension>
315#ifndef ITK_MANUAL_INSTANTIATION
316# include "itkCovariantVector.hxx"
Pixel-wise addition of two images.
A templated class holding a n-Dimensional covariant vector.
ValueType operator*(const Self &other) const
vnl_vector< T > GetVnlVector() const
RealValueType GetNorm() const
typename NumericTraits< ValueType >::RealType RealValueType
vnl_vector_ref< T > GetVnlVector()
Self operator+(const Self &vec) const
CovariantVector(const ValueType &r)
CovariantVector(const ValueType r[Dimension])
RealValueType Normalize()
const Self & operator*=(const Tt &value)
CovariantVector & operator=(const ValueType r[VVectorDimension])
void CastFrom(const CovariantVector< TCoordinateB, VVectorDimension > &pa)
void SetVnlVector(const vnl_vector< T > &)
CovariantVector(const CovariantVector< TVectorValueType, VVectorDimension > &r)
RealValueType GetSquaredNorm() const
static unsigned int GetNumberOfComponents()
ValueType operator*(const Vector< T, VVectorDimension > &other) const
CovariantVector()=default
Self operator-(const Self &vec) const
Self operator*(const ValueType &val) const
Self & operator=(const CovariantVector< TCovariantVectorValueType, VVectorDimension > &r)
Self operator/(const Tt &val) const
const Self & operator-=(const Self &vec)
const Self & operator/=(const Tt &value)
static unsigned int GetCovariantVectorDimension()
const Self & operator+=(const Self &vec)
Simulate a standard C array with copy semantics.
A templated class holding a n-Dimensional vector.
constexpr unsigned int Dimension
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
void swap(Array< T > &a, Array< T > &b) noexcept
CovariantVector< T, VVectorDimension > operator*(const T &scalar, const CovariantVector< T, VVectorDimension > &v)
ITKCommon_EXPORT void CrossProduct(CovariantVector< double, 3 > &, const Vector< double, 3 > &, const Vector< double, 3 > &)