LSST Applications g0265f82a02+0e5473021a,g02d81e74bb+0dd8ce4237,g1470d8bcf6+3ea6592b6f,g2079a07aa2+86d27d4dc4,g2305ad1205+5ca4c0b359,g295015adf3+d10818ec9d,g2a9a014e59+6f9be1b9cd,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g3ddfee87b4+703ba97ebf,g487adcacf7+4fa16da234,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+ffa42b374e,g5a732f18d5+53520f316c,g64a986408d+0dd8ce4237,g858d7b2824+0dd8ce4237,g8a8a8dda67+585e252eca,g99cad8db69+d39438377f,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+f1d96605c8,gb0e22166c9+60f28cb32d,gb6a65358fc+0e5473021a,gba4ed39666+c2a2e4ac27,gbb8dafda3b+e5339d463f,gc120e1dc64+da31e9920e,gc28159a63d+0e5473021a,gcf0d15dbbd+703ba97ebf,gdaeeff99f8+f9a426f77a,ge6526c86ff+889fc9d533,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gf18bd8381d+7268b93478,gff1a9f87cc+0dd8ce4237,w.2024.16
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Public Attributes | Static Public Attributes | List of all members
lsst.meas.base.plugins.ForcedTransformedShapePlugin Class Reference
Inheritance diagram for lsst.meas.base.plugins.ForcedTransformedShapePlugin:
lsst.meas.base.forcedMeasurement.ForcedPlugin lsst.meas.base.baseMeasurement.BaseMeasurementPlugin lsst.meas.base.pluginsBase.BasePlugin

Public Member Functions

 getExecutionOrder (cls)
 
 __init__ (self, config, name, schemaMapper, metadata)
 
 measure (self, measRecord, exposure, refRecord, refWcs)
 

Public Attributes

 shapeKey
 
 flagKey
 

Static Public Attributes

 ConfigClass = ForcedTransformedShapeConfig
 

Detailed Description

Record the transformation of the reference catalog shape.

The shape recorded in the reference catalog is tranformed to the
measurement coordinate system and stored.

Parameters
----------
config : `ForcedTransformedShapeConfig`
    Plugin configuration
name : `str`
    Plugin name
schemaMapper : `lsst.afw.table.SchemaMapper`
    A mapping from reference catalog fields to output
    catalog fields. Output fields are added to the output schema.
metadata : `lsst.daf.base.PropertySet`
    Plugin metadata that will be attached to the output catalog.

Notes
-----
This is used as the slot shape by default in forced measurement, allowing
subsequent measurements to simply refer to the slot value just as they
would in single-frame measurement.

Definition at line 903 of file plugins.py.

Constructor & Destructor Documentation

◆ __init__()

lsst.meas.base.plugins.ForcedTransformedShapePlugin.__init__ ( self,
config,
name,
schemaMapper,
metadata )

Reimplemented from lsst.meas.base.forcedMeasurement.ForcedPlugin.

Definition at line 934 of file plugins.py.

934 def __init__(self, config, name, schemaMapper, metadata):
935 ForcedPlugin.__init__(self, config, name, schemaMapper, metadata)
936 schema = schemaMapper.editOutputSchema()
937 # Allocate xx, yy, xy fields, join these into a single FunctorKey for ease-of-use.
938 xxKey = schema.addField(name + "_xx", type="D", doc="transformed reference shape x^2 moment",
939 units="pixel^2")
940 yyKey = schema.addField(name + "_yy", type="D", doc="transformed reference shape y^2 moment",
941 units="pixel^2")
942 xyKey = schema.addField(name + "_xy", type="D", doc="transformed reference shape xy moment",
943 units="pixel^2")
944 self.shapeKey = lsst.afw.table.QuadrupoleKey(xxKey, yyKey, xyKey)
945 # Because we're taking the reference position as given, we don't bother transforming its
946 # uncertainty and reporting that here, so there are no sigma or cov fields. We do propagate
947 # the flag field, if it exists.
948 if "slot_Shape_flag" in schemaMapper.getInputSchema():
949 self.flagKey = schema.addField(name + "_flag", type="Flag",
950 doc="whether the reference shape is marked as bad")
951 else:
952 self.flagKey = None
953
A FunctorKey used to get or set a geom::ellipses::Quadrupole from a tuple of constituent Keys.
Definition aggregates.h:369

Member Function Documentation

◆ getExecutionOrder()

lsst.meas.base.plugins.ForcedTransformedShapePlugin.getExecutionOrder ( cls)
Get the relative execution order of this plugin.

Must be reimplemented as a class method by concrete derived classes.

Reimplemented from lsst.meas.base.pluginsBase.BasePlugin.

Definition at line 931 of file plugins.py.

931 def getExecutionOrder(cls):
932 return cls.SHAPE_ORDER
933

◆ measure()

lsst.meas.base.plugins.ForcedTransformedShapePlugin.measure ( self,
measRecord,
exposure,
refRecord,
refWcs )
Measure the properties of a source given an image and a reference.

Parameters
----------
exposure : `lsst.afw.image.ExposureF`
    The pixel data to be measured, together with the associated PSF,
    WCS, etc. All other sources in the image should have been replaced
    by noise according to deblender outputs.
measRecord : `lsst.afw.table.SourceRecord`
    Record describing the object being measured. Previously-measured
    quantities will be retrieved from here, and it will be updated
    in-place with the outputs of this plugin.
refRecord : `lsst.afw.table.SimpleRecord`
    Additional parameters to define the fit, as measured elsewhere.
refWcs : `lsst.afw.geom.SkyWcs` or `lsst.afw.geom.Angle`
    The coordinate system for the reference catalog values. An
    `~lsst.geom.Angle` may be passed, indicating that a local tangent
    WCS should be created for each object using the given angle as a
    pixel scale.

Notes
-----
In the normal mode of operation, the source centroid will be set to
the WCS-transformed position of the reference object, so plugins that
only require a reference position should not have to access the
reference object at all.

Reimplemented from lsst.meas.base.forcedMeasurement.ForcedPlugin.

Definition at line 954 of file plugins.py.

954 def measure(self, measRecord, exposure, refRecord, refWcs):
955 targetWcs = exposure.getWcs()
956 if not refWcs == targetWcs:
957 fullTransform = lsst.afw.geom.makeWcsPairTransform(refWcs, targetWcs)
958 localTransform = lsst.afw.geom.linearizeTransform(fullTransform, refRecord.getCentroid())
959 measRecord.set(self.shapeKey, refRecord.getShape().transform(localTransform.getLinear()))
960 else:
961 measRecord.set(self.shapeKey, refRecord.getShape())
962 if self.flagKey is not None:
963 measRecord.set(self.flagKey, refRecord.getShapeFlag())
std::shared_ptr< TransformPoint2ToPoint2 > makeWcsPairTransform(SkyWcs const &src, SkyWcs const &dst)
A Transform obtained by putting two SkyWcs objects "back to back".
Definition SkyWcs.cc:146
lsst::geom::AffineTransform linearizeTransform(TransformPoint2ToPoint2 const &original, lsst::geom::Point2D const &inPoint)
Approximate a Transform by its local linearization.

Member Data Documentation

◆ ConfigClass

lsst.meas.base.plugins.ForcedTransformedShapePlugin.ConfigClass = ForcedTransformedShapeConfig
static

Definition at line 928 of file plugins.py.

◆ flagKey

lsst.meas.base.plugins.ForcedTransformedShapePlugin.flagKey

Definition at line 949 of file plugins.py.

◆ shapeKey

lsst.meas.base.plugins.ForcedTransformedShapePlugin.shapeKey

Definition at line 944 of file plugins.py.


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