LSST Applications g0265f82a02+32fec32616,g0bb0af90fd+f5dc583633,g1e7d6db67d+b5ae400c1a,g1fdc4b6800+6c4785dcad,g26482f50c6+b877b2b840,g2bbee38e9b+32fec32616,g3273194fdb+14984c1173,g36c42b5980+54014c7926,g3eccfa81ec+38f9af2e6a,g4c90b7bd52+7cf7a7847c,g4d318ecf75+22f940484f,g4f7801ab40+32fec32616,g5679e1724d+5b1cbc6d7b,g673ccd32cf+32fec32616,g726579da51+32fec32616,g733a212e47+28ef02efc0,g877625a462+8dbed4964d,g98ffbb4407+8dbed4964d,g9ddcbc5298+d7594c9347,ga1e77700b3+f258a22cbf,ga500d100eb+833bc1611b,gacaae59b5d+0005efa287,gb2715bf1a1+0005efa287,gbac042402a+17dfc79d6b,gbae45e39e2+5e939bd0b5,gc45c8d2e98+a10d610406,gc86a011abf+0005efa287,gcf0d15dbbd+667bae79af,gdaeeff99f8+f78d25140c,gdb4ec4c597+32fec32616,gdc81be3499+0005efa287,ge23793e450+667bae79af,gee31e0d7c8+667bae79af,gf041782ebf+e1018a7e59,w.2023.28
LSST Data Management Base Package
Loading...
Searching...
No Matches
Classes | Namespaces | Macros | Functions | Variables
Angle.h File Reference
#include <cmath>
#include <iostream>
#include <type_traits>
#include "lsst/sphgeom/Angle.h"
#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

namespace  lsst
 
namespace  lsst::geom
 
namespace  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.
 
constexpr Angle lsst::geom::operator- (Angle a, Angle d) noexcept
 Difference of two angles.
 
constexpr Angle lsst::geom::operator* (Angle a, Angle d) noexcept
 Product of two angles.
 
constexpr Angle lsst::geom::operator* (Angle a, double d) noexcept
 Product of an angle and a scalar.
 
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.
 
constexpr Angle lsst::geom::operator/ (Angle a, int d) noexcept
 Ratio of an angle and a scalar.
 
constexpr Angle lsst::geom::operator/ (Angle a, double d) noexcept
 Ratio of an angle and a scalar.
 
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.
 
template<typename T >
constexpr bool lsst::geom::isAngle (T) noexcept
 Allow a user to check if they have an angle.
 
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.
 

Variables

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

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 266 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)); \
}
table::Key< int > a

Definition at line 294 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 301 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 242 of file Angle.h.