LSST Applications g0265f82a02+e0119c8a10,g1e7d6db67d+8a13ff89d9,g26482f50c6+d5a636daa0,g2bbee38e9b+e0119c8a10,g2cc88a2952+aeaaabe67b,g3273194fdb+78f48b10ca,g35da1f9f46+e724663f17,g374be3e903+53a873df59,g3eccfa81ec+5fd6494a32,g4c90b7bd52+c6585dc629,g5e83b0b6c4+53a873df59,g669dc769c9+049746c1eb,g726579da51+e0119c8a10,g733a212e47+bfb0567752,g81e08b039b+832f198409,g877625a462+434c804113,g90805c0507+fb0117aa65,g93c4d6e787+be99d1f45c,g98ffbb4407+434c804113,g9ddcbc5298+7684e62712,ga1e77700b3+834140c74f,ga79a28c7a9+8ec653cd9e,gae46bcf261+e0119c8a10,gb2715bf1a1+53a873df59,gbae45e39e2+5da6e07588,gc45c8d2e98+c47d166095,gc86a011abf+53a873df59,gcf0d15dbbd+832f198409,gdaeeff99f8+452a7372b1,gdb4ec4c597+e0119c8a10,ge23793e450+832f198409,gf041782ebf+2f66163b1a,gf3487cfe8b+e0119c8a10,gfd4c4674e9+1ace8a3221,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.