LSSTApplications  10.0-2-g4f67435,11.0.rc2+1,11.0.rc2+12,11.0.rc2+3,11.0.rc2+4,11.0.rc2+5,11.0.rc2+6,11.0.rc2+7,11.0.rc2+8
LSSTDataManagementBasePackage
SeparableXYTransform.h
Go to the documentation of this file.
1 // -*- lsst-c++ -*-
2 
3 /*
4  * LSST Data Management System
5  * Copyright 2015 LSST Corporation.
6  *
7  * This product includes software developed by the
8  * LSST Project (http://www.lsst.org/).
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the LSST License Statement and
21  * the GNU General Public License along with this program. If not,
22  * see <http://www.lsstcorp.org/LegalNotices/>.
23  */
24 
31 #ifndef LSST_AFW_GEOM_SEPARABLEXYTRANSFORM_H
32 #define LSST_AFW_GEOM_SEPARABLEXYTRANSFORM_H
33 
35 
36 namespace lsst {
37 namespace afw {
38 namespace geom {
39 
40 class Functor;
41 
47 
48 public:
49 
54  SeparableXYTransform(Functor const & xfunctor, Functor const & yfunctor);
55 
56  virtual ~SeparableXYTransform() {}
57 
58  virtual PTR(XYTransform) clone() const;
59 
65  virtual Point2D forwardTransform(Point2D const & point) const;
66 
71  virtual Point2D reverseTransform(Point2D const & point) const;
72 
74  Functor const & getXfunctor() const;
75 
77  Functor const & getYfunctor() const;
78 
79 private:
80 
83 
84 };
85 
86 } // namespace geom
87 } // namespace af
88 } // namespace lsst
89 
90 #endif // LSST_AFW_GEOM_SEPARABLEXYTRANSFORM_H
boost::shared_ptr< Functor > _xfunctor
virtual boost::shared_ptr< XYTransform > clone() const
returns a deep copy
Functor const & getYfunctor() const
#define PTR(...)
Definition: base.h:41
Functor const & getXfunctor() const
SeparableXYTransform(Functor const &xfunctor, Functor const &yfunctor)
A 2D transform for which the pixel distortions in the in the x- and y-directions are separable...
virtual Point2D forwardTransform(Point2D const &point) const
virtual Point2D reverseTransform(Point2D const &point) const
boost::shared_ptr< Functor > _yfunctor
Virtual base class for 2D transforms.
Definition: XYTransform.h:48
Abstract base class for function objects. A default implementation of the inverse(...) member function is provided that computes the inverse of the function using the Newton-Raphson method. Concrete subclasses must therefore implement a derivative(...) member function. In cases where the function is analytically invertible, the inverse(...) function should be re-implemented in the subclass using the analytic expression.
Definition: Functor.h:49
Class representing an invertible 2D transform.