LSST Applications g0265f82a02+c6dfa2ddaf,g2079a07aa2+1b2e822518,g2ab2c8e58b+dcaebcd53c,g2bbee38e9b+c6dfa2ddaf,g337abbeb29+c6dfa2ddaf,g3ddfee87b4+971473b56f,g420f1b9425+9c5d1f27f4,g4770a20bdc+7962a82c67,g50ff169b8f+2eb0e556e8,g52b1c1532d+90ebb246c7,g555ede804d+971473b56f,g591dd9f2cf+601419b17e,g5ec818987f+105adce70b,g858d7b2824+dcaebcd53c,g876c692160+5450b3d607,g8a8a8dda67+90ebb246c7,g8cdfe0ae6a+4fd9e222a8,g99cad8db69+ed556ab06a,g9ddcbc5298+a1346535a5,ga1e77700b3+df8f93165b,ga8c6da7877+e280585b77,gae46bcf261+c6dfa2ddaf,gb0e22166c9+8634eb87fb,gb3f2274832+5f6d78177c,gba4ed39666+1ac82b564f,gbb8dafda3b+d1938d02c0,gbeb006f7da+2258dca5ef,gc28159a63d+c6dfa2ddaf,gc86a011abf+dcaebcd53c,gcf0d15dbbd+971473b56f,gd2a12a3803+6772067a4c,gdaeeff99f8+1cafcb7cd4,ge79ae78c31+c6dfa2ddaf,gee10cc3b42+90ebb246c7,gf1cff7945b+dcaebcd53c,w.2024.14
LSST Data Management Base Package
Loading...
Searching...
No Matches
Orientation.cc
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
25
26namespace lsst {
27namespace afw {
28namespace cameraGeom {
29
33 : _fpPosition(fpPosition), _refPoint(refPoint), _yaw(yaw), _pitch(pitch), _roll(roll), _rotMat() {
34 double cosYaw = std::cos(_yaw);
35 double sinYaw = std::sin(_yaw);
36 double cosPitch = std::cos(_pitch);
37 double sinPitch = std::sin(_pitch);
38 double cosRoll = std::cos(_roll);
39 double sinRoll = std::sin(_roll);
40
41 // This comes from the rotation matrix written down here:
42 // http://en.wikipedia.org/wiki/Euler_angles
43 // for Tait-Bryan angles Z_1Y_2X_3
44 // _rotMat = coeffA coeffB
45 // coeffD coeffE
46 _rotMat << cosYaw * cosPitch, cosYaw * sinPitch * sinRoll - cosRoll * sinYaw, cosPitch * sinYaw,
47 cosYaw * cosRoll + sinYaw * sinPitch * sinRoll;
48}
49
50Orientation::~Orientation() noexcept = default;
51// Can't combine noexcept and =default until Eigen::Matrix supports noexcept
52Orientation::Orientation(Orientation const &other) noexcept
53 : _fpPosition(other._fpPosition),
54 _refPoint(other._refPoint),
55 _yaw(other._yaw),
56 _pitch(other._pitch),
57 _roll(other._roll),
58 _rotMat(other._rotMat) {}
60 : _fpPosition(std::move(other._fpPosition)),
61 _refPoint(std::move(other._refPoint)),
62 _yaw(std::move(other._yaw)),
63 _pitch(std::move(other._pitch)),
64 _roll(std::move(other._roll)),
65 _rotMat(std::move(other._rotMat)) {}
67 _fpPosition = other._fpPosition;
68 _refPoint = other._refPoint;
69 _yaw = other._yaw;
70 _pitch = other._pitch;
71 _roll = other._roll;
72 _rotMat = other._rotMat;
73 return *this;
74}
76 _fpPosition = std::move(other._fpPosition);
77 _refPoint = std::move(other._refPoint);
78 _yaw = std::move(other._yaw);
79 _pitch = std::move(other._pitch);
80 _roll = std::move(other._roll);
81 _rotMat = std::move(other._rotMat);
82 return *this;
83}
84
85int Orientation::getNQuarter() const noexcept {
86 float yawDeg = _yaw.asDegrees();
87 while (yawDeg < 0.) {
88 yawDeg += 360.;
89 }
90 return std::floor((yawDeg + 45.) / 90.);
91}
92
94 lsst::geom::Extent2D const pixelSizeMm) const {
95 // jacobian = coeffA*pixelSizeMmX, coeffB*pixelSizeMmY,
96 // coeffD*pixelSizeMmX, coeffE*pixelSizeMmY
97 Eigen::Matrix2d jacobian =
98 _rotMat.array() * (Eigen::Vector2d::Ones() * pixelSizeMm.asEigen().transpose()).array();
99
100 Eigen::Vector2d refMm = pixelSizeMm.asEigen().array() * _refPoint.asEigen().array();
101 Eigen::Vector2d translation = _fpPosition.asEigen().head<2>() - (_rotMat * refMm);
102
103 lsst::geom::AffineTransform affineTransform = lsst::geom::AffineTransform(jacobian, translation);
104 return afw::geom::makeTransform(affineTransform);
105}
106
111
112} // namespace cameraGeom
113} // namespace afw
114} // namespace lsst
table::Point2DKey refPoint
Definition Detector.cc:169
table::Point3DKey fpPosition
Definition Detector.cc:168
table::Key< lsst::geom::Angle > yaw
Definition Detector.cc:170
table::Key< lsst::geom::Angle > roll
Definition Detector.cc:172
table::Key< lsst::geom::Angle > pitch
Definition Detector.cc:171
Describe a detector's orientation in the focal plane.
Definition Orientation.h:51
Orientation(lsst::geom::Point3D const fpPosition=lsst::geom::Point3D(0, 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))
Orientation & operator=(Orientation const &) noexcept
std::shared_ptr< geom::TransformPoint2ToPoint2 > makePixelFpTransform(lsst::geom::Extent2D const pixelSizeMm) const
Generate a Transform from pixel to focal plane coordinates.
std::shared_ptr< geom::TransformPoint2ToPoint2 > makeFpPixelTransform(lsst::geom::Extent2D const pixelSizeMm) const
Generate a Transform from focal plane to pixel coordinates.
int getNQuarter() const noexcept
Return the number of quarter turns (rounded to the closest quarter)
An affine coordinate transformation consisting of a linear transformation and an offset.
A class representing an angle.
Definition Angle.h:128
constexpr double asDegrees() const noexcept
Return an Angle's value in degrees.
Definition Angle.h:176
EigenVector const & asEigen() const noexcept(IS_ELEMENT_NOTHROW_COPYABLE)
Return a fixed-size Eigen representation of the coordinate object.
A coordinate class intended to represent absolute positions.
Definition Point.h:169
T cos(T... args)
T floor(T... args)
T move(T... args)
std::shared_ptr< TransformPoint2ToPoint2 > makeTransform(lsst::geom::AffineTransform const &affine)
Wrap an lsst::geom::AffineTransform as a Transform.
T sin(T... args)