SourceDeblendTask

SourceDeblendTask splits blended sources into individual sources.

Processing summary

SourceDeblendTask performs housekeeping work — updating table schemas and extracting the PSF from the input image — then delegates to lsst.meas.deblender.deblend to perform deblending. The task has no return value; the input SourceCatalog is modified in-place.

Python API summary

from lsst.meas.deblender.sourceDeblendTask import SourceDeblendTask
classSourceDeblendTask(schema, peakSchema=None, **kwargs)

Split blended sources into individual sources...

attributeconfig

Access configuration fields and retargetable subtasks.

methodrun(exposure, sources)

Get the PSF from the provided exposure and then run deblend...

See also

See the SourceDeblendTask API reference for complete details.

Retargetable subtasks

No subtasks.

Configuration fields

assignStrayFlux

Default
True
Field type

bool Field

Assign stray flux (not claimed by any child in the deblender) to deblend children.

catchFailures

Default
False
Field type

bool Field

If True, catch exceptions thrown by the deblender, log them, and set a flag on the parent, instead of letting them propagate up

ciDeblendChildRange

Default
[2, 10]
Field type

int ListField

Only deblend parent Footprints with a number of peaks in the (inclusive) range indicated.If useCiLimits==False then this parameter is ignored.

ciNumParentsToDeblend

Default
10
Field type

int Field

Only use the first ciNumParentsToDeblend parent footprints with a total peak count within ciDebledChildRange. If useCiLimits==False then this parameter is ignored.

clipStrayFluxFraction

Default
0.001
Field type

float Field

When splitting stray flux, clip fractions below this value to zero.

edgeHandling

Default
'ramp'
Field type

str ChoiceField (optional)

Choices
'clip'

Clip the template at the edge AND the mirror of the edge.

'ramp'

Ramp down flux at the image edge by the PSF

'noclip'

Ignore the edge when building the symmetric template.

None

Field is optional

What to do when a peak to be deblended is close to the edge of the image

maskLimits

Default
{}
Field type

DictField

Key type

str

Value type

float

Mask planes with the corresponding limit on the fraction of masked pixels. Sources violating this limit will not be deblended.

maskPlanes

Default
['SAT', 'INTRP', 'NO_DATA']
Field type

str ListField

Mask planes to ignore when performing statistics

maxFootprintArea

Default
1000000
Field type

int Field

Maximum area for footprints before they are ignored as large; non-positive means no threshold applied

maxFootprintSize

Default
0
Field type

int Field

Maximum linear dimension for footprints before they are ignored as large; non-positive means no threshold applied

maxNumberOfPeaks

Default
0
Field type

int Field

Only deblend the brightest maxNumberOfPeaks peaks in the parent (<= 0: unlimited)

maxTempDotProd

Default
0.5
Field type

float Field

If the dot product between two templates is larger than this value, we consider them to be describing the same object (i.e. they are degenerate). If one of the objects has been labeled as a PSF it will be removed, otherwise the template with the lowest value will be removed.

medianSmoothTemplate

Default
True
Field type

bool Field

Apply a smoothing filter to all of the template images

minFootprintAxisRatio

Default
0.0
Field type

float Field

Minimum axis ratio for footprints before they are ignored as large; non-positive means no threshold applied

notDeblendedMask

Default
'NOT_DEBLENDED'
Field type

str Field (optional)

Mask name for footprints not deblended, or None

propagateAllPeaks

Default
False
Field type

bool Field

Guarantee that all peaks produce a child source.

psfChisq1

Default
1.5
Field type

float Field

Chi-squared per DOF cut for deciding a source is a PSF during deblending (un-shifted PSF model)

psfChisq2

Default
1.5
Field type

float Field

Chi-squared per DOF cut for deciding a source is PSF during deblending (shifted PSF model)

psfChisq2b

Default
1.5
Field type

float Field

Chi-squared per DOF cut for deciding a source is a PSF during deblending (shifted PSF model #2)

removeDegenerateTemplates

Default
False
Field type

bool Field

Try to remove similar templates?

strayFluxRule

Default
'trim'
Field type

str ChoiceField (optional)

Choices
'r-to-peak'

~ 1/(1+R^2) to the peak

'r-to-footprint'

~ 1/(1+R^2) to the closest pixel in the footprint. CAUTION: this can be computationally expensive on large footprints!

'nearest-footprint'

Assign 100% to the nearest footprint (using L-1 norm aka Manhattan distance)

'trim'

Shrink the parent footprint to pixels that are not assigned to children

None

Field is optional

How to split flux among peaks

strayFluxToPointSources

Default
'necessary'
Field type

str ChoiceField (optional)

Choices
'necessary'

When there is not an extended object in the footprint

'always'

Always

'never'

Never; stray flux will not be attributed to any deblended child if the deblender thinks all peaks look like point sources

None

Field is optional

When the deblender should attribute stray flux to point sources

tinyFootprintSize

Default
2
Field type

int RangeField

Range

[2,inf)

Footprints smaller in width or height than this value will be ignored; minimum of 2 due to PSF gradient calculation.

useCiLimits

Default
False
Field type

bool Field

Limit the number of sources deblended for CI to prevent long build times

weightTemplates

Default
False
Field type

bool Field

If true, a least-squares fit of the templates will be done to the full image. The templates will be re-weighted based on this fit.