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
Functions
lsst.meas.astrom.verifyWcs Namespace Reference

Functions

def checkMatches (srcMatchSet, exposure, log=None)
 

Function Documentation

◆ checkMatches()

def lsst.meas.astrom.verifyWcs.checkMatches (   srcMatchSet,
  exposure,
  log = None 
)
Check astrometric matches and assess Wcs quality by computing statics
over spacial cells in the image.

Parameters
----------
srcMatchSet : `list` of `lsst.afw.table.ReferenceMatch`
    List of matched sources to a reference catalog.
exposure : `lsst.afw.image.Exposure`
    Image the sources in srcMatchSet were detected/measured in.
log : `lsst.log.Log`
    Logger object.

Returns
-------
values : `dict`
    Result dictionary with fields:

    - ``minObjectsPerCell`` : (`int`)
    - ``maxObjectsPerCell`` : (`int`)
    - ``meanObjectsPerCell`` : (`float`)
    - ``stdObjectsPerCell`` : (`float`)

Definition at line 35 of file verifyWcs.py.

35 def checkMatches(srcMatchSet, exposure, log=None):
36  """Check astrometric matches and assess Wcs quality by computing statics
37  over spacial cells in the image.
38 
39  Parameters
40  ----------
41  srcMatchSet : `list` of `lsst.afw.table.ReferenceMatch`
42  List of matched sources to a reference catalog.
43  exposure : `lsst.afw.image.Exposure`
44  Image the sources in srcMatchSet were detected/measured in.
45  log : `lsst.log.Log`
46  Logger object.
47 
48  Returns
49  -------
50  values : `dict`
51  Result dictionary with fields:
52 
53  - ``minObjectsPerCell`` : (`int`)
54  - ``maxObjectsPerCell`` : (`int`)
55  - ``meanObjectsPerCell`` : (`float`)
56  - ``stdObjectsPerCell`` : (`float`)
57  """
58  if not exposure:
59  return {}
60 
61  if log is None:
62  log = Log.getLogger("meas.astrom.verifyWcs.checkMatches")
63 
64  im = exposure.getMaskedImage().getImage()
65  width, height = im.getWidth(), im.getHeight()
66  nx, ny = 3, 3
67  w, h = width//nx, height//ny
68 
69  if w == 0:
70  w = 1
71  while nx*w < width:
72  w += 1
73 
74  if h == 0:
75  h = 1
76  while ny*h < height:
77  h += 1
78 
79  cellSet = afwMath.SpatialCellSet(
80  lsst.geom.Box2I(lsst.geom.Point2I(0, 0), lsst.geom.Extent2I(width, height)), w, h)
81  #
82  # Populate cellSet
83  #
84  i = -1
85  for m in srcMatchSet:
86  i += 1
87 
88  src = m.second
89  csrc = afwDetection.Source()
90  csrc.setId(i)
91  csrc.setXAstrom(src.getXAstrom())
92  csrc.setYAstrom(src.getYAstrom())
93 
94  try:
95  cellSet.insertCandidate(measAlg.PsfCandidateF(csrc, exposure.getMaskedImage()))
96  except Exception as e:
97  log.warn(str(e))
98 
99  ncell = len(cellSet.getCellList())
100  nobj = np.ndarray(ncell, dtype='i')
101 
102  for i in range(ncell):
103  cell = cellSet.getCellList()[i]
104 
105  nobj[i] = cell.size()
106 
107  dx = np.ndarray(cell.size())
108  dy = np.ndarray(cell.size())
109 
110  j = 0
111  for cand in cell:
112  #
113  # Swig doesn't know that we're a SpatialCellImageCandidate; all it knows is that we have
114  # a SpatialCellCandidate so we need an explicit (dynamic) cast
115  #
116  mid = cand.getSource().getId()
117  dx[j] = srcMatchSet[mid].first.getXAstrom() - srcMatchSet[mid].second.getXAstrom()
118  dy[j] = srcMatchSet[mid].first.getYAstrom() - srcMatchSet[mid].second.getYAstrom()
119 
120  j += 1
121 
122  log.debug("%s %-30s %8s dx,dy = %5.2f,%5.2f rms_x,y = %5.2f,%5.2f",
123  cell.getLabel(), cell.getBBox(), ("nobj=%d" % cell.size()),
124  dx.mean(), dy.mean(), dx.std(), dy.std())
125 
126  nobj.sort()
127 
128  values = {}
129  values["minObjectsPerCell"] = int(nobj[0]) # otherwise it's a numpy integral type
130  values["maxObjectsPerCell"] = int(nobj[-1])
131  values["meanObjectsPerCell"] = nobj.mean()
132  values["stdObjectsPerCell"] = nobj.std()
133 
134  return values
lsst::meas::astrom.verifyWcs.checkMatches
def checkMatches(srcMatchSet, exposure, log=None)
Definition: verifyWcs.py:35
lsst::geom::Point< int, 2 >
lsst::geom::Box2I
An integer coordinate rectangle.
Definition: Box.h:55
lsst::afw::math::SpatialCellSet
A collection of SpatialCells covering an entire image.
Definition: SpatialCell.h:387
lsst::geom::Extent< int, 2 >