LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Functions
lsst.meas.astrom.sip.sourceMatchStatistics Namespace Reference

Functions

def sourceMatchStatistics (matchList, log=None)
 

Function Documentation

◆ sourceMatchStatistics()

def lsst.meas.astrom.sip.sourceMatchStatistics.sourceMatchStatistics (   matchList,
  log = None 
)
Compute statistics on the accuracy of a wcs solution, using a
precomputed list of matches between an image and a catalog.

Parameters
----------
matchList : `lsst.afw.detection.SourceMatch`
    List of matches between sources and references to compute statistics
    on.

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

    - diffInPixels_mean : Average distance between image and
      catalog position in pixels (`float`).
    - diffInPixels_std : Root mean square of distribution of distances
      (`float`).
    - diffInPixels_Q25 : 25% quantile boundary of the match dist
      distribution (`float`).
    - diffInPixels_Q50 : 50% quantile boundary of the match dist
      distribution (`float`).
    - diffInPixels_Q75 : 75% quantile boundary of the match
      dist distribution (`float`).

Definition at line 28 of file sourceMatchStatistics.py.

28 def sourceMatchStatistics(matchList, log=None):
29  """Compute statistics on the accuracy of a wcs solution, using a
30  precomputed list of matches between an image and a catalog.
31 
32  Parameters
33  ----------
34  matchList : `lsst.afw.detection.SourceMatch`
35  List of matches between sources and references to compute statistics
36  on.
37 
38  Returns
39  -------
40  values : `dict
41  Value dictionary with fields:
42 
43  - diffInPixels_mean : Average distance between image and
44  catalog position in pixels (`float`).
45  - diffInPixels_std : Root mean square of distribution of distances
46  (`float`).
47  - diffInPixels_Q25 : 25% quantile boundary of the match dist
48  distribution (`float`).
49  - diffInPixels_Q50 : 50% quantile boundary of the match dist
50  distribution (`float`).
51  - diffInPixels_Q75 : 75% quantile boundary of the match
52  dist distribution (`float`).
53  """
54 
55  size = len(matchList)
56  if size == 0:
57  raise ValueError("matchList contains no elements")
58 
59  dist = np.zeros(size)
60  i = 0
61  for match in matchList:
62  catObj = match.first
63  srcObj = match.second
64 
65  cx = catObj.getXAstrom()
66  cy = catObj.getYAstrom()
67 
68  sx = srcObj.getXAstrom()
69  sy = srcObj.getYAstrom()
70 
71  dist[i] = np.hypot(cx-sx, cy-sy)
72  i = i+1
73 
74  dist.sort()
75 
76  quartiles = []
77  for f in (0.25, 0.50, 0.75):
78  i = int(f*size + 0.5)
79  if i >= size:
80  i = size - 1
81  quartiles.append(dist[i])
82 
83  values = {}
84  values['diffInPixels_Q25'] = quartiles[0]
85  values['diffInPixels_Q50'] = quartiles[1]
86  values['diffInPixels_Q75'] = quartiles[2]
87  values['diffInPixels_mean'] = dist.mean()
88  values['diffInPixels_std'] = dist.std()
89 
90  return values