LSSTApplications  16.0-10-g0ee56ad+5,16.0-11-ga33d1f2+5,16.0-12-g3ef5c14+3,16.0-12-g71e5ef5+18,16.0-12-gbdf3636+3,16.0-13-g118c103+3,16.0-13-g8f68b0a+3,16.0-15-gbf5c1cb+4,16.0-16-gfd17674+3,16.0-17-g7c01f5c+3,16.0-18-g0a50484+1,16.0-20-ga20f992+8,16.0-21-g0e05fd4+6,16.0-21-g15e2d33+4,16.0-22-g62d8060+4,16.0-22-g847a80f+4,16.0-25-gf00d9b8+1,16.0-28-g3990c221+4,16.0-3-gf928089+3,16.0-32-g88a4f23+5,16.0-34-gd7987ad+3,16.0-37-gc7333cb+2,16.0-4-g10fc685+2,16.0-4-g18f3627+26,16.0-4-g5f3a788+26,16.0-5-gaf5c3d7+4,16.0-5-gcc1f4bb+1,16.0-6-g3b92700+4,16.0-6-g4412fcd+3,16.0-6-g7235603+4,16.0-69-g2562ce1b+2,16.0-8-g14ebd58+4,16.0-8-g2df868b+1,16.0-8-g4cec79c+6,16.0-8-gadf6c7a+1,16.0-8-gfc7ad86,16.0-82-g59ec2a54a+1,16.0-9-g5400cdc+2,16.0-9-ge6233d7+5,master-g2880f2d8cf+3,v17.0.rc1
LSSTDataManagementBasePackage
Scaling2d.h
Go to the documentation of this file.
1 // -*- LSST-C++ -*-
2 /*
3  * Developed for the LSST Data Management System.
4  * This product includes software developed by the LSST Project
5  * (https://www.lsst.org).
6  * See the COPYRIGHT file at the top-level directory of this distribution
7  * for details of code ownership.
8  *
9  * This program is free software: you can redistribute it and/or modify
10  * it under the terms of the GNU General Public License as published by
11  * the Free Software Foundation, either version 3 of the License, or
12  * (at your option) any later version.
13  *
14  * This program is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  * GNU General Public License for more details.
18  *
19  * You should have received a copy of the GNU General Public License
20  * along with this program. If not, see <https://www.gnu.org/licenses/>.
21  */
22 #ifndef LSST_AFW_MATH_POLYNOMIALS_Scaling2d_h_INCLUDED
23 #define LSST_AFW_MATH_POLYNOMIALS_Scaling2d_h_INCLUDED
24 
26 #include "lsst/geom/Point.h"
27 #include "lsst/geom/Box.h"
28 
29 namespace lsst { namespace geom { namespace polynomials {
30 
48 class Scaling2d {
49 public:
50 
52  Scaling2d(Scaling1d const & x, Scaling1d const & y) noexcept : _x(x), _y(y) {}
53 
55  Scaling2d(Scaling2d const &) noexcept = default;
56 
58  Scaling2d(Scaling2d &&) noexcept = default;
59 
61  Scaling2d & operator=(Scaling2d const &) noexcept = default;
62 
64  Scaling2d & operator=(Scaling2d &&) noexcept = default;
65 
67  Scaling1d const & getX() const noexcept { return _x; }
68 
70  Scaling1d const & getY() const noexcept { return _y; }
71 
73  geom::Point2D applyForward(geom::Point2D const & p) const noexcept {
74  return geom::Point2D(getX().applyForward(p.getX()), getY().applyForward(p.getY()));
75  }
76 
78  geom::Point2D applyInverse(geom::Point2D const & p) const noexcept {
79  return geom::Point2D(getX().applyInverse(p.getX()), getY().applyInverse(p.getY()));
80  }
81 
89  Scaling2d inverted() const noexcept {
90  return Scaling2d(getX().inverted(), getY().inverted());
91  }
92 
100  Scaling2d then(Scaling2d const & second) const noexcept {
101  return Scaling2d(getX().then(second.getX()), getY().then(second.getY()));
102  }
103 
104 private:
105  Scaling1d _x;
106  Scaling1d _y;
107 };
108 
113  return Scaling2d(
114  makeUnitRangeScaling1d(box.getMinX(), box.getMaxX()),
116  );
117 }
118 
119 }}} // namespace lsst::geom::polynomials
120 
121 #endif // !LSST_AFW_MATH_POLYNOMIALS_Scaling2d_h_INCLUDED
Scaling1d const & getY() const noexcept
Return the 1-d scaling in the Y direction.
Definition: Scaling2d.h:70
double getMinY() const noexcept
Definition: Box.h:384
A floating-point coordinate rectangle geometry.
Definition: Box.h:294
double getMinX() const noexcept
Definition: Box.h:383
int y
Definition: SpanSet.cc:49
double getMaxX() const noexcept
Definition: Box.h:387
Scaling2d inverted() const noexcept
Invert the transform.
Definition: Scaling2d.h:89
Scaling2d & operator=(Scaling2d const &) noexcept=default
Default copy assignment.
Point< double, 2 > Point2D
Definition: Point.h:324
double applyInverse(double y) const noexcept
Apply the inverse of the forward transform;.
Definition: Scaling1d.h:79
double getMaxY() const noexcept
Definition: Box.h:388
A 2-d separable affine transform that can be used to map one interval to another. ...
Definition: Scaling2d.h:48
A base class for image defects.
geom::Point2D applyInverse(geom::Point2D const &p) const noexcept
Apply the inverse of the forward transform.
Definition: Scaling2d.h:78
Scaling1d makeUnitRangeScaling1d(double min, double max) noexcept
Return a Scaling1d that maps the interval [min, max] to [-1, 1].
Definition: Scaling1d.h:120
double applyForward(double x) const noexcept
Apply the transform in the forward direction.
Definition: Scaling1d.h:72
double x
Scaling2d then(Scaling2d const &second) const noexcept
Compose two transforms.
Definition: Scaling2d.h:100
Scaling2d(Scaling1d const &x, Scaling1d const &y) noexcept
Construct from the given 1-d scalings.
Definition: Scaling2d.h:52
geom::Point2D applyForward(geom::Point2D const &p) const noexcept
Apply the transform in the forward direction.
Definition: Scaling2d.h:73
Scaling2d makeUnitRangeScaling2d(geom::Box2D const &box)
Return a Scaling1d that maps the given box to [-1, 1]x[-1, 1].
Definition: Scaling2d.h:112
A 1-d affine transform that can be used to map one interval to another.
Definition: Scaling1d.h:46
Scaling1d then(Scaling1d const &second) const noexcept
Compose two transforms.
Definition: Scaling1d.h:107
Scaling1d const & getX() const noexcept
Return the 1-d scaling in the X direction.
Definition: Scaling2d.h:67