LSST Applications g06d8191974+b5247657d3,g180d380827+b23588344e,g2079a07aa2+86d27d4dc4,g2305ad1205+0130fb9023,g29320951ab+7714a6b20a,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g33d1c0ed96+0e5473021a,g3a166c0a6a+0e5473021a,g3ddfee87b4+8783ab7716,g48712c4677+72a8b1060b,g487adcacf7+bbaada240a,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+ecccb6240b,g5a732f18d5+53520f316c,g5ea96fc03c+33ab2bc355,g64a986408d+b5247657d3,g858d7b2824+b5247657d3,g8a8a8dda67+585e252eca,g99cad8db69+1453026da9,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,gb0e22166c9+60f28cb32d,gba4ed39666+c2a2e4ac27,gbb8dafda3b+3751ca9c65,gc120e1dc64+c91d1388df,gc28159a63d+0e5473021a,gc3e9b769f7+241adb7c58,gcf0d15dbbd+8783ab7716,gdaeeff99f8+f9a426f77a,ge6526c86ff+acdbe9a537,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gff1a9f87cc+b5247657d3,w.2024.17
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)