LSST Applications  21.0.0+04719a4bac,21.0.0-1-ga51b5d4+ae94e5adf4,21.0.0-10-g2408eff+ad7fe00a3b,21.0.0-10-g560fb7b+5d30037bff,21.0.0-10-gcf60f90+7fd8e8fd04,21.0.0-11-g25eff31+491f1498e8,21.0.0-11-gd78879e+d13a45ff19,21.0.0-12-g1e69a3f+69d54d99d8,21.0.0-17-g6590b197+c8c705a94e,21.0.0-2-g103fe59+29086b68f8,21.0.0-2-g1367e85+d793a9824f,21.0.0-2-g45278ab+04719a4bac,21.0.0-2-g5242d73+d793a9824f,21.0.0-2-g7f82c8f+7178d1fb8b,21.0.0-2-g8f08a60+fd0b970de5,21.0.0-2-g8faa9b5+3b24369756,21.0.0-2-ga326454+7178d1fb8b,21.0.0-2-gde069b7+ca45a81b40,21.0.0-2-gecfae73+3609a557ba,21.0.0-2-gfc62afb+d793a9824f,21.0.0-22-g2a5702db6+f385fa6f38,21.0.0-3-g357aad2+673ab9f056,21.0.0-3-g4be5c26+d793a9824f,21.0.0-3-g65f322c+45176dc65e,21.0.0-3-g7d9da8d+3b24369756,21.0.0-3-ge02ed75+d05e6d1be4,21.0.0-4-g591bb35+d05e6d1be4,21.0.0-4-g65b4814+5d30037bff,21.0.0-4-gccdca77+a631590478,21.0.0-4-ge8a399c+7f1b116a8b,21.0.0-5-gb7b9a9f+d793a9824f,21.0.0-5-gd00fb1e+de3bd29da1,21.0.0-55-g0be6b205+66ae927d20,21.0.0-6-g2d4f3f3+04719a4bac,21.0.0-7-g04766d7+510a52a951,21.0.0-7-g98eecf7+adb4d61a8d,21.0.0-9-g39e06b5+d05e6d1be4,master-gac4afde19b+d05e6d1be4,w.2021.12
LSST Data Management Base Package
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 
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
Describe a detector's orientation in the focal plane.
Definition: Orientation.h:52
lsst::geom::Point2D getReferencePoint() const noexcept
Return detector reference point (pixels)
Definition: Orientation.h:78
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
lsst::geom::Angle getPitch() const noexcept
Return the pitch angle.
Definition: Orientation.h:84
lsst::geom::Angle getYaw() const noexcept
Return the yaw angle.
Definition: Orientation.h:81
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
lsst::geom::Point2D getFpPosition() const noexcept
Return focal plane position of detector reference point (mm)
Definition: Orientation.h:75
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
int getNQuarter() const noexcept
Return the number of quarter turns (rounded to the closest quarter)
Definition: Orientation.cc:85
lsst::geom::Angle getRoll() const noexcept
Return the roll angle.
Definition: Orientation.h:87
A class representing an angle.
Definition: Angle.h:127
Transform< Point2Endpoint, Point2Endpoint > TransformPoint2ToPoint2
Definition: Transform.h:300
class[[deprecated("Removed with no replacement (but see lsst::afw::image::TransmissionCurve). Will be " "removed after v22.")]] FilterProperty final
Describe the properties of a Filter (e.g.
Definition: Filter.h:53
lsst::geom::Angle Angle
Definition: misc.h:33
Extent< double, 2 > Extent2D
Definition: Extent.h:400
Point< double, 2 > Point2D
Definition: Point.h:324
Eigen::Matrix< Scalar, Eigen::Dynamic, Eigen::Dynamic > Matrix
Definition: common.h:45
A base class for image defects.
STL namespace.
table::Point2DKey refPoint
Definition: Detector.cc:168
table::Key< lsst::geom::Angle > yaw
Definition: Detector.cc:169
table::Key< lsst::geom::Angle > roll
Definition: Detector.cc:171
table::Point2DKey fpPosition
Definition: Detector.cc:167
table::Key< lsst::geom::Angle > pitch
Definition: Detector.cc:170