LSST Applications g00274db5b6+edbf708997,g00d0e8bbd7+edbf708997,g199a45376c+5137f08352,g1fd858c14a+1d4b6db739,g262e1987ae+f4d9505c4f,g29ae962dfc+7156fb1a53,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3e17d7035e+5b3adc59f5,g3fd5ace14f+852fa6fbcb,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+9f17e571f4,g67b6fd64d1+6dc8069a4c,g74acd417e5+ae494d68d9,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+536efcc10a,g7cc15d900a+d121454f8d,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d7436a09f+28c28d8d6d,g8ea07a8fe4+db21c37724,g92c671f44c+9f17e571f4,g98df359435+b2e6376b13,g99af87f6a8+b0f4ad7b8d,gac66b60396+966efe6077,gb88ae4c679+7dec8f19df,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gc24b5d6ed1+9f17e571f4,gca7fc764a6+6dc8069a4c,gcc769fe2a4+97d0256649,gd7ef33dd92+6dc8069a4c,gdab6d2f7ff+ae494d68d9,gdbb4c4dda9+9f17e571f4,ge410e46f29+6dc8069a4c,geaed405ab2+e194be0d2b,w.2025.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
ProperMotion.h
Go to the documentation of this file.
1// -*- LSST-C++ -*-
2/*
3 * This file is part of jointcal.
4 *
5 * Developed for the LSST Data Management System.
6 * This product includes software developed by the LSST Project
7 * (https://www.lsst.org).
8 * See the COPYRIGHT file at the top-level directory of this distribution
9 * for details of code ownership.
10 *
11 * This program is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation, either version 3 of the License, or
14 * (at your option) any later version.
15 *
16 * This program is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
20 *
21 * You should have received a copy of the GNU General Public License
22 * along with this program. If not, see <https://www.gnu.org/licenses/>.
23 */
24
25#ifndef LSST_JOINTCAL_PROPER_MOTION_H
26#define LSST_JOINTCAL_PROPER_MOTION_H
27
28#include <cmath> // atan2
29#include <iostream>
30#include <memory>
31
32namespace lsst {
33namespace jointcal {
34
35class Point;
36
46public:
47 ProperMotion(double ra, double dec, double raErr, double decErr, double raDecCov = 0)
48 : _ra(ra), _dec(dec), _raErr(raErr), _decErr(decErr), _raDecCov(raDecCov) {
49 _offsetBearing = atan2(dec, ra);
50 };
51
52 ProperMotion(ProperMotion const &) = default;
54 ProperMotion &operator=(ProperMotion const &) = default;
56 ~ProperMotion() = default;
57
68 Point apply(const Point& star, double timeDeltaYears) const;
69
70 friend std::ostream &operator<<(std::ostream &stream, ProperMotion const &pm);
71
72private:
73 // Proper motion in ra and dec. Units are radians/year
74 double _ra, _dec;
75 double _raErr, _decErr, _raDecCov;
76
77 // Cache the bearing along-which to offset.
78 double _offsetBearing;
79};
80} // namespace jointcal
81} // namespace lsst
82
83#endif // LSST_JOINTCAL_PROPER_MOTION_H
T atan2(T... args)
A point in a plane.
Definition Point.h:37
ProperMotion & operator=(ProperMotion &&)=default
Point apply(const Point &star, double timeDeltaYears) const
Apply proper motion correction to the input star, returning a star with PM-corrected coordinates.
ProperMotion(double ra, double dec, double raErr, double decErr, double raDecCov=0)
ProperMotion & operator=(ProperMotion const &)=default
ProperMotion(ProperMotion &&)=default
friend std::ostream & operator<<(std::ostream &stream, ProperMotion const &pm)
ProperMotion(ProperMotion const &)=default
T dec(T... args)