LSSTApplications  17.0+50,17.0+84,17.0+9,18.0.0+14,18.0.0+2,18.0.0+30,18.0.0+4,18.0.0+9,18.0.0-2-ge43143a+4,18.1.0-1-g0001055,18.1.0-1-g0896a44+6,18.1.0-1-g1349e88+4,18.1.0-1-g2505f39+3,18.1.0-1-g380d4d4+4,18.1.0-1-g5e4b7ea,18.1.0-1-g85f8cd4+3,18.1.0-1-g9a6769a+2,18.1.0-1-ga1a4c1a+2,18.1.0-1-gc037db8,18.1.0-1-gd55f500+1,18.1.0-1-ge10677a+3,18.1.0-10-g73b8679e+7,18.1.0-11-g311e899+3,18.1.0-12-g0d73a3591,18.1.0-12-gc95f69a+3,18.1.0-2-g000ad9a+3,18.1.0-2-g31c43f9+3,18.1.0-2-g9c63283+4,18.1.0-2-gdf0b915+4,18.1.0-2-gf03bb23,18.1.0-3-g2e29e3d+6,18.1.0-3-g52aa583+2,18.1.0-3-g9cb968e+3,18.1.0-4-gd2e8982+6,18.1.0-5-g510c42a+3,18.1.0-5-gaeab27e+4,18.1.0-6-gdda7f3e+6,18.1.0-7-g89824ecc+4,w.2019.32
LSSTDataManagementBasePackage
Orientation.h
Go to the documentation of this file.
1 /*
2  * LSST Data Management System
3  * Copyright 2008, 2009, 2010, 2011, 2012, 2013, 2014 LSST Corporation.
4  *
5  * This product includes software developed by the
6  * LSST Project (http://www.lsst.org/).
7  *
8  * This program is free software: you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation, either version 3 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the LSST License Statement and
19  * the GNU General Public License along with this program. If not,
20  * see <http://www.lsstcorp.org/LegalNotices/>.
21  */
22 
23 #if !defined(LSST_AFW_CAMERAGEOM_ORIENTATION_H)
24 #define LSST_AFW_CAMERAGEOM_ORIENTATION_H
25 
26 #include <string>
27 #include <cmath>
28 #include "Eigen/Dense"
29 #include "lsst/geom.h"
31 #include "lsst/afw/image/Utils.h"
32 
33 /*
34  * Describe a Detector's orientation
35  */
36 namespace lsst {
37 namespace afw {
38 namespace cameraGeom {
39 
52 class Orientation final {
53 public:
60  lsst::geom::Angle const yaw =
63  0),
65  0)
66  );
67 
68  ~Orientation() noexcept;
69  Orientation(Orientation const &) noexcept;
70  Orientation(Orientation &&) noexcept;
71  Orientation &operator=(Orientation const &) noexcept;
72  Orientation &operator=(Orientation &&) noexcept;
73 
75  lsst::geom::Point2D getFpPosition() const noexcept { return _fpPosition; }
76 
78  lsst::geom::Point2D getReferencePoint() const noexcept { return _refPoint; }
79 
81  lsst::geom::Angle getYaw() const noexcept { return _yaw; }
82 
84  lsst::geom::Angle getPitch() const noexcept { return _pitch; }
85 
87  lsst::geom::Angle getRoll() const noexcept { return _roll; }
88 
90  int getNQuarter() const noexcept;
91 
98  lsst::geom::Extent2D const pixelSizeMm
99  ) const;
100 
107  lsst::geom::Extent2D const pixelSizeMm
108  ) const;
109 
110 private:
111  lsst::geom::Point2D _fpPosition;
112  lsst::geom::Point2D _refPoint;
113 
114  lsst::geom::Angle _yaw;
115  lsst::geom::Angle _pitch;
116  lsst::geom::Angle _roll;
117 
118  // Elements of the Jacobian for three space rotation projected into XY plane.
119  // Turn off alignment since this is dynamically allocated (via Detector)
120  Eigen::Matrix<double, 2, 2, Eigen::DontAlign> _rotMat;
121 };
122 } // namespace cameraGeom
123 } // namespace afw
124 } // namespace lsst
125 
126 #endif
lsst::geom::Point2D getFpPosition() const noexcept
Return focal plane position of detector reference point (mm)
Definition: Orientation.h:75
lsst::geom::Angle getRoll() const noexcept
Return the roll angle.
Definition: Orientation.h:87
std::shared_ptr< geom::TransformPoint2ToPoint2 > makePixelFpTransform(lsst::geom::Extent2D const pixelSizeMm) const
Generate a Transform from pixel to focal plane coordinates.
Definition: Orientation.cc:93
table::Point2DKey refPoint
Definition: Detector.cc:172
std::shared_ptr< geom::TransformPoint2ToPoint2 > makeFpPixelTransform(lsst::geom::Extent2D const pixelSizeMm) const
Generate a Transform from focal plane to pixel coordinates.
Definition: Orientation.cc:107
A class representing an angle.
Definition: Angle.h:127
Describe a detector&#39;s orientation in the focal plane.
Definition: Orientation.h:52
table::Key< lsst::geom::Angle > pitch
Definition: Detector.cc:174
A base class for image defects.
int getNQuarter() const noexcept
Return the number of quarter turns (rounded to the closest quarter)
Definition: Orientation.cc:85
table::Key< lsst::geom::Angle > roll
Definition: Detector.cc:175
Orientation(lsst::geom::Point2D const fpPosition=lsst::geom::Point2D(0, 0), lsst::geom::Point2D const refPoint=lsst::geom::Point2D(-0.5, -0.5), lsst::geom::Angle const yaw=lsst::geom::Angle(0), lsst::geom::Angle const pitch=lsst::geom::Angle(0), lsst::geom::Angle const roll=lsst::geom::Angle(0))
Definition: Orientation.cc:30
Orientation & operator=(Orientation const &) noexcept
Definition: Orientation.cc:66
table::Point2DKey fpPosition
Definition: Detector.cc:171
table::Key< lsst::geom::Angle > yaw
Definition: Detector.cc:173
lsst::geom::Angle getPitch() const noexcept
Return the pitch angle.
Definition: Orientation.h:84
lsst::geom::Point2D getReferencePoint() const noexcept
Return detector reference point (pixels)
Definition: Orientation.h:78
lsst::geom::Angle getYaw() const noexcept
Return the yaw angle.
Definition: Orientation.h:81