LSST Applications g063fba187b+eddd1b24d7,g0f08755f38+4a855ab515,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g1a2382251a+062a45aee3,g1dcb35cd9c+45d3fa5522,g20f6ffc8e0+4a855ab515,g217e2c1bcf+f55e51b560,g28da252d5a+7d8e536cc7,g2bbee38e9b+2d92fc7d83,g2bc492864f+2d92fc7d83,g3156d2b45e+6e55a43351,g32e5bea42b+625186cc6b,g347aa1857d+2d92fc7d83,g35bb328faa+a8ce1bb630,g3a166c0a6a+2d92fc7d83,g3e281a1b8c+c5dd892a6c,g3e8969e208+a8ce1bb630,g414038480c+5927e1bc1e,g41af890bb2+1af189bab1,g7af13505b9+7b6a50a2f8,g80478fca09+6174b7f182,g82479be7b0+5b71efbaf0,g858d7b2824+4a855ab515,g9125e01d80+a8ce1bb630,ga5288a1d22+61618a97c4,gb58c049af0+d64f4d3760,gc28159a63d+2d92fc7d83,gc5452a3dca+f4add4ffd5,gcab2d0539d+d9f5af7f69,gcf0d15dbbd+6c7e0a19ec,gda6a2b7d83+6c7e0a19ec,gdaeeff99f8+1711a396fd,ge79ae78c31+2d92fc7d83,gef2f8181fd+55fff6f525,gf0baf85859+c1f95f4921,gfa517265be+4a855ab515,gfa999e8aa5+17cd334064,w.2024.51
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | List of all members
lsst::geom::polynomials::Scaling2d Class Reference

A 2-d separable affine transform that can be used to map one interval to another. More...

#include <Scaling2d.h>

Public Member Functions

 Scaling2d (Scaling1d const &x, Scaling1d const &y) noexcept
 Construct from the given 1-d scalings.
 
 Scaling2d (Scaling2d const &) noexcept=default
 Default copy constructor.
 
 Scaling2d (Scaling2d &&) noexcept=default
 Default move constructor.
 
Scaling2doperator= (Scaling2d const &) noexcept=default
 Default copy assignment.
 
Scaling2doperator= (Scaling2d &&) noexcept=default
 Default move assignment.
 
Scaling1d const & getX () const noexcept
 Return the 1-d scaling in the X direction.
 
Scaling1d const & getY () const noexcept
 Return the 1-d scaling in the Y direction.
 
geom::Point2D applyForward (geom::Point2D const &p) const noexcept
 Apply the transform in the forward direction.
 
geom::Point2D applyInverse (geom::Point2D const &p) const noexcept
 Apply the inverse of the forward transform.
 
Scaling2d inverted () const noexcept
 Invert the transform.
 
Scaling2d then (Scaling2d const &second) const noexcept
 Compose two transforms.
 

Detailed Description

A 2-d separable affine transform that can be used to map one interval to another.

The transform is represented in each dimension as an additive shift followed by a multiplicative scaling. Unlike a full affine transform, Scaling2d cannot include rotations.

Note
This class (and to a lesser extent its 1-d counterpart, Scaling1d) has a lot in common with geom::AffineTransform, and ideally they should share code and be highly interoperable. Doing that well would require a larger-scale rethink of geom, however, and at present we don't actually have a use case for that interoperability, so it's something we should keep in mind for the future, not a high priority for the present.
See also
makeUnitRangeScaling2d

Definition at line 48 of file Scaling2d.h.

Constructor & Destructor Documentation

◆ Scaling2d() [1/3]

lsst::geom::polynomials::Scaling2d::Scaling2d ( Scaling1d const & x,
Scaling1d const & y )
inlinenoexcept

Construct from the given 1-d scalings.

Definition at line 52 of file Scaling2d.h.

52: _x(x), _y(y) {}
int y
Definition SpanSet.cc:48

◆ Scaling2d() [2/3]

lsst::geom::polynomials::Scaling2d::Scaling2d ( Scaling2d const & )
defaultnoexcept

Default copy constructor.

◆ Scaling2d() [3/3]

lsst::geom::polynomials::Scaling2d::Scaling2d ( Scaling2d && )
defaultnoexcept

Default move constructor.

Member Function Documentation

◆ applyForward()

geom::Point2D lsst::geom::polynomials::Scaling2d::applyForward ( geom::Point2D const & p) const
inlinenoexcept

Apply the transform in the forward direction.

Definition at line 73 of file Scaling2d.h.

73 {
74 return geom::Point2D(getX().applyForward(p.getX()), getY().applyForward(p.getY()));
75 }
geom::Point2D applyForward(geom::Point2D const &p) const noexcept
Apply the transform in the forward direction.
Definition Scaling2d.h:73
Scaling1d const & getX() const noexcept
Return the 1-d scaling in the X direction.
Definition Scaling2d.h:67
Scaling1d const & getY() const noexcept
Return the 1-d scaling in the Y direction.
Definition Scaling2d.h:70
Point< double, 2 > Point2D
Definition Point.h:324

◆ applyInverse()

geom::Point2D lsst::geom::polynomials::Scaling2d::applyInverse ( geom::Point2D const & p) const
inlinenoexcept

Apply the inverse of the forward transform.

Definition at line 78 of file Scaling2d.h.

78 {
79 return geom::Point2D(getX().applyInverse(p.getX()), getY().applyInverse(p.getY()));
80 }
geom::Point2D applyInverse(geom::Point2D const &p) const noexcept
Apply the inverse of the forward transform.
Definition Scaling2d.h:78

◆ getX()

Scaling1d const & lsst::geom::polynomials::Scaling2d::getX ( ) const
inlinenoexcept

Return the 1-d scaling in the X direction.

Definition at line 67 of file Scaling2d.h.

67{ return _x; }

◆ getY()

Scaling1d const & lsst::geom::polynomials::Scaling2d::getY ( ) const
inlinenoexcept

Return the 1-d scaling in the Y direction.

Definition at line 70 of file Scaling2d.h.

70{ return _y; }

◆ inverted()

Scaling2d lsst::geom::polynomials::Scaling2d::inverted ( ) const
inlinenoexcept

Invert the transform.

If r = t.inverted(), then r.applyForward(p) is equivalent to t.applyInverse(p) and r.applyInverse(q) is equivalent to t.applyForward(q).

Definition at line 89 of file Scaling2d.h.

89 {
90 return Scaling2d(getX().inverted(), getY().inverted());
91 }
Scaling2d inverted() const noexcept
Invert the transform.
Definition Scaling2d.h:89
Scaling2d(Scaling1d const &x, Scaling1d const &y) noexcept
Construct from the given 1-d scalings.
Definition Scaling2d.h:52

◆ operator=() [1/2]

Scaling2d & lsst::geom::polynomials::Scaling2d::operator= ( Scaling2d && )
defaultnoexcept

Default move assignment.

◆ operator=() [2/2]

Scaling2d & lsst::geom::polynomials::Scaling2d::operator= ( Scaling2d const & )
defaultnoexcept

Default copy assignment.

◆ then()

Scaling2d lsst::geom::polynomials::Scaling2d::then ( Scaling2d const & second) const
inlinenoexcept

Compose two transforms.

If r = a.then(b), then r.applyForward(p) is equivalent to b.applyForward(a.applyForward(p)) and r.applyInverse(q) is equivalent to a.applyInverse(b.applyInverse(q)).

Definition at line 100 of file Scaling2d.h.

100 {
101 return Scaling2d(getX().then(second.getX()), getY().then(second.getY()));
102 }
Scaling2d then(Scaling2d const &second) const noexcept
Compose two transforms.
Definition Scaling2d.h:100

The documentation for this class was generated from the following file: