LSST Applications g04a91732dc+146a938ab0,g07dc498a13+80b84b0d75,g0fba68d861+0decac7526,g1409bbee79+80b84b0d75,g1a7e361dbc+80b84b0d75,g1fd858c14a+f6e422e056,g20f46db602+483a84333a,g21d47ad084+4a6cd485de,g35bb328faa+fcb1d3bbc8,g42c1b31a95+a1301e4c20,g4d39ba7253+9b833be27e,g4e0f332c67+5d362be553,g53246c7159+fcb1d3bbc8,g60b5630c4e+9b833be27e,g78460c75b0+2f9a1b4bcd,g786e29fd12+cf7ec2a62a,g7b71ed6315+fcb1d3bbc8,g8852436030+790117df0f,g89139ef638+80b84b0d75,g8d6b6b353c+9b833be27e,g9125e01d80+fcb1d3bbc8,g989de1cb63+80b84b0d75,g9f33ca652e+9c6b68d7f3,ga9baa6287d+9b833be27e,gaaedd4e678+80b84b0d75,gabe3b4be73+1e0a283bba,gb1101e3267+9f3571abad,gb58c049af0+f03b321e39,gb90eeb9370+691e4ab549,gc741bbaa4f+5f483edd21,gcf25f946ba+790117df0f,gd24842266e+c54cdbdbd2,gd315a588df+5b65d88fe4,gd6cbbdb0b4+c8606af20c,gd9a9a58781+fcb1d3bbc8,gde0f65d7ad+c99546153d,ge278dab8ac+932305ba37,ge82c20c137+76d20ab76d,w.2025.10
LSST Data Management Base Package
Loading...
Searching...
No Matches
lsst.meas.astrom.verifyWcs Namespace Reference

Functions

 checkMatches (srcMatchSet, exposure, log=None)
 

Variables

 _LOG = logging.getLogger(__name__)
 

Function Documentation

◆ checkMatches()

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` or `logging.Logger`
    Logger object.

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

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

Definition at line 37 of file verifyWcs.py.

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

Variable Documentation

◆ _LOG

lsst.meas.astrom.verifyWcs._LOG = logging.getLogger(__name__)
protected

Definition at line 34 of file verifyWcs.py.