LSST Applications  21.0.0-131-g8cabc107+528f53ee53,22.0.0+00495a2688,22.0.0+0ef2527977,22.0.0+11a2aa21cd,22.0.0+269b7e55e3,22.0.0+2c6b6677a3,22.0.0+64c1bc5aa5,22.0.0+7b3a3f865e,22.0.0+e1b6d2281c,22.0.0+ff3c34362c,22.0.1-1-g1b65d06+c95cbdf3df,22.0.1-1-g7058be7+1cf78af69b,22.0.1-1-g7dab645+2a65e40b06,22.0.1-1-g8760c09+64c1bc5aa5,22.0.1-1-g949febb+64c1bc5aa5,22.0.1-1-ga324b9c+269b7e55e3,22.0.1-1-gf9d8b05+ff3c34362c,22.0.1-10-g781e53d+9b51d1cd24,22.0.1-10-gba590ab+b9624b875d,22.0.1-13-g76f9b8d+2c6b6677a3,22.0.1-14-g22236948+57af756299,22.0.1-18-g3db9cf4b+9b7092c56c,22.0.1-18-gb17765a+2264247a6b,22.0.1-2-g8ef0a89+2c6b6677a3,22.0.1-2-gcb770ba+c99495d3c6,22.0.1-24-g2e899d296+4206820b0d,22.0.1-3-g7aa11f2+2c6b6677a3,22.0.1-3-g8c1d971+f253ffa91f,22.0.1-3-g997b569+ff3b2f8649,22.0.1-4-g1930a60+6871d0c7f6,22.0.1-4-g5b7b756+6b209d634c,22.0.1-6-ga02864e+6871d0c7f6,22.0.1-7-g3402376+a1a2182ac4,22.0.1-7-g65f59fa+54b92689ce,master-gcc5351303a+e1b6d2281c,w.2021.32
LSST Data Management Base Package
Public Member Functions | Static Public Attributes | List of all members
lsst.cp.pipe.defects.MergeDefectsTask Class Reference
Inheritance diagram for lsst.cp.pipe.defects.MergeDefectsTask:

Public Member Functions

def run (self, inputDefects, camera)
 

Static Public Attributes

 ConfigClass = MergeDefectsTaskConfig
 

Detailed Description

Merge the defects from multiple exposures.

Definition at line 598 of file defects.py.

Member Function Documentation

◆ run()

def lsst.cp.pipe.defects.MergeDefectsTask.run (   self,
  inputDefects,
  camera 
)

Definition at line 604 of file defects.py.

604  def run(self, inputDefects, camera):
605  detectorId = inputDefects[0].getMetadata().get('DETECTOR', None)
606  if detectorId is None:
607  raise RuntimeError("Cannot identify detector id.")
608  detector = camera[detectorId]
609 
610  imageTypes = set()
611  for inDefect in inputDefects:
612  imageType = inDefect.getMetadata().get('cpDefectGenImageType', 'UNKNOWN')
613  imageTypes.add(imageType)
614 
615  # Determine common defect pixels separately for each input image type.
616  splitDefects = list()
617  for imageType in imageTypes:
618  sumImage = afwImage.MaskedImageF(detector.getBBox())
619  count = 0
620  for inDefect in inputDefects:
621  if imageType == inDefect.getMetadata().get('cpDefectGenImageType', 'UNKNOWN'):
622  count += 1
623  for defect in inDefect:
624  sumImage.image[defect.getBBox()] += 1.0
625  sumImage /= count
626  nDetected = len(np.where(sumImage.getImage().getArray() > 0)[0])
627  self.log.info("Pre-merge %s pixels with non-zero detections for %s" % (nDetected, imageType))
628 
629  if self.config.combinationMode == 'AND':
630  threshold = 1.0
631  elif self.config.combinationMode == 'OR':
632  threshold = 0.0
633  elif self.config.combinationMode == 'FRACTION':
634  threshold = self.config.combinationFraction
635  else:
636  raise RuntimeError(f"Got unsupported combinationMode {self.config.combinationMode}")
637  indices = np.where(sumImage.getImage().getArray() > threshold)
638  BADBIT = sumImage.getMask().getPlaneBitMask('BAD')
639  sumImage.getMask().getArray()[indices] |= BADBIT
640  self.log.info("Post-merge %s pixels marked as defects for %s" % (len(indices[0]), imageType))
641  partialDefect = Defects.fromMask(sumImage, 'BAD')
642  splitDefects.append(partialDefect)
643 
644  # Do final combination of separate image types
645  finalImage = afwImage.MaskedImageF(detector.getBBox())
646  for inDefect in splitDefects:
647  for defect in inDefect:
648  finalImage.image[defect.getBBox()] += 1
649  finalImage /= len(splitDefects)
650  nDetected = len(np.where(finalImage.getImage().getArray() > 0)[0])
651  self.log.info("Pre-final merge %s pixels with non-zero detections" % (nDetected, ))
652 
653  # This combination is the OR of all image types
654  threshold = 0.0
655  indices = np.where(finalImage.getImage().getArray() > threshold)
656  BADBIT = finalImage.getMask().getPlaneBitMask('BAD')
657  finalImage.getMask().getArray()[indices] |= BADBIT
658  self.log.info("Post-final merge %s pixels marked as defects" % (len(indices[0]), ))
659 
660  if self.config.edgesAsDefects:
661  self.log.info("Masking edge pixels as defects.")
662  # Do the same as IsrTask.maskEdges()
663  box = detector.getBBox()
664  subImage = finalImage[box]
665  box.grow(-self.nPixBorder)
666  SourceDetectionTask.setEdgeBits(subImage, box, BADBIT)
667 
668  merged = Defects.fromMask(finalImage, 'BAD')
669  merged.updateMetadata(camera=camera, detector=detector, filterName=None,
670  setCalibId=True, setDate=True)
671 
672  return pipeBase.Struct(
673  mergedDefects=merged,
674  )
675 
676 
daf::base::PropertyList * list
Definition: fits.cc:913
daf::base::PropertySet * set
Definition: fits.cc:912
def run(self, skyInfo, tempExpRefList, imageScalerList, weightList, altMaskList=None, mask=None, supplementaryData=None)

Member Data Documentation

◆ ConfigClass

lsst.cp.pipe.defects.MergeDefectsTask.ConfigClass = MergeDefectsTaskConfig
static

Definition at line 601 of file defects.py.


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