LSST Applications g11f7dcd041+3309dba821,g1cd03abf6b+5538b8be6d,g1ce3e0751c+f991eae79d,g28da252d5a+9cd75b2bbf,g2bbee38e9b+b474e213a6,g2bc492864f+b474e213a6,g2cdde0e794+1e3907a55c,g2e95ee2dae+b3f7f8b914,g347aa1857d+b474e213a6,g35bb328faa+b86e4b8053,g3a166c0a6a+b474e213a6,g4322eb9e3a+f7440700bb,g461a3dce89+b86e4b8053,g52b1c1532d+b86e4b8053,g78056777b3+b52dbcd3a1,g858d7b2824+d6777fb84b,g8cd86fa7b1+15b40b54d8,g9ddcbc5298+f24b38b85a,ga61afda322+d6777fb84b,ga68bd05109+bf27b4c466,gae0086650b+b86e4b8053,gbb886bcc26+43b45a029f,gbd462c55f0+538be87034,gc28159a63d+b474e213a6,gc2a6998b7e+f95f64aeae,gc30aee3386+6076c0b52b,gcaf7e4fdec+d6777fb84b,gcd45df26be+d6777fb84b,gcdd4ae20e8+490f2fb51f,gce08ada175+bde66f6e3f,gcf0d15dbbd+490f2fb51f,gdaeeff99f8+006e14e809,gdbce86181e+61a8f2cffc,ge3d4d395c2+5a6209b744,ge77125146a+06b6d19373,ge79ae78c31+b474e213a6,gf048a9a2f4+060b48ea8f,gf9c3535cb8+b86e4b8053,w.2024.28
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)