LSSTApplications  19.0.0-14-gb0260a2+4cd158d902,20.0.0+126303c00d,20.0.0+2f3d0e5c40,20.0.0+36ef800059,20.0.0+8d0ab3d2aa,20.0.0+bebc1f60e8,20.0.0+e271cb8385,20.0.0+e2e26847c2,20.0.0+eaf69e532d,20.0.0-1-g10df615+d6cc7df41f,20.0.0-1-g253301a+36ef800059,20.0.0-1-g2b7511a+bebc1f60e8,20.0.0-1-g4d801e7+6fee74fd2f,20.0.0-1-g5b95a8c+6c6c03acd5,20.0.0-1-g660595b+f45b7d88f4,20.0.0-1-gc96f8cb+d4517efcba,20.0.0-1-gd1c87d7+85c46248f3,20.0.0-1-gedffbd8+17eaf5db5c,20.0.0-16-g111fe95+d4517efcba,20.0.0-16-g233ea98+c27695f312,20.0.0-17-ga9337b4+cbc55e0393,20.0.0-19-gcdd82e7+317a1f5500,20.0.0-2-g4dae9ad+d4517efcba,20.0.0-2-g7818986+85c46248f3,20.0.0-2-gec03fae+ff10c6d78d,20.0.0-29-g26d13349+2d5e4f2fd7,20.0.0-3-g4cc78c6+63636aeed8,20.0.0-3-g6a8623c+317a1f5500,20.0.0-3-g750bffe+699cb77157,20.0.0-4-gfea843c+f45b7d88f4,20.0.0-5-g357b56b+f45b7d88f4,20.0.0-5-gfcebe35+ef19f498ed,20.0.0-54-gba713e9+a7d430d1e1,20.0.0-7-gcda7bf1+31d79aecbb,20.0.0-9-g61a2a9a3d+14f89e4eca,20.0.0-9-g70cec07d+482e8042f7,w.2020.40
LSSTDataManagementBasePackage
Classes | Namespaces | Macros | Functions | Variables
Angle.h File Reference
#include <cmath>
#include <iostream>
#include <type_traits>
#include "boost/math/constants/constants.hpp"

Go to the source code of this file.

Classes

class  lsst::geom::AngleUnit
 A class used to convert scalar POD types such as double to Angle. More...
 
class  lsst::geom::Angle
 A class representing an angle. More...
 
struct  std::hash< lsst::geom::AngleUnit >
 
struct  std::hash< lsst::geom::Angle >
 

Namespaces

 lsst
 A base class for image defects.
 
 lsst::geom
 
 std
 STL namespace.
 

Macros

#define ANGLE_OPUP_TYPE(OP, TYPE)
 
#define ANGLE_COMP(OP)   constexpr bool operator OP(const Angle& rhs) const noexcept { return _val OP rhs._val; }
 
#define ANGLE_OP(OP)
 
#define ANGLE_OP_TYPE(OP, TYPE)
 

Functions

constexpr double lsst::geom::degToRad (double x) noexcept
 
constexpr double lsst::geom::radToDeg (double x) noexcept
 
constexpr double lsst::geom::radToArcsec (double x) noexcept
 
constexpr double lsst::geom::radToMas (double x) noexcept
 
constexpr double lsst::geom::arcsecToRad (double x) noexcept
 
constexpr double lsst::geom::masToRad (double x) noexcept
 
constexpr Angle lsst::geom::operator+ (Angle a, Angle d) noexcept
 Sum of two angles. More...
 
constexpr Angle lsst::geom::operator- (Angle a, Angle d) noexcept
 Difference of two angles. More...
 
constexpr Angle lsst::geom::operator* (Angle a, Angle d) noexcept
 Product of two angles. More...
 
constexpr Angle lsst::geom::operator* (Angle a, double d) noexcept
 Product of an angle and a scalar. More...
 
constexpr Angle lsst::geom::operator* (double d, Angle a) noexcept
 
constexpr Angle lsst::geom::operator* (Angle a, int d) noexcept
 
constexpr Angle lsst::geom::operator* (int d, Angle a) noexcept
 
constexpr Angle lsst::geom::operator- (Angle angle)
 An angle in the opposite sense. More...
 
constexpr Angle lsst::geom::operator/ (Angle a, int d) noexcept
 Ratio of an angle and a scalar. More...
 
constexpr Angle lsst::geom::operator/ (Angle a, double d) noexcept
 Ratio of an angle and a scalar. More...
 
template<typename T >
constexpr double lsst::geom::operator/ (T const lhs, Angle rhs) noexcept=delete
 
std::ostreamlsst::geom::operator<< (std::ostream &s, Angle a)
 Print an Angle to a stream. More...
 
template<typename T >
constexpr bool lsst::geom::isAngle (T) noexcept
 Allow a user to check if they have an angle. More...
 
template<typename T >
constexpr Angle lsst::geom::operator* (T lhs, AngleUnit rhs) noexcept
 Use AngleUnit to convert a POD (e.g. int, double) to an Angle; e.g. 180*degrees. More...
 

Variables

constexpr double lsst::geom::PI = boost::math::constants::pi<double>()
 The ratio of a circle's circumference to diameter. More...
 
constexpr double lsst::geom::TWOPI = boost::math::constants::pi<double>() * 2.0
 
constexpr double lsst::geom::HALFPI = boost::math::constants::pi<double>() * 0.5
 
constexpr double lsst::geom::ONE_OVER_PI = 1.0 / boost::math::constants::pi<double>()
 
double const lsst::geom::SQRTPI = sqrt(boost::math::constants::pi<double>())
 
double const lsst::geom::INVSQRTPI = 1.0 / sqrt(boost::math::constants::pi<double>())
 
constexpr double lsst::geom::ROOT2 = boost::math::constants::root_two<double>()
 
constexpr AngleUnit lsst::geom::radians = AngleUnit(1.0)
 constant with units of radians More...
 
constexpr AngleUnit lsst::geom::degrees = AngleUnit(PI / 180.0)
 constant with units of degrees More...
 
constexpr AngleUnit lsst::geom::hours = AngleUnit(PI * 15.0 / 180.0)
 constant with units of hours More...
 
constexpr AngleUnit lsst::geom::arcminutes = AngleUnit(PI / 60 / 180.0)
 constant with units of arcminutes More...
 
constexpr AngleUnit lsst::geom::arcseconds = AngleUnit(PI / 180.0 / 3600.0)
 constant with units of arcseconds More...
 
constexpr AngleUnit lsst::geom::milliarcseconds
 constant with units of milliarcseconds More...
 

Macro Definition Documentation

◆ ANGLE_COMP

#define ANGLE_COMP (   OP)    constexpr bool operator OP(const Angle& rhs) const noexcept { return _val OP rhs._val; }

Definition at line 260 of file Angle.h.

◆ ANGLE_OP

#define ANGLE_OP (   OP)
Value:
inline constexpr Angle operator OP(Angle a, Angle d) noexcept { \
return Angle(static_cast<double>(a) OP static_cast<double>(d)); \
}

Definition at line 288 of file Angle.h.

◆ ANGLE_OP_TYPE

#define ANGLE_OP_TYPE (   OP,
  TYPE 
)
Value:
inline constexpr Angle operator OP(Angle a, TYPE d) noexcept { \
return Angle(static_cast<double>(a) OP d); \
} \
\
inline constexpr Angle operator OP(TYPE d, Angle a) noexcept { \
return Angle(d OP static_cast<double>(a)); \
}

Definition at line 295 of file Angle.h.

◆ ANGLE_OPUP_TYPE

#define ANGLE_OPUP_TYPE (   OP,
  TYPE 
)
Value:
Angle& operator OP(TYPE const& d) noexcept { \
_val OP d; \
return *this; \
}

Definition at line 236 of file Angle.h.

lsst::afw::table::Angle
lsst::geom::Angle Angle
Definition: misc.h:33
a
table::Key< int > a
Definition: TransmissionCurve.cc:466