LSSTApplications  21.0.0+75b29a8a7f,21.0.0+e70536a077,21.0.0-1-ga51b5d4+62c747d40b,21.0.0-11-ga6ea59e8e+47cba9fc36,21.0.0-2-g103fe59+914993bf7c,21.0.0-2-g1367e85+e2614ded12,21.0.0-2-g45278ab+e70536a077,21.0.0-2-g4bc9b9f+7b2b5f8678,21.0.0-2-g5242d73+e2614ded12,21.0.0-2-g54e2caa+6403186824,21.0.0-2-g7f82c8f+3ac4acbffc,21.0.0-2-g8dde007+04a6aea1af,21.0.0-2-g8f08a60+9402881886,21.0.0-2-ga326454+3ac4acbffc,21.0.0-2-ga63a54e+81dd751046,21.0.0-2-gc738bc1+5f65c6e7a9,21.0.0-2-gde069b7+26c92b3210,21.0.0-2-gecfae73+0993ddc9bd,21.0.0-2-gfc62afb+e2614ded12,21.0.0-21-gba890a8+5a4f502a26,21.0.0-23-g9966ff26+03098d1af8,21.0.0-3-g357aad2+8ad216c477,21.0.0-3-g4be5c26+e2614ded12,21.0.0-3-g6d51c4a+4d2fe0280d,21.0.0-3-g7d9da8d+75b29a8a7f,21.0.0-3-gaa929c8+522e0f12c2,21.0.0-3-ge02ed75+4d2fe0280d,21.0.0-4-g3300ddd+e70536a077,21.0.0-4-gc004bbf+eac6615e82,21.0.0-4-gccdca77+f94adcd104,21.0.0-4-gd1c1571+18b81799f9,21.0.0-5-g7b47fff+4d2fe0280d,21.0.0-5-gb155db7+d2632f662b,21.0.0-5-gdf36809+637e4641ee,21.0.0-6-g722ad07+28c848f42a,21.0.0-7-g959bb79+522e0f12c2,21.0.0-7-gfd72ab2+cf01990774,21.0.0-9-g87fb7b8d+e2ab11cdd6,w.2021.04
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
lsst::geom::Point2D
Point< double, 2 > Point2D
Definition: Point.h:324
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
lsst::afw::cameraGeom::Orientation::getReferencePoint
lsst::geom::Point2D getReferencePoint() const noexcept
Return detector reference point (pixels)
Definition: Orientation.h:78
Transform.h
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
Utils.h
lsst::geom
Definition: AffineTransform.h:36
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
geom.h