LSSTApplications  18.0.0+67,19.0.0+5,19.0.0+54,19.0.0+57,19.0.0+63,19.0.0+9,19.0.0-1-g20d9b18+23,19.0.0-1-g49a97f9+3,19.0.0-1-g5549ca4+4,19.0.0-1-g8c57eb9+23,19.0.0-1-g8e6e14c+13,19.0.0-1-ga72da6b+3,19.0.0-1-gbfe0924+50,19.0.0-1-ge272bc4+23,19.0.0-1-gefe1d0d+36,19.0.0-11-g57ef05f+1,19.0.0-13-g8db0348+4,19.0.0-14-g706b86db4+1,19.0.0-14-ge428dae,19.0.0-15-g557baf8+8,19.0.0-16-gdc8ce7c+1,19.0.0-2-g0d9f9cd+59,19.0.0-2-g260436e+40,19.0.0-2-g9675b69+3,19.0.0-2-g9b11441+48,19.0.0-2-gde8e5e3+3,19.0.0-2-gf01c5b1+1,19.0.0-2-gff6972b+7,19.0.0-3-g27e4659+25,19.0.0-3-g6513920+52,19.0.0-4-gac56cce+1,19.0.0-41-g13db8fbc+1,19.0.0-43-gbcf6a3c,19.0.0-6-gdd6eb13,19.0.0-7-g686a884+4,19.0.0-9-gce87a591+7,w.2020.14
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:168
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:170
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:171
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:167
table::Key< lsst::geom::Angle > yaw
Definition: Detector.cc:169
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