LSSTApplications  16.0-10-g0ee56ad+5,16.0-11-ga33d1f2+5,16.0-12-g3ef5c14+3,16.0-12-g71e5ef5+18,16.0-12-gbdf3636+3,16.0-13-g118c103+3,16.0-13-g8f68b0a+3,16.0-15-gbf5c1cb+4,16.0-16-gfd17674+3,16.0-17-g7c01f5c+3,16.0-18-g0a50484+1,16.0-20-ga20f992+8,16.0-21-g0e05fd4+6,16.0-21-g15e2d33+4,16.0-22-g62d8060+4,16.0-22-g847a80f+4,16.0-25-gf00d9b8+1,16.0-28-g3990c221+4,16.0-3-gf928089+3,16.0-32-g88a4f23+5,16.0-34-gd7987ad+3,16.0-37-gc7333cb+2,16.0-4-g10fc685+2,16.0-4-g18f3627+26,16.0-4-g5f3a788+26,16.0-5-gaf5c3d7+4,16.0-5-gcc1f4bb+1,16.0-6-g3b92700+4,16.0-6-g4412fcd+3,16.0-6-g7235603+4,16.0-69-g2562ce1b+2,16.0-8-g14ebd58+4,16.0-8-g2df868b+1,16.0-8-g4cec79c+6,16.0-8-gadf6c7a+1,16.0-8-gfc7ad86,16.0-82-g59ec2a54a+1,16.0-9-g5400cdc+2,16.0-9-ge6233d7+5,master-g2880f2d8cf+3,v17.0.rc1
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