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
Classes | Functions
lsst.cp.pipe.cpCombine Namespace Reference

Classes

class  CalibStatsConfig
 
class  CalibStatsTask
 
class  CalibCombineConnections
 
class  CalibCombineConfig
 
class  CalibCombineTask
 
class  CalibCombineByFilterConnections
 
class  CalibCombineByFilterConfig
 
class  CalibCombineByFilterTask
 

Functions

def VignetteExposure (exposure, polygon=None, doUpdateMask=True, maskPlane="NO_DATA", doSetValue=False, vignetteValue=0.0, log=None)
 

Function Documentation

◆ VignetteExposure()

def lsst.cp.pipe.cpCombine.VignetteExposure (   exposure,
  polygon = None,
  doUpdateMask = True,
  maskPlane = "NO_DATA",
  doSetValue = False,
  vignetteValue = 0.0,
  log = None 
)
Apply vignetted polygon to image pixels.

Parameters
----------
exposure : `lsst.afw.image.Exposure`
    Image to be updated.
doUpdateMask : `bool`, optional
    Update the exposure mask for vignetted area?
maskPlane : `str`, optional
    Mask plane to assign.
doSetValue : `bool`, optional
    Set image value for vignetted area?
vignetteValue : `float`, optional
    Value to assign.
log : `lsst.log.Log`, optional
    Log to write to.

Raises
------
RuntimeError
    Raised if no valid polygon exists.

Definition at line 558 of file cpCombine.py.

561  log=None):
562  """Apply vignetted polygon to image pixels.
563 
564  Parameters
565  ----------
566  exposure : `lsst.afw.image.Exposure`
567  Image to be updated.
568  doUpdateMask : `bool`, optional
569  Update the exposure mask for vignetted area?
570  maskPlane : `str`, optional
571  Mask plane to assign.
572  doSetValue : `bool`, optional
573  Set image value for vignetted area?
574  vignetteValue : `float`, optional
575  Value to assign.
576  log : `lsst.log.Log`, optional
577  Log to write to.
578 
579  Raises
580  ------
581  RuntimeError
582  Raised if no valid polygon exists.
583  """
584  polygon = polygon if polygon else exposure.getInfo().getValidPolygon()
585  if not polygon:
586  raise RuntimeError("Could not find valid polygon!")
587  log = log if log else Log.getLogger(__name__.partition(".")[2])
588 
589  fullyIlluminated = True
590  for corner in exposure.getBBox().getCorners():
591  if not polygon.contains(Point2D(corner)):
592  fullyIlluminated = False
593 
594  log.info("Exposure is fully illuminated? %s", fullyIlluminated)
595 
596  if not fullyIlluminated:
597  # Scan pixels.
598  mask = exposure.getMask()
599  numPixels = mask.getBBox().getArea()
600 
601  xx, yy = np.meshgrid(np.arange(0, mask.getWidth(), dtype=int),
602  np.arange(0, mask.getHeight(), dtype=int))
603 
604  vignMask = np.array([not polygon.contains(Point2D(x, y)) for x, y in
605  zip(xx.reshape(numPixels), yy.reshape(numPixels))])
606  vignMask = vignMask.reshape(mask.getHeight(), mask.getWidth())
607 
608  if doUpdateMask:
609  bitMask = mask.getPlaneBitMask(maskPlane)
610  maskArray = mask.getArray()
611  maskArray[vignMask] |= bitMask
612  if doSetValue:
613  imageArray = exposure.getImage().getArray()
614  imageArray[vignMask] = vignetteValue
615  log.info("Exposure contains %d vignetted pixels.",
616  np.count_nonzero(vignMask))
Point< double, 2 > Point2D
Definition: Point.h:324