LSST Applications g0265f82a02+0e5473021a,g02d81e74bb+f5613e8b4f,g1470d8bcf6+190ad2ba91,g14a832a312+311607e4ab,g2079a07aa2+86d27d4dc4,g2305ad1205+a8e3196225,g295015adf3+b67ee847e5,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g3ddfee87b4+a761f810f3,g487adcacf7+17c8fdbcbd,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+65b5bd823e,g5a732f18d5+53520f316c,g64a986408d+f5613e8b4f,g6c1bc301e9+51106c2951,g858d7b2824+f5613e8b4f,g8a8a8dda67+585e252eca,g99cad8db69+6729933424,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+ef4e3a5875,gb0e22166c9+60f28cb32d,gb6a65358fc+0e5473021a,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e9bba80f27,gc120e1dc64+eee469a5e5,gc28159a63d+0e5473021a,gcf0d15dbbd+a761f810f3,gdaeeff99f8+f9a426f77a,ge6526c86ff+d4c1d4bfef,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gf1cff7945b+f5613e8b4f,w.2024.16
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Protected Member Functions | List of all members
lsst::jointcal::MagnitudeTransformSpatiallyInvariant Class Reference

Photometric offset independent of position, defined as -2.5 * log(flux / fluxMag0). More...

#include <PhotometryTransform.h>

Inheritance diagram for lsst::jointcal::MagnitudeTransformSpatiallyInvariant:
lsst::jointcal::PhotometryTransformSpatiallyInvariant lsst::jointcal::PhotometryTransform

Public Member Functions

 MagnitudeTransformSpatiallyInvariant (double value=0)
 
double transform (double x, double y, double mag) const override
 Return the transform of value at (x,y).
 
double transformError (double x, double y, double value, double valueErr) const override
 Return the transformed valueErr at Point(x,y).
 
std::shared_ptr< PhotometryTransformclone () const override
 return a copy (allocated by new) of the transformation.
 
void computeParameterDerivatives (double x, double y, double value, Eigen::Ref< Eigen::VectorXd > derivatives) const override
 Compute the derivatives with respect to the parameters (i.e.
 
void print (std::ostream &out) const override
 Print the transform coefficients to stream.
 
std::size_t getNpar () const override
 Return the number of parameters (used to compute chisq)
 
void offsetParams (Eigen::VectorXd const &delta) override
 Offset the parameters by some (negative) amount during fitting.
 
Eigen::VectorXd getParameters () const override
 Get a copy of the parameters of this model, in the same order as offsetParams.
 
double transform (Point const &in, double value) const
 Return the transformed value at Point(x,y).
 
double transformError (Point const &in, double value, double valueErr) const
 Return the transformed valueErr at Point(x,y).
 

Protected Member Functions

double getValue () const
 

Detailed Description

Photometric offset independent of position, defined as -2.5 * log(flux / fluxMag0).

initialMagnitude + SpatiallyInvariantTransform -> correctedMagnitude

Definition at line 179 of file PhotometryTransform.h.

Constructor & Destructor Documentation

◆ MagnitudeTransformSpatiallyInvariant()

lsst::jointcal::MagnitudeTransformSpatiallyInvariant::MagnitudeTransformSpatiallyInvariant ( double value = 0)
inlineexplicit

Member Function Documentation

◆ clone()

std::shared_ptr< PhotometryTransform > lsst::jointcal::MagnitudeTransformSpatiallyInvariant::clone ( ) const
inlineoverridevirtual

return a copy (allocated by new) of the transformation.

Implements lsst::jointcal::PhotometryTransform.

Definition at line 193 of file PhotometryTransform.h.

193 {
194 return std::make_shared<MagnitudeTransformSpatiallyInvariant>(getValue());
195 }

◆ computeParameterDerivatives()

void lsst::jointcal::MagnitudeTransformSpatiallyInvariant::computeParameterDerivatives ( double x,
double y,
double value,
Eigen::Ref< Eigen::VectorXd > derivatives ) const
inlineoverridevirtual

Compute the derivatives with respect to the parameters (i.e.

the coefficients).

Parameters
[in]xThe x coordinate to compute at (in the appropriate units for this transform).
[in]yThe y coordinate to compute at (in the appropriate units for this transform).
[in]valueThe instrument flux or magnitude to compute the derivative at.
[out]derivativesThe computed derivatives, in the same order as the deltas in offsetParams.

Implements lsst::jointcal::PhotometryTransform.

Definition at line 198 of file PhotometryTransform.h.

199 {
200 // the derivative of a spatially constant transform w.r.t. that value is 1.
201 derivatives[0] = 1;
202 }

◆ getNpar()

std::size_t lsst::jointcal::PhotometryTransformSpatiallyInvariant::getNpar ( ) const
inlineoverridevirtualinherited

Return the number of parameters (used to compute chisq)

Implements lsst::jointcal::PhotometryTransform.

Definition at line 121 of file PhotometryTransform.h.

121{ return 1; }

◆ getParameters()

Eigen::VectorXd lsst::jointcal::PhotometryTransformSpatiallyInvariant::getParameters ( ) const
inlineoverridevirtualinherited

Get a copy of the parameters of this model, in the same order as offsetParams.

Implements lsst::jointcal::PhotometryTransform.

Definition at line 127 of file PhotometryTransform.h.

127 {
128 Eigen::VectorXd parameters(1);
129 parameters[0] = _value;
130 return parameters;
131 }

◆ getValue()

double lsst::jointcal::PhotometryTransformSpatiallyInvariant::getValue ( ) const
inlineprotectedinherited

Definition at line 134 of file PhotometryTransform.h.

134{ return _value; }

◆ offsetParams()

void lsst::jointcal::PhotometryTransformSpatiallyInvariant::offsetParams ( Eigen::VectorXd const & delta)
inlineoverridevirtualinherited

Offset the parameters by some (negative) amount during fitting.

Equivalent to flatten(parameters) -= delta

Ordering of delta is the same as the ordering of the derivatives returned from computeParameterDerivatives.

Implements lsst::jointcal::PhotometryTransform.

Definition at line 124 of file PhotometryTransform.h.

124{ _value -= delta[0]; };

◆ print()

void lsst::jointcal::PhotometryTransformSpatiallyInvariant::print ( std::ostream & out) const
inlineoverridevirtualinherited

Print the transform coefficients to stream.

Implements lsst::jointcal::PhotometryTransform.

Definition at line 116 of file PhotometryTransform.h.

116 {
117 out << "PhotometryTransformSpatiallyInvariant: " << std::setprecision(10) << _value;
118 }
T setprecision(T... args)

◆ transform() [1/2]

double lsst::jointcal::MagnitudeTransformSpatiallyInvariant::transform ( double x,
double y,
double mag ) const
inlineoverridevirtual

Return the transform of value at (x,y).

Implements lsst::jointcal::PhotometryTransform.

Definition at line 185 of file PhotometryTransform.h.

185{ return mag + getValue(); }

◆ transform() [2/2]

double lsst::jointcal::PhotometryTransform::transform ( Point const & in,
double value ) const
inlineinherited

Return the transformed value at Point(x,y).

Definition at line 58 of file PhotometryTransform.h.

58{ return transform(in.x, in.y, value); }
table::Key< int > transform

◆ transformError() [1/2]

double lsst::jointcal::MagnitudeTransformSpatiallyInvariant::transformError ( double x,
double y,
double value,
double valueErr ) const
inlineoverridevirtual

Return the transformed valueErr at Point(x,y).

Implements lsst::jointcal::PhotometryTransform.

Definition at line 188 of file PhotometryTransform.h.

188 {
189 return valueErr;
190 }

◆ transformError() [2/2]

double lsst::jointcal::PhotometryTransform::transformError ( Point const & in,
double value,
double valueErr ) const
inlineinherited

Return the transformed valueErr at Point(x,y).

Definition at line 64 of file PhotometryTransform.h.

64 {
65 return transformError(in.x, in.y, value, valueErr);
66 }
virtual double transformError(double x, double y, double value, double valueErr) const =0
Return the transformed valueErr at Point(x,y).

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