LSST Applications 27.0.0,g0265f82a02+469cd937ee,g02d81e74bb+21ad69e7e1,g1470d8bcf6+cbe83ee85a,g2079a07aa2+e67c6346a6,g212a7c68fe+04a9158687,g2305ad1205+94392ce272,g295015adf3+81dd352a9d,g2bbee38e9b+469cd937ee,g337abbeb29+469cd937ee,g3939d97d7f+72a9f7b576,g487adcacf7+71499e7cba,g50ff169b8f+5929b3527e,g52b1c1532d+a6fc98d2e7,g591dd9f2cf+df404f777f,g5a732f18d5+be83d3ecdb,g64a986408d+21ad69e7e1,g858d7b2824+21ad69e7e1,g8a8a8dda67+a6fc98d2e7,g99cad8db69+f62e5b0af5,g9ddcbc5298+d4bad12328,ga1e77700b3+9c366c4306,ga8c6da7877+71e4819109,gb0e22166c9+25ba2f69a1,gb6a65358fc+469cd937ee,gbb8dafda3b+69d3c0e320,gc07e1c2157+a98bf949bb,gc120e1dc64+615ec43309,gc28159a63d+469cd937ee,gcf0d15dbbd+72a9f7b576,gdaeeff99f8+a38ce5ea23,ge6526c86ff+3a7c1ac5f1,ge79ae78c31+469cd937ee,gee10cc3b42+a6fc98d2e7,gf1cff7945b+21ad69e7e1,gfbcc870c63+9a11dc8c8f
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: