LSSTApplications  19.0.0-14-gb0260a2+72efe9b372,20.0.0+7927753e06,20.0.0+8829bf0056,20.0.0+995114c5d2,20.0.0+b6f4b2abd1,20.0.0+bddc4f4cbe,20.0.0-1-g253301a+8829bf0056,20.0.0-1-g2b7511a+0d71a2d77f,20.0.0-1-g5b95a8c+7461dd0434,20.0.0-12-g321c96ea+23efe4bbff,20.0.0-16-gfab17e72e+fdf35455f6,20.0.0-2-g0070d88+ba3ffc8f0b,20.0.0-2-g4dae9ad+ee58a624b3,20.0.0-2-g61b8584+5d3db074ba,20.0.0-2-gb780d76+d529cf1a41,20.0.0-2-ged6426c+226a441f5f,20.0.0-2-gf072044+8829bf0056,20.0.0-2-gf1f7952+ee58a624b3,20.0.0-20-geae50cf+e37fec0aee,20.0.0-25-g3dcad98+544a109665,20.0.0-25-g5eafb0f+ee58a624b3,20.0.0-27-g64178ef+f1f297b00a,20.0.0-3-g4cc78c6+e0676b0dc8,20.0.0-3-g8f21e14+4fd2c12c9a,20.0.0-3-gbd60e8c+187b78b4b8,20.0.0-3-gbecbe05+48431fa087,20.0.0-38-ge4adf513+a12e1f8e37,20.0.0-4-g97dc21a+544a109665,20.0.0-4-gb4befbc+087873070b,20.0.0-4-gf910f65+5d3db074ba,20.0.0-5-gdfe0fee+199202a608,20.0.0-5-gfbfe500+d529cf1a41,20.0.0-6-g64f541c+d529cf1a41,20.0.0-6-g9a5b7a1+a1cd37312e,20.0.0-68-ga3f3dda+5fca18c6a4,20.0.0-9-g4aef684+e18322736b,w.2020.45
LSSTDataManagementBasePackage
Classes | Functions
lsst.meas.algorithms.skyObjects Namespace Reference

Classes

class  SkyObjectsConfig
 
class  SkyObjectsTask
 

Functions

def generateSkyObjects (mask, seed, config)
 

Function Documentation

◆ generateSkyObjects()

def lsst.meas.algorithms.skyObjects.generateSkyObjects (   mask,
  seed,
  config 
)
Generate a list of Footprints of sky objects

Sky objects don't overlap with other objects. This is determined
through the provided `mask` (in which objects are typically flagged
as `DETECTED`).

The algorithm for determining sky objects is random trial and error:
we try up to `nTrialSkySources` random positions to find `nSources`
sky objects.

Parameters
----------
mask : `lsst.afw.image.Mask`
    Input mask plane, which identifies pixels to avoid for the sky
    objects.
seed : `int`
    Random number generator seed.
config : `SkyObjectsConfig`
    Configuration for finding sky objects.

Returns
-------
skyFootprints : `list` of `lsst.afw.detection.Footprint`
    Footprints of sky objects. Each will have a peak at the center
    of the sky object.

Definition at line 29 of file skyObjects.py.

29 def generateSkyObjects(mask, seed, config):
30  """Generate a list of Footprints of sky objects
31 
32  Sky objects don't overlap with other objects. This is determined
33  through the provided `mask` (in which objects are typically flagged
34  as `DETECTED`).
35 
36  The algorithm for determining sky objects is random trial and error:
37  we try up to `nTrialSkySources` random positions to find `nSources`
38  sky objects.
39 
40  Parameters
41  ----------
42  mask : `lsst.afw.image.Mask`
43  Input mask plane, which identifies pixels to avoid for the sky
44  objects.
45  seed : `int`
46  Random number generator seed.
47  config : `SkyObjectsConfig`
48  Configuration for finding sky objects.
49 
50  Returns
51  -------
52  skyFootprints : `list` of `lsst.afw.detection.Footprint`
53  Footprints of sky objects. Each will have a peak at the center
54  of the sky object.
55  """
56  if config.nSources <= 0:
57  return []
58 
59  skySourceRadius = config.sourceRadius
60  nSkySources = config.nSources
61  nTrialSkySources = config.nTrialSources
62  if nTrialSkySources is None:
63  nTrialSkySources = config.nTrialSourcesMultiplier*nSkySources
64 
65  box = mask.getBBox()
66  box.grow(-(int(skySourceRadius) + 1)) # Avoid objects partially off the image
67  xMin, yMin = box.getMin()
68  xMax, yMax = box.getMax()
69 
70  avoid = lsst.afw.geom.SpanSet.fromMask(mask, mask.getPlaneBitMask(config.avoidMask))
71  if config.growMask > 0:
72  avoid = avoid.dilated(config.growMask)
73 
74  rng = lsst.afw.math.Random(seed=seed)
75 
76  skyFootprints = []
77  for _ in range(nTrialSkySources):
78  if len(skyFootprints) == nSkySources:
79  break
80 
81  x = int(rng.flat(xMin, xMax))
82  y = int(rng.flat(yMin, yMax))
83  spans = lsst.afw.geom.SpanSet.fromShape(int(skySourceRadius), offset=(x, y))
84  if spans.overlaps(avoid):
85  continue
86 
87  fp = lsst.afw.detection.Footprint(spans, mask.getBBox())
88  fp.addPeak(x, y, 0)
89  skyFootprints.append(fp)
90 
91  return skyFootprints
92 
93 
lsst::meas::algorithms.skyObjects.generateSkyObjects
def generateSkyObjects(mask, seed, config)
Definition: skyObjects.py:29
lsst::afw::geom::SpanSet::fromMask
static std::shared_ptr< geom::SpanSet > fromMask(image::Mask< T > const &mask, UnaryPredicate comparator=details::AnyBitSetFunctor< T >())
Create a SpanSet from a mask.
Definition: SpanSet.h:644
lsst::afw::geom::SpanSet::fromShape
static std::shared_ptr< geom::SpanSet > fromShape(int r, Stencil s=Stencil::CIRCLE, lsst::geom::Point2I offset=lsst::geom::Point2I())
Factory function for creating SpanSets from a Stencil.
Definition: SpanSet.cc:689
lsst::afw::math::Random
A class that can be used to generate sequences of random numbers according to a number of different a...
Definition: Random.h:57
lsst::afw::detection::Footprint
Class to describe the properties of a detected object from an image.
Definition: Footprint.h:63