LSST Applications g02d81e74bb+86cf3d8bc9,g180d380827+7a4e862ed4,g2079a07aa2+86d27d4dc4,g2305ad1205+e1ca1c66fa,g29320951ab+012e1474a1,g295015adf3+341ea1ce94,g2bbee38e9b+0e5473021a,g337abbeb29+0e5473021a,g33d1c0ed96+0e5473021a,g3a166c0a6a+0e5473021a,g3ddfee87b4+c429d67c83,g48712c4677+f88676dd22,g487adcacf7+27e1e21933,g50ff169b8f+96c6868917,g52b1c1532d+585e252eca,g591dd9f2cf+b41db86c35,g5a732f18d5+53520f316c,g64a986408d+86cf3d8bc9,g858d7b2824+86cf3d8bc9,g8a8a8dda67+585e252eca,g99cad8db69+84912a7fdc,g9ddcbc5298+9a081db1e4,ga1e77700b3+15fc3df1f7,ga8c6da7877+a2b54eae19,gb0e22166c9+60f28cb32d,gba4ed39666+c2a2e4ac27,gbb8dafda3b+6681f309db,gc120e1dc64+f0fcc2f6d8,gc28159a63d+0e5473021a,gcf0d15dbbd+c429d67c83,gdaeeff99f8+f9a426f77a,ge6526c86ff+0433e6603d,ge79ae78c31+0e5473021a,gee10cc3b42+585e252eca,gff1a9f87cc+86cf3d8bc9,w.2024.17
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Protected Member Functions | List of all members
lsst.meas.algorithms.testUtils.MockReferenceObjectLoaderFromFiles Class Reference
Inheritance diagram for lsst.meas.algorithms.testUtils.MockReferenceObjectLoaderFromFiles:

Public Member Functions

 __init__ (self, filenames, name='cal_ref_cat', config=None, htmLevel=4)
 

Protected Member Functions

 _createDataIdsAndRefcats (self, filenames, htmLevel, name)
 

Detailed Description

A mock of ReferenceObjectLoader using files on disk.

This mock ReferenceObjectLoader uses a set of files on disk to create
mock dataIds and data reference handles that can be accessed
without a butler. The files must be afw catalog files in the reference
catalog format, sharded with HTM pixelization.

Parameters
----------
filenames : `list` [`str`]
    Names of files to use.
config : `lsst.meas.astrom.LoadReferenceObjectsConfig`, optional
    Configuration object if necessary to override defaults.
htmLevel : `int`, optional
    HTM level to use for the loader.

Definition at line 209 of file testUtils.py.

Constructor & Destructor Documentation

◆ __init__()

lsst.meas.algorithms.testUtils.MockReferenceObjectLoaderFromFiles.__init__ ( self,
filenames,
name = 'cal_ref_cat',
config = None,
htmLevel = 4 )

Definition at line 226 of file testUtils.py.

226 def __init__(self, filenames, name='cal_ref_cat', config=None, htmLevel=4):
227 dataIds, refCats = self._createDataIdsAndRefcats(filenames, htmLevel, name)
228
229 super().__init__(dataIds, refCats, name=name, config=config)
230

Member Function Documentation

◆ _createDataIdsAndRefcats()

lsst.meas.algorithms.testUtils.MockReferenceObjectLoaderFromFiles._createDataIdsAndRefcats ( self,
filenames,
htmLevel,
name )
protected
Create mock dataIds and refcat handles.

Parameters
----------
filenames : `list` [`str`]
    Names of files to use.
htmLevel : `int`
    HTM level to use for the loader.
name : `str`
    Name of reference catalog (for logging).

Returns
-------
dataIds : `list` [`MockRefcatDataId`]
    List of mock dataIds.
refCats : `list` [`lsst.pipe.base.InMemoryDatasetHandle`]
    List of mock deferred dataset handles.

Raises
------
RuntimeError if any file contains sources that cover more than one HTM
    pixel at level ``htmLevel``.

Definition at line 231 of file testUtils.py.

231 def _createDataIdsAndRefcats(self, filenames, htmLevel, name):
232 """Create mock dataIds and refcat handles.
233
234 Parameters
235 ----------
236 filenames : `list` [`str`]
237 Names of files to use.
238 htmLevel : `int`
239 HTM level to use for the loader.
240 name : `str`
241 Name of reference catalog (for logging).
242
243 Returns
244 -------
245 dataIds : `list` [`MockRefcatDataId`]
246 List of mock dataIds.
247 refCats : `list` [`lsst.pipe.base.InMemoryDatasetHandle`]
248 List of mock deferred dataset handles.
249
250 Raises
251 ------
252 RuntimeError if any file contains sources that cover more than one HTM
253 pixel at level ``htmLevel``.
254 """
255 pixelization = sphgeom.HtmPixelization(htmLevel)
256 htm = esutil.htm.HTM(htmLevel)
257
258 dataIds = []
259 refCats = []
260
261 for filename in filenames:
262 cat = afwTable.BaseCatalog.readFits(filename)
263
264 ids = htm.lookup_id(np.rad2deg(cat['coord_ra']), np.rad2deg(cat['coord_dec']))
265
266 if len(np.unique(ids)) != 1:
267 raise RuntimeError(f"File {filename} contains more than one pixel at level {htmLevel}")
268
269 dataIds.append(MockRefcatDataId(pixelization.pixel(ids[0])))
270 refCats.append(InMemoryDatasetHandle(cat, name=name))
271
272 return dataIds, refCats
273
274

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