LSST Applications g00274db5b6+edbf708997,g00d0e8bbd7+edbf708997,g199a45376c+5137f08352,g1fd858c14a+1d4b6db739,g262e1987ae+f4d9505c4f,g29ae962dfc+7156fb1a53,g2cef7863aa+73c82f25e4,g35bb328faa+edbf708997,g3e17d7035e+5b3adc59f5,g3fd5ace14f+852fa6fbcb,g47891489e3+6dc8069a4c,g53246c7159+edbf708997,g64539dfbff+9f17e571f4,g67b6fd64d1+6dc8069a4c,g74acd417e5+ae494d68d9,g786e29fd12+af89c03590,g7ae74a0b1c+a25e60b391,g7aefaa3e3d+536efcc10a,g7cc15d900a+d121454f8d,g87389fa792+a4172ec7da,g89139ef638+6dc8069a4c,g8d7436a09f+28c28d8d6d,g8ea07a8fe4+db21c37724,g92c671f44c+9f17e571f4,g98df359435+b2e6376b13,g99af87f6a8+b0f4ad7b8d,gac66b60396+966efe6077,gb88ae4c679+7dec8f19df,gbaa8f7a6c5+38b34f4976,gbf99507273+edbf708997,gc24b5d6ed1+9f17e571f4,gca7fc764a6+6dc8069a4c,gcc769fe2a4+97d0256649,gd7ef33dd92+6dc8069a4c,gdab6d2f7ff+ae494d68d9,gdbb4c4dda9+9f17e571f4,ge410e46f29+6dc8069a4c,geaed405ab2+e194be0d2b,w.2025.47
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst::afw::geom::ellipses::BaseCore::GridTransform Class Referencefinal

A temporary-only expression object representing an lsst::geom::LinearTransform that maps the ellipse core to a unit circle. More...

#include <GridTransform.h>

Public Types

using DerivativeMatrix = Eigen::Matrix<double, 4, 3>
 Matrix type for derivative with respect to ellipse parameters.
 

Public Member Functions

 GridTransform (BaseCore const &input)
 Standard constructor.
 
 operator lsst::geom::LinearTransform () const
 Convert the proxy to an lsst::geom::LinearTransform.
 
lsst::geom::LinearTransform::Matrix getMatrix () const
 Return the transform matrix as an Eigen object.
 
DerivativeMatrix d () const
 Return the derivative of the transform with respect to input core.
 
double getDeterminant () const
 Return the determinant of the lsst::geom::LinearTransform.
 
lsst::geom::LinearTransform inverted () const
 Return the inverse of the lsst::geom::LinearTransform;.
 

Detailed Description

A temporary-only expression object representing an lsst::geom::LinearTransform that maps the ellipse core to a unit circle.

Definition at line 48 of file GridTransform.h.

Member Typedef Documentation

◆ DerivativeMatrix

Matrix type for derivative with respect to ellipse parameters.

Definition at line 51 of file GridTransform.h.

Constructor & Destructor Documentation

◆ GridTransform()

lsst::afw::geom::ellipses::BaseCore::GridTransform::GridTransform ( BaseCore const & input)
explicit

Standard constructor.

Definition at line 35 of file GridTransform.cc.

36 : _input(input), _eig(Quadrupole(input).getMatrix()) {}
lsst::geom::LinearTransform::Matrix getMatrix() const
Return the transform matrix as an Eigen object.

Member Function Documentation

◆ d()

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

Return the derivative of the transform with respect to input core.

Definition at line 46 of file GridTransform.cc.

46 {
47 /*
48 Grid transform is easiest to differentiate in the ReducedShear/DeterminantRadius parametrization.
49 But we actually differentiate the inverse of the transform, and then use
50 $dM^{-1}/dt = -M^{-1} dM/dt M^{-1} to compute the derivative of the inverse.
51
52 The inverse of the grid transform in ReducedShear/DeterminantRadius is:
53 $\frac{r}{\sqrt{1-g^2}}(\sigma_x + g_1 \sigma_z + g2 \sigma_y)$, where $\sigma_i$ are the
54 Pauli spin matrices.
55 */
56 using C = Separable<ReducedShear, DeterminantRadius>;
57 C core;
58 Jacobian rhs = core.dAssign(_input);
59 double g1 = core.getE1();
60 double g2 = core.getE2();
61 double g = core.getEllipticity().getE();
62 double r = core.getRadius();
63 double beta = 1.0 - g * g;
64 double alpha = r / std::sqrt(beta);
65
66 Eigen::Matrix2d sigma_z, sigma_y;
67 sigma_z << 1.0, 0.0, 0.0, -1.0;
68 sigma_y << 0.0, 1.0, 1.0, 0.0;
69 Eigen::Matrix2d t = _eig.operatorSqrt();
70 Eigen::Matrix2d tInv = _eig.operatorInverseSqrt();
71 Eigen::Matrix2d dt_dg1 = t * g1 / beta + alpha * sigma_z;
72 Eigen::Matrix2d dt_dg2 = t * g2 / beta + alpha * sigma_y;
73 Eigen::Matrix2d dt_dr = t * (1.0 / r);
74 Eigen::Matrix2d dtInv_dg1 = -tInv * dt_dg1 * tInv;
75 Eigen::Matrix2d dtInv_dg2 = -tInv * dt_dg2 * tInv;
76 Eigen::Matrix2d dtInv_dr = -tInv * dt_dr * tInv;
77
79 mid(lsst::geom::LinearTransform::XX, C::E1) = dtInv_dg1(0, 0);
81 dtInv_dg1(0, 1);
82 mid(lsst::geom::LinearTransform::YY, C::E1) = dtInv_dg1(1, 1);
83 mid(lsst::geom::LinearTransform::XX, C::E2) = dtInv_dg2(0, 0);
85 dtInv_dg2(0, 1);
86 mid(lsst::geom::LinearTransform::YY, C::E2) = dtInv_dg2(1, 1);
87 mid(lsst::geom::LinearTransform::XX, C::RADIUS) = dtInv_dr(0, 0);
89 dtInv_dr(0, 1);
90 mid(lsst::geom::LinearTransform::YY, C::RADIUS) = dtInv_dr(1, 1);
91 return mid * rhs;
92}
Eigen::Matrix< double, 4, 3 > DerivativeMatrix
Matrix type for derivative with respect to ellipse parameters.
Eigen::Matrix3d Jacobian
Parameter Jacobian matrix type.
Definition BaseCore.h:64
T sqrt(T... args)

◆ getDeterminant()

double lsst::afw::geom::ellipses::BaseCore::GridTransform::getDeterminant ( ) const

Return the determinant of the lsst::geom::LinearTransform.

Definition at line 94 of file GridTransform.cc.

94{ return sqrt(1.0 / _eig.eigenvalues().prod()); }

◆ getMatrix()

lsst::geom::LinearTransform::Matrix lsst::afw::geom::ellipses::BaseCore::GridTransform::getMatrix ( ) const

Return the transform matrix as an Eigen object.

Definition at line 38 of file GridTransform.cc.

38 {
39 return _eig.operatorInverseSqrt();
40}

◆ inverted()

lsst::geom::LinearTransform lsst::afw::geom::ellipses::BaseCore::GridTransform::inverted ( ) const

Return the inverse of the lsst::geom::LinearTransform;.

Definition at line 96 of file GridTransform.cc.

96 {
97 return lsst::geom::LinearTransform(_eig.operatorSqrt());
98}

◆ operator lsst::geom::LinearTransform()

lsst::afw::geom::ellipses::BaseCore::GridTransform::operator lsst::geom::LinearTransform ( ) const

Convert the proxy to an lsst::geom::LinearTransform.

Definition at line 42 of file GridTransform.cc.

42 {
43 return lsst::geom::LinearTransform(_eig.operatorInverseSqrt());
44}

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