LSST Applications g034a557a3c+dd8dd8f11d,g0afe43252f+b86e4b8053,g11f7dcd041+017865fdd3,g1cd03abf6b+8446defddb,g1ce3e0751c+f991eae79d,g28da252d5a+ca8a1a9fb3,g2bbee38e9b+b6588ad223,g2bc492864f+b6588ad223,g2cdde0e794+8523d0dbb4,g347aa1857d+b6588ad223,g35bb328faa+b86e4b8053,g3a166c0a6a+b6588ad223,g461a3dce89+b86e4b8053,g52b1c1532d+b86e4b8053,g7f3b0d46df+ad13c1b82d,g80478fca09+f29c5d6c70,g858d7b2824+293f439f82,g8cd86fa7b1+af721d2595,g965a9036f2+293f439f82,g979bb04a14+51ed57f74c,g9ddcbc5298+f24b38b85a,gae0086650b+b86e4b8053,gbb886bcc26+b97e247655,gc28159a63d+b6588ad223,gc30aee3386+a2f0f6cab9,gcaf7e4fdec+293f439f82,gcd45df26be+293f439f82,gcdd4ae20e8+70b5def7e6,gce08ada175+da9c58a417,gcf0d15dbbd+70b5def7e6,gdaeeff99f8+006e14e809,gdbce86181e+6a170ce272,ge3d4d395c2+224150c836,ge5f7162a3a+bb2241c923,ge6cb8fbbf7+d119aed356,ge79ae78c31+b6588ad223,gf048a9a2f4+40ffced2b8,gf0baf85859+b4cca3d10f,w.2024.30
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: