LSSTApplications  18.1.0
LSSTDataManagementBasePackage
Public Types | Public Member Functions | Public Attributes | List of all members
lsst::afw::geom::ellipses::BaseCore::Convolution Class Referencefinal

A temporary-only expression object for ellipse core convolution. More...

#include <Convolution.h>

Public Types

typedef Eigen::Matrix3d DerivativeMatrix
 Matrix type for derivative with respect to input ellipse parameters. More...
 

Public Member Functions

 Convolution (BaseCore &self, BaseCore const &other)
 Standard constructor. More...
 
std::shared_ptr< BaseCorecopy () const
 Return a new convolved ellipse core. More...
 
void inPlace ()
 Convolve the ellipse core in-place. More...
 
DerivativeMatrix d () const
 Return the derivative of convolved core with respect to self. More...
 
void apply (BaseCore &result) const
 

Public Attributes

BaseCoreself
 
BaseCore const & other
 

Detailed Description

A temporary-only expression object for ellipse core convolution.

Definition at line 46 of file Convolution.h.

Member Typedef Documentation

◆ DerivativeMatrix

Matrix type for derivative with respect to input ellipse parameters.

Definition at line 49 of file Convolution.h.

Constructor & Destructor Documentation

◆ Convolution()

lsst::afw::geom::ellipses::BaseCore::Convolution::Convolution ( BaseCore self,
BaseCore const &  other 
)
inline

Standard constructor.

Definition at line 52 of file Convolution.h.

52 : self(self), other(other) {}

Member Function Documentation

◆ apply()

void lsst::afw::geom::ellipses::BaseCore::Convolution::apply ( BaseCore result) const

Definition at line 50 of file Convolution.cc.

50  {
51  double ixx1, iyy1, ixy1;
52  double ixx2, iyy2, ixy2;
53  self._assignToQuadrupole(ixx1, iyy1, ixy1);
54  other._assignToQuadrupole(ixx2, iyy2, ixy2);
55  result._assignFromQuadrupole(ixx1 + ixx2, iyy1 + iyy2, ixy1 + ixy2);
56 }
py::object result
Definition: schema.cc:418
virtual void _assignToQuadrupole(double &ixx, double &iyy, double &ixy) const =0

◆ copy()

std::shared_ptr< BaseCore > lsst::afw::geom::ellipses::BaseCore::Convolution::copy ( ) const

Return a new convolved ellipse core.

Definition at line 32 of file Convolution.cc.

32  {
34  apply(*r);
35  return r;
36 }
std::shared_ptr< BaseCore > clone() const
Deep-copy the Core.
Definition: BaseCore.h:82

◆ d()

BaseCore::Convolution::DerivativeMatrix lsst::afw::geom::ellipses::BaseCore::Convolution::d ( ) const

Return the derivative of convolved core with respect to self.

Definition at line 40 of file Convolution.cc.

40  {
41  double ixx1, iyy1, ixy1;
42  double ixx2, iyy2, ixy2;
43  Jacobian rhs = self._dAssignToQuadrupole(ixx1, iyy1, ixy1);
44  other._assignToQuadrupole(ixx2, iyy2, ixy2);
45  std::shared_ptr<BaseCore> convolved(self.clone());
46  Jacobian lhs = convolved->_dAssignFromQuadrupole(ixx1 + ixx2, iyy1 + iyy2, ixy1 + ixy2);
47  return lhs * rhs;
48 }
std::shared_ptr< BaseCore > clone() const
Deep-copy the Core.
Definition: BaseCore.h:82
Eigen::Matrix3d Jacobian
Parameter Jacobian matrix type.
Definition: BaseCore.h:64
virtual void _assignToQuadrupole(double &ixx, double &iyy, double &ixy) const =0

◆ inPlace()

void lsst::afw::geom::ellipses::BaseCore::Convolution::inPlace ( )

Convolve the ellipse core in-place.

Definition at line 38 of file Convolution.cc.

38 { apply(self); }

Member Data Documentation

◆ other

BaseCore const& lsst::afw::geom::ellipses::BaseCore::Convolution::other

Definition at line 66 of file Convolution.h.

◆ self

BaseCore& lsst::afw::geom::ellipses::BaseCore::Convolution::self

Definition at line 65 of file Convolution.h.


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