LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+f5e6047307,21.0.0-11-g2b59f77+a9c1acf22d,21.0.0-11-ga42c5b2+86977b0b17,21.0.0-12-gf4ce030+76814010d2,21.0.0-13-g1721dae+760e7a6536,21.0.0-13-g3a573fe+768d78a30a,21.0.0-15-g5a7caf0+f21cbc5713,21.0.0-16-g0fb55c1+b60e2d390c,21.0.0-19-g4cded4ca+71a93a33c0,21.0.0-2-g103fe59+bb20972958,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+3ad5d60fb1,21.0.0-2-g7f82c8f+8babb168e8,21.0.0-2-g8f08a60+06509c8b61,21.0.0-2-g8faa9b5+616205b9df,21.0.0-2-ga326454+8babb168e8,21.0.0-2-gde069b7+5e4aea9c2f,21.0.0-2-gecfae73+1d3a86e577,21.0.0-2-gfc62afb+3ad5d60fb1,21.0.0-25-g1d57be3cd+e73869a214,21.0.0-3-g357aad2+ed88757d29,21.0.0-3-g4a4ce7f+3ad5d60fb1,21.0.0-3-g4be5c26+3ad5d60fb1,21.0.0-3-g65f322c+e0b24896a3,21.0.0-3-g7d9da8d+616205b9df,21.0.0-3-ge02ed75+a9c1acf22d,21.0.0-4-g591bb35+a9c1acf22d,21.0.0-4-g65b4814+b60e2d390c,21.0.0-4-gccdca77+0de219a2bc,21.0.0-4-ge8a399c+6c55c39e83,21.0.0-5-gd00fb1e+05fce91b99,21.0.0-6-gc675373+3ad5d60fb1,21.0.0-64-g1122c245+4fb2b8f86e,21.0.0-7-g04766d7+cd19d05db2,21.0.0-7-gdf92d54+04719a4bac,21.0.0-8-g5674e7b+d1bd76f71f,master-gac4afde19b+a9c1acf22d,w.2021.13
LSST Data Management Base Package
Public Types | Public Member Functions | Static Public Attributes | Protected Member Functions | Protected Attributes | List of all members
lsst::geom::CoordinateBase< Derived, T, 2 > Class Template Reference

Specialization of CoordinateBase for 2 dimensions. More...

#include <CoordinateBase.h>

Public Types

typedef T Element
 
typedef Eigen::Matrix< T, 2, 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. More...
 
T const & getX () const noexcept
 
T const & getY () const noexcept
 
T & getX () noexcept
 
T & getY () noexcept
 
void setX (T x) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
void setY (T y) noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 
std::pair< T, T > asPair () const noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 Return a std::pair representation of the coordinate object. More...
 
std::tuple< T, T > asTuple () const noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
 Return a std::tuple representation of the coordinate object. More...
 

Static Public Attributes

static int const dimensions = 2
 
static constexpr bool IS_ELEMENT_NOTHROW_COPYABLE = std::is_nothrow_copy_constructible<T>::value
 
static constexpr bool 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, 2 >

Specialization of CoordinateBase for 2 dimensions.

Definition at line 129 of file CoordinateBase.h.

Member Typedef Documentation

◆ EigenVector

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

Definition at line 133 of file CoordinateBase.h.

◆ Element

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

Definition at line 131 of file CoordinateBase.h.

Constructor & Destructor Documentation

◆ CoordinateBase() [1/4]

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

Definition at line 138 of file CoordinateBase.h.

139  : _vector(other._vector) {}
ItemVariant const * other
Definition: Schema.cc:56

◆ CoordinateBase() [2/4]

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

Definition at line 140 of file CoordinateBase.h.

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

◆ ~CoordinateBase()

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

◆ CoordinateBase() [3/4]

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

Definition at line 183 of file CoordinateBase.h.

184  : _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, 2 >::CoordinateBase ( Eigen::MatrixBase< Vector > const &  vector)
inlineexplicitprotected

Definition at line 187 of file CoordinateBase.h.

187 : _vector(vector) {}

Member Function Documentation

◆ _swap()

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

Definition at line 188 of file CoordinateBase.h.

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

◆ asEigen()

template<typename Derived , typename T >
EigenVector const& lsst::geom::CoordinateBase< Derived, T, 2 >::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 163 of file CoordinateBase.h.

163 { return _vector; }

◆ asPair()

template<typename Derived , typename T >
std::pair<T, T> lsst::geom::CoordinateBase< Derived, T, 2 >::asPair ( ) const
inlinenoexcept

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

Definition at line 173 of file CoordinateBase.h.

173  {
174  return std::make_pair(_vector.x(), _vector.y());
175  }
T make_pair(T... args)

◆ asTuple()

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

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

Definition at line 178 of file CoordinateBase.h.

178  {
179  return std::make_tuple(_vector.x(), _vector.y());
180  }
T make_tuple(T... args)

◆ coeffRef() [1/2]

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

Definition at line 154 of file CoordinateBase.h.

154 { return _vector.coeffRef(n); }

◆ coeffRef() [2/2]

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

Definition at line 155 of file CoordinateBase.h.

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

◆ getX() [1/2]

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

Definition at line 165 of file CoordinateBase.h.

165 { return _vector.x(); }

◆ getX() [2/2]

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

Definition at line 167 of file CoordinateBase.h.

167 { return _vector.x(); }

◆ getY() [1/2]

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

Definition at line 166 of file CoordinateBase.h.

166 { return _vector.y(); }

◆ getY() [2/2]

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

Definition at line 168 of file CoordinateBase.h.

168 { return _vector.y(); }

◆ operator=() [1/2]

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

Definition at line 146 of file CoordinateBase.h.

146  {
147  _vector = std::move(other._vector);
148  return *this;
149  }

◆ operator=() [2/2]

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

Definition at line 142 of file CoordinateBase.h.

142  {
143  _vector = other._vector;
144  return *this;
145  }

◆ operator[]() [1/2]

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

Definition at line 152 of file CoordinateBase.h.

152 { return _vector[n]; }

◆ operator[]() [2/2]

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

Definition at line 153 of file CoordinateBase.h.

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

◆ setX()

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

Definition at line 169 of file CoordinateBase.h.

169 { _vector.x() = x; }
double x

◆ setY()

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

Definition at line 170 of file CoordinateBase.h.

170 { _vector.y() = y; }
int y
Definition: SpanSet.cc:49

Member Data Documentation

◆ _vector

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

Definition at line 189 of file CoordinateBase.h.

◆ dimensions

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

Definition at line 132 of file CoordinateBase.h.

◆ IS_ELEMENT_NOTHROW_ASSIGNABLE

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

Definition at line 135 of file CoordinateBase.h.

◆ IS_ELEMENT_NOTHROW_COPYABLE

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

Definition at line 134 of file CoordinateBase.h.


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