LSSTApplications  20.0.0
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
fpPosition
table::Point2DKey fpPosition
Definition: Detector.cc:167
lsst::afw::cameraGeom::Orientation::makePixelFpTransform
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::afw::cameraGeom::Orientation::getPitch
lsst::geom::Angle getPitch() const noexcept
Return the pitch angle.
Definition: Orientation.h:84
yaw
table::Key< lsst::geom::Angle > yaw
Definition: Detector.cc:169
lsst::afw
Definition: imageAlgorithm.dox:1
lsst::afw::cameraGeom::Orientation::getYaw
lsst::geom::Angle getYaw() const noexcept
Return the yaw angle.
Definition: Orientation.h:81
lsst::afw::cameraGeom::Orientation::Orientation
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
geom.h
lsst::geom::Point2D
Point< double, 2 > Point2D
Definition: Point.h:324
Transform.h
roll
table::Key< lsst::geom::Angle > roll
Definition: Detector.cc:171
lsst::afw::cameraGeom::Orientation::makeFpPixelTransform
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
lsst::afw::table::Angle
lsst::geom::Angle Angle
Definition: misc.h:33
Utils.h
lsst::afw::cameraGeom::Orientation::getReferencePoint
lsst::geom::Point2D getReferencePoint() const noexcept
Return detector reference point (pixels)
Definition: Orientation.h:78
lsst::afw::geom::TransformPoint2ToPoint2
Transform< Point2Endpoint, Point2Endpoint > TransformPoint2ToPoint2
Definition: Transform.h:300
lsst::afw::cameraGeom::Orientation::~Orientation
~Orientation() noexcept
refPoint
table::Point2DKey refPoint
Definition: Detector.cc:168
lsst
A base class for image defects.
Definition: imageAlgorithm.dox:1
lsst::afw::cameraGeom::Orientation
Describe a detector's orientation in the focal plane.
Definition: Orientation.h:52
lsst::meas::modelfit::Matrix
Eigen::Matrix< Scalar, Eigen::Dynamic, Eigen::Dynamic > Matrix
Definition: common.h:45
lsst::geom
Definition: geomOperators.dox:4
std
STL namespace.
lsst::afw::cameraGeom::Orientation::getNQuarter
int getNQuarter() const noexcept
Return the number of quarter turns (rounded to the closest quarter)
Definition: Orientation.cc:85
lsst::geom::Point< double, 2 >
lsst::geom::Angle
A class representing an angle.
Definition: Angle.h:127
lsst::geom::Extent2D
Extent< double, 2 > Extent2D
Definition: Extent.h:400
pitch
table::Key< lsst::geom::Angle > pitch
Definition: Detector.cc:170
lsst::afw::cameraGeom::Orientation::getFpPosition
lsst::geom::Point2D getFpPosition() const noexcept
Return focal plane position of detector reference point (mm)
Definition: Orientation.h:75
lsst::afw::cameraGeom::Orientation::getRoll
lsst::geom::Angle getRoll() const noexcept
Return the roll angle.
Definition: Orientation.h:87