LSST Applications g0d97872fb5+4fd969bb9d,g1653933729+34a971ddd9,g28da252d5a+072f89fe25,g2bbee38e9b+a99b0ab4cd,g2bc492864f+a99b0ab4cd,g2ca4be77d2+c0e3b27cd8,g2cdde0e794+704103fe75,g3156d2b45e+6e87dc994a,g347aa1857d+a99b0ab4cd,g35bb328faa+34a971ddd9,g3a166c0a6a+a99b0ab4cd,g3e281a1b8c+8ec26ec694,g4005a62e65+ba0306790b,g414038480c+9ed5ed841a,g569e0e2b34+cb4faa46ad,g5a97de2502+520531a62c,g717e5f8c0f+29153700a5,g7ede599f99+367733290c,g80478fca09+17051a22cc,g82479be7b0+f2f1ea0a87,g858d7b2824+29153700a5,g8b782ad322+29153700a5,g8cd86fa7b1+05420e7f7d,g9125e01d80+34a971ddd9,ga5288a1d22+e7f674aaf3,gae0086650b+34a971ddd9,gae74b0b5c6+45ef5cdc51,gb58c049af0+ace264a4f2,gc28159a63d+a99b0ab4cd,gcf0d15dbbd+8051a81198,gda6a2b7d83+8051a81198,gdaeeff99f8+7774323b41,gdf4d240d4a+34a971ddd9,ge2409df99d+cb167bac99,ge33fd446bb+29153700a5,ge79ae78c31+a99b0ab4cd,gf0baf85859+890af219f9,gf5289d68f6+9faa5c5784,w.2024.36
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Attributes | Protected Member Functions | Protected Attributes | List of all members
lsst::geom::CoordinateBase< Derived, T, 3 > Class Template Reference

Specialization of CoordinateBase for 3 dimensions. More...

#include <CoordinateBase.h>

Public Types

typedef T Element
 
typedef Eigen::Matrix< T, 3, 1, Eigen::DontAlign > EigenVector
 

Public Member Functions

 CoordinateBase (CoordinateBase const &other) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
 CoordinateBase (CoordinateBase &&other) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
CoordinateBaseoperator= (CoordinateBase const &other) noexcept(IS_ELEMENT_NOTHROW_ASSIGNABLE)
 
CoordinateBaseoperator= (CoordinateBase &&other) noexcept(IS_ELEMENT_NOTHROW_ASSIGNABLE)
 
 ~CoordinateBase () noexcept=default
 
T & operator[] (int n)
 
T const & operator[] (int n) const
 
T & coeffRef (int n)
 
T const & coeffRef (int n) const
 
EigenVector const & asEigen () const noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 Return a fixed-size Eigen representation of the coordinate object.
 
T const & getX () const noexcept
 
T const & getY () const noexcept
 
T const & getZ () const noexcept
 
T & getX () noexcept
 
T & getY () noexcept
 
T & getZ () noexcept
 
void setX (T x) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
void setY (T y) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
void setZ (T z) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
std::tuple< T, T, T > asTuple () const noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 Return a std::tuple representation of the coordinate object.
 

Static Public Attributes

static int const dimensions = 3
 
static bool constexpr IS_ELEMENT_NOTHROW_COPYABLE = std::is_nothrow_copy_constructible<T>::value
 
static bool constexpr IS_ELEMENT_NOTHROW_ASSIGNABLE = std::is_nothrow_copy_assignable<T>::value
 

Protected Member Functions

 CoordinateBase (T val=static_cast< T >(0)) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
template<typename Vector >
 CoordinateBase (Eigen::MatrixBase< Vector > const &vector)
 
void _swap (CoordinateBase &other) noexcept
 

Protected Attributes

EigenVector _vector
 

Detailed Description

template<typename Derived, typename T>
class lsst::geom::CoordinateBase< Derived, T, 3 >

Specialization of CoordinateBase for 3 dimensions.

Definition at line 196 of file CoordinateBase.h.

Member Typedef Documentation

◆ EigenVector

template<typename Derived , typename T >
typedef Eigen::Matrix<T, 3, 1, Eigen::DontAlign> lsst::geom::CoordinateBase< Derived, T, 3 >::EigenVector

Definition at line 200 of file CoordinateBase.h.

◆ Element

template<typename Derived , typename T >
typedef T lsst::geom::CoordinateBase< Derived, T, 3 >::Element

Definition at line 198 of file CoordinateBase.h.

Constructor & Destructor Documentation

◆ CoordinateBase() [1/4]

template<typename Derived , typename T >
lsst::geom::CoordinateBase< Derived, T, 3 >::CoordinateBase ( CoordinateBase< Derived, T, 3 > const & other)
inlinenoexcept

Definition at line 205 of file CoordinateBase.h.

206 : _vector(other._vector) {}

◆ CoordinateBase() [2/4]

template<typename Derived , typename T >
lsst::geom::CoordinateBase< Derived, T, 3 >::CoordinateBase ( CoordinateBase< Derived, T, 3 > && other)
inlinenoexcept

Definition at line 207 of file CoordinateBase.h.

208 : _vector(std::move(other._vector)) {}
T move(T... args)

◆ ~CoordinateBase()

template<typename Derived , typename T >
lsst::geom::CoordinateBase< Derived, T, 3 >::~CoordinateBase ( )
defaultnoexcept

◆ CoordinateBase() [3/4]

template<typename Derived , typename T >
lsst::geom::CoordinateBase< Derived, T, 3 >::CoordinateBase ( T val = static_cast<T>(0))
inlineexplicitprotectednoexcept

Definition at line 248 of file CoordinateBase.h.

249 : _vector(EigenVector::Constant(val)) {}
ImageT val
Definition CR.cc:146

◆ CoordinateBase() [4/4]

template<typename Derived , typename T >
template<typename Vector >
lsst::geom::CoordinateBase< Derived, T, 3 >::CoordinateBase ( Eigen::MatrixBase< Vector > const & vector)
inlineexplicitprotected

Definition at line 252 of file CoordinateBase.h.

252: _vector(vector) {}

Member Function Documentation

◆ _swap()

template<typename Derived , typename T >
void lsst::geom::CoordinateBase< Derived, T, 3 >::_swap ( CoordinateBase< Derived, T, 3 > & other)
inlineprotectednoexcept

Definition at line 253 of file CoordinateBase.h.

253{ _vector.swap(other._vector); }

◆ asEigen()

template<typename Derived , typename T >
EigenVector const & lsst::geom::CoordinateBase< Derived, T, 3 >::asEigen ( ) const
inlinenoexcept

Return a fixed-size Eigen representation of the coordinate object.

The fact that this returns by const reference rather than by value should not be considered part of the API; this is merely an optimization enabled by the implementation.

Definition at line 230 of file CoordinateBase.h.

230{ return _vector; }

◆ asTuple()

template<typename Derived , typename T >
std::tuple< T, T, T > lsst::geom::CoordinateBase< Derived, T, 3 >::asTuple ( ) const
inlinenoexcept

Return a std::tuple representation of the coordinate object.

Definition at line 243 of file CoordinateBase.h.

243 {
244 return std::make_tuple(_vector.x(), _vector.y(), _vector.z());
245 }
T make_tuple(T... args)

◆ coeffRef() [1/2]

template<typename Derived , typename T >
T & lsst::geom::CoordinateBase< Derived, T, 3 >::coeffRef ( int n)
inline

Definition at line 221 of file CoordinateBase.h.

221{ return _vector.coeffRef(n); }

◆ coeffRef() [2/2]

template<typename Derived , typename T >
T const & lsst::geom::CoordinateBase< Derived, T, 3 >::coeffRef ( int n) const
inline

Definition at line 222 of file CoordinateBase.h.

222{ return const_cast<EigenVector&>(_vector).coeffRef(n); }
Eigen::Matrix< T, 3, 1, Eigen::DontAlign > EigenVector

◆ getX() [1/2]

template<typename Derived , typename T >
T const & lsst::geom::CoordinateBase< Derived, T, 3 >::getX ( ) const
inlinenoexcept

Definition at line 232 of file CoordinateBase.h.

232{ return _vector.x(); }

◆ getX() [2/2]

template<typename Derived , typename T >
T & lsst::geom::CoordinateBase< Derived, T, 3 >::getX ( )
inlinenoexcept

Definition at line 235 of file CoordinateBase.h.

235{ return _vector.x(); }

◆ getY() [1/2]

template<typename Derived , typename T >
T const & lsst::geom::CoordinateBase< Derived, T, 3 >::getY ( ) const
inlinenoexcept

Definition at line 233 of file CoordinateBase.h.

233{ return _vector.y(); }

◆ getY() [2/2]

template<typename Derived , typename T >
T & lsst::geom::CoordinateBase< Derived, T, 3 >::getY ( )
inlinenoexcept

Definition at line 236 of file CoordinateBase.h.

236{ return _vector.y(); }

◆ getZ() [1/2]

template<typename Derived , typename T >
T const & lsst::geom::CoordinateBase< Derived, T, 3 >::getZ ( ) const
inlinenoexcept

Definition at line 234 of file CoordinateBase.h.

234{ return _vector.z(); }

◆ getZ() [2/2]

template<typename Derived , typename T >
T & lsst::geom::CoordinateBase< Derived, T, 3 >::getZ ( )
inlinenoexcept

Definition at line 237 of file CoordinateBase.h.

237{ return _vector.z(); }

◆ operator=() [1/2]

template<typename Derived , typename T >
CoordinateBase & lsst::geom::CoordinateBase< Derived, T, 3 >::operator= ( CoordinateBase< Derived, T, 3 > && other)
inlinenoexcept

Definition at line 213 of file CoordinateBase.h.

213 {
214 _vector = std::move(other._vector);
215 return *this;
216 }

◆ operator=() [2/2]

template<typename Derived , typename T >
CoordinateBase & lsst::geom::CoordinateBase< Derived, T, 3 >::operator= ( CoordinateBase< Derived, T, 3 > const & other)
inlinenoexcept

Definition at line 209 of file CoordinateBase.h.

209 {
210 _vector = other._vector;
211 return *this;
212 }

◆ operator[]() [1/2]

template<typename Derived , typename T >
T & lsst::geom::CoordinateBase< Derived, T, 3 >::operator[] ( int n)
inline

Definition at line 219 of file CoordinateBase.h.

219{ return _vector[n]; }

◆ operator[]() [2/2]

template<typename Derived , typename T >
T const & lsst::geom::CoordinateBase< Derived, T, 3 >::operator[] ( int n) const
inline

Definition at line 220 of file CoordinateBase.h.

220{ return const_cast<EigenVector&>(_vector)[n]; }

◆ setX()

template<typename Derived , typename T >
void lsst::geom::CoordinateBase< Derived, T, 3 >::setX ( T x)
inlinenoexcept

Definition at line 238 of file CoordinateBase.h.

238{ _vector.x() = x; }

◆ setY()

template<typename Derived , typename T >
void lsst::geom::CoordinateBase< Derived, T, 3 >::setY ( T y)
inlinenoexcept

Definition at line 239 of file CoordinateBase.h.

239{ _vector.y() = y; }
int y
Definition SpanSet.cc:48

◆ setZ()

template<typename Derived , typename T >
void lsst::geom::CoordinateBase< Derived, T, 3 >::setZ ( T z)
inlinenoexcept

Definition at line 240 of file CoordinateBase.h.

240{ _vector.z() = z; }
double z
Definition Match.cc:44

Member Data Documentation

◆ _vector

template<typename Derived , typename T >
EigenVector lsst::geom::CoordinateBase< Derived, T, 3 >::_vector
protected

Definition at line 254 of file CoordinateBase.h.

◆ dimensions

template<typename Derived , typename T >
int const lsst::geom::CoordinateBase< Derived, T, 3 >::dimensions = 3
static

Definition at line 199 of file CoordinateBase.h.

◆ IS_ELEMENT_NOTHROW_ASSIGNABLE

template<typename Derived , typename T >
bool constexpr lsst::geom::CoordinateBase< Derived, T, 3 >::IS_ELEMENT_NOTHROW_ASSIGNABLE = std::is_nothrow_copy_assignable<T>::value
staticconstexpr

Definition at line 202 of file CoordinateBase.h.

◆ IS_ELEMENT_NOTHROW_COPYABLE

template<typename Derived , typename T >
bool constexpr lsst::geom::CoordinateBase< Derived, T, 3 >::IS_ELEMENT_NOTHROW_COPYABLE = std::is_nothrow_copy_constructible<T>::value
staticconstexpr

Definition at line 201 of file CoordinateBase.h.


The documentation for this class was generated from the following file: