LSSTApplications  17.0+11,17.0+34,17.0+56,17.0+57,17.0+59,17.0+7,17.0-1-g377950a+33,17.0.1-1-g114240f+2,17.0.1-1-g4d4fbc4+28,17.0.1-1-g55520dc+49,17.0.1-1-g5f4ed7e+52,17.0.1-1-g6dd7d69+17,17.0.1-1-g8de6c91+11,17.0.1-1-gb9095d2+7,17.0.1-1-ge9fec5e+5,17.0.1-1-gf4e0155+55,17.0.1-1-gfc65f5f+50,17.0.1-1-gfc6fb1f+20,17.0.1-10-g87f9f3f+1,17.0.1-11-ge9de802+16,17.0.1-16-ga14f7d5c+4,17.0.1-17-gc79d625+1,17.0.1-17-gdae4c4a+8,17.0.1-2-g26618f5+29,17.0.1-2-g54f2ebc+9,17.0.1-2-gf403422+1,17.0.1-20-g2ca2f74+6,17.0.1-23-gf3eadeb7+1,17.0.1-3-g7e86b59+39,17.0.1-3-gb5ca14a,17.0.1-3-gd08d533+40,17.0.1-30-g596af8797,17.0.1-4-g59d126d+4,17.0.1-4-gc69c472+5,17.0.1-6-g5afd9b9+4,17.0.1-7-g35889ee+1,17.0.1-7-gc7c8782+18,17.0.1-9-gc4bbfb2+3,w.2019.22
LSSTDataManagementBasePackage
mergeOnlyFakes.py
Go to the documentation of this file.
1 import lsst.pex.config as pexConfig
2 import lsst.afw.detection as afwDetect
3 import lsst.pipe.tasks.multiBand as mBand
4 from lsst.pipe.tasks.coaddBase import getSkyInfo
5 
6 # WARNING: if you want to add configuration variables (maybe how close you are
7 # to a fake object), you will need to deal with the fact that the configuration
8 # for a retargeted subtask (like this one) blows away any overrides in setDefault of
9 # the parent task (processCoadd in this case) and, it seems any camera specific
10 # overrides in $OBS_SUBARU/config/hsc/processCcd.py.
11 # See https://dev.lsstcorp.org/trac/ticket/2282 for more details
12 # I think you need something like cmdLineTask.applyOverrides to deal with this
13 
14 # Song Huang
15 
16 
17 class OnlyFakesMergeConfig(mBand.MeasureMergedCoaddSourcesTask.ConfigClass):
18  dummyVar = pexConfig.Field(doc='Dummy config variable, does nothing',
19  dtype=bool, default=True)
20 
21 
22 class OnlyFakesMergeTask(mBand.MeasureMergedCoaddSourcesTask):
23  """This task serves culls the source list to sources which overlap with fakes"""
24 
25  # WARNING: we are using the parent configuration class instead of the
26  # OnlyFakesMergeConfig to avoid having to fix overridden config parameters
27  ConfigClass = mBand.MeasureMergedCoaddSourcesConfig
28 
29  def runDataRef(self, patchRef):
30  """Measure and deblend"""
31 
32  exposure = patchRef.get(self.config.coaddName + "Coadd", immediate=True)
33 
34  """Read in the FAKE mask plane"""
35  mask = exposure.getMaskedImage().getMask()
36  fakebit = mask.getPlaneBitMask('FAKE')
37 
38  sources = self.readSources(patchRef)
39  self.log.info("Found %d sources" % len(sources))
40  """ignore objects whose footprints do NOT overlap with the 'FAKE' mask"""
41  removes = []
42  for i_ss, ss in enumerate(sources):
43  foot = ss.getFootprint()
44  footTmp = afwDetect.Footprint(foot)
45  footTmp.intersectMask(mask, fakebit)
46  if footTmp.getArea() == foot.getArea():
47  removes.append(i_ss)
48  removes = sorted(removes, reverse=True)
49  for r in removes:
50  del sources[r]
51  self.log.info("Found %d sources near fake footprints" % len(sources))
52 
53  if self.config.doDeblend:
54  self.deblend.run(exposure, sources, exposure.getPsf())
55 
56  bigKey = sources.schema["deblend.parent-too-big"].asKey()
57  # catalog is non-contiguous so can't extract column
58  numBig = sum((s.get(bigKey) for s in sources))
59  if numBig > 0:
60  self.log.warn("Patch %s contains %d large footprints that were not deblended" %
61  (patchRef.dataId, numBig))
62  self.measurement.run(exposure, sources)
63  skyInfo = getSkyInfo(coaddName=self.config.coaddName, patchRef=patchRef)
64  self.setPrimaryFlags.run(sources, skyInfo.skyMap, skyInfo.tractInfo, skyInfo.patchInfo,
65  includeDeblend=self.config.doDeblend)
66  self.propagateFlags.run(patchRef.getButler(), sources, self.propagateFlags.getCcdInputs(exposure),
67  exposure.getWcs())
68  if self.config.doMatchSources:
69  self.writeMatches(patchRef, exposure, sources)
70 
71  self.write(patchRef, sources)
Class to describe the properties of a detected object from an image.
Definition: Footprint.h:62
def getSkyInfo(coaddName, patchRef)
Return the SkyMap, tract and patch information, wcs, and outer bbox of the patch to be coadded...
Definition: coaddBase.py:231