LSST Applications g063fba187b+66a50001ff,g0f08755f38+1a22dc2551,g1653933729+a8ce1bb630,g168dd56ebc+a8ce1bb630,g217e2c1bcf+12e87a5bd8,g246886dfd9+466c7b6c06,g28da252d5a+858b171e04,g2bbee38e9b+404b60ec9b,g2bc492864f+404b60ec9b,g3156d2b45e+6e55a43351,g347aa1857d+404b60ec9b,g35bb328faa+a8ce1bb630,g3a166c0a6a+404b60ec9b,g3e281a1b8c+c5dd892a6c,g414038480c+6b9177ef31,g41af890bb2+70bea58702,g599934f4f4+b8c5400ca5,g781aacb6e4+a8ce1bb630,g7af13505b9+b5b9cefdb8,g80478fca09+c2997882f3,g82479be7b0+8974e6af0f,g858d7b2824+1a22dc2551,g89c8672015+f4add4ffd5,g8f1c07a47a+de51c9b0a5,g9125e01d80+a8ce1bb630,ga5288a1d22+b66f8cf76b,gb58c049af0+d64f4d3760,gc28159a63d+404b60ec9b,gcab2d0539d+66cf1de5d4,gcf0d15dbbd+12cb7e2563,gda6a2b7d83+12cb7e2563,gdaeeff99f8+1711a396fd,ge79ae78c31+404b60ec9b,gef2f8181fd+414189b318,gf0baf85859+c1f95f4921,gf0c06eb49c+1a22dc2551,gfa517265be+1a22dc2551,gfa999e8aa5+17cd334064,v28.0.0.rc2
LSST Data Management Base Package
Loading...
Searching...
No Matches
Public Member Functions | Static Public Member Functions | Public Attributes | List of all members
lsst.meas.algorithms.htmIndexer.HtmIndexer Class Reference

Public Member Functions

 __init__ (self, depth=7)
 
 getShardIds (self, ctrCoord, radius)
 
 indexPoints (self, raList, decList)
 

Static Public Member Functions

 makeDataId (shardId, datasetName)
 

Public Attributes

 htm
 

Detailed Description

Manage a spatial index of hierarchical triangular mesh (HTM)
shards.

Parameters
----------
depth : `int`
    Depth of the HTM hierarchy to construct.

Definition at line 29 of file htmIndexer.py.

Constructor & Destructor Documentation

◆ __init__()

lsst.meas.algorithms.htmIndexer.HtmIndexer.__init__ ( self,
depth = 7 )

Definition at line 38 of file htmIndexer.py.

38 def __init__(self, depth=7):
39 self.htm = esutil.htm.HTM(depth)
40

Member Function Documentation

◆ getShardIds()

lsst.meas.algorithms.htmIndexer.HtmIndexer.getShardIds ( self,
ctrCoord,
radius )
Get the IDs of all shards that touch a circular aperture.

Parameters
----------
ctrCoord : `lsst.geom.SpherePoint`
    ICRS center of search region.
radius : `lsst.geom.Angle`
    Radius of search region.

Returns
-------
results : `tuple`
    A tuple containing:

    - shardIdList : `list` of `int`
        List of shard IDs
    - isOnBoundary : `list` of `bool`
        For each shard in ``shardIdList`` is the shard on the
        boundary (not fully enclosed by the search region)?

Definition at line 41 of file htmIndexer.py.

41 def getShardIds(self, ctrCoord, radius):
42 """Get the IDs of all shards that touch a circular aperture.
43
44 Parameters
45 ----------
46 ctrCoord : `lsst.geom.SpherePoint`
47 ICRS center of search region.
48 radius : `lsst.geom.Angle`
49 Radius of search region.
50
51 Returns
52 -------
53 results : `tuple`
54 A tuple containing:
55
56 - shardIdList : `list` of `int`
57 List of shard IDs
58 - isOnBoundary : `list` of `bool`
59 For each shard in ``shardIdList`` is the shard on the
60 boundary (not fully enclosed by the search region)?
61 """
62 shardIdList = self.htm.intersect(ctrCoord.getLongitude().asDegrees(),
63 ctrCoord.getLatitude().asDegrees(),
64 radius.asDegrees(), inclusive=True)
65 coveredShardIdList = self.htm.intersect(ctrCoord.getLongitude().asDegrees(),
66 ctrCoord.getLatitude().asDegrees(),
67 radius.asDegrees(), inclusive=False)
68 isOnBoundary = (shardId not in coveredShardIdList for shardId in shardIdList)
69 return shardIdList, isOnBoundary
70

◆ indexPoints()

lsst.meas.algorithms.htmIndexer.HtmIndexer.indexPoints ( self,
raList,
decList )
Generate shard IDs for sky positions.

Parameters
----------
raList : `list` of `float`
    List of right ascensions, in degrees.
decList : `list` of `float`
    List of declinations, in degrees.

Returns
-------
shardIds : `list` of `int`
    List of shard IDs

Definition at line 71 of file htmIndexer.py.

71 def indexPoints(self, raList, decList):
72 """Generate shard IDs for sky positions.
73
74 Parameters
75 ----------
76 raList : `list` of `float`
77 List of right ascensions, in degrees.
78 decList : `list` of `float`
79 List of declinations, in degrees.
80
81 Returns
82 -------
83 shardIds : `list` of `int`
84 List of shard IDs
85 """
86 return self.htm.lookup_id(raList, decList)
87

◆ makeDataId()

lsst.meas.algorithms.htmIndexer.HtmIndexer.makeDataId ( shardId,
datasetName )
static
Make a data id from a shard ID.

Parameters
----------
shardId : `int`
    ID of shard in question.
datasetName : `str`
    Name of dataset to use.

Returns
-------
dataId : `dict`
    Data ID for shard.

Definition at line 89 of file htmIndexer.py.

89 def makeDataId(shardId, datasetName):
90 """Make a data id from a shard ID.
91
92 Parameters
93 ----------
94 shardId : `int`
95 ID of shard in question.
96 datasetName : `str`
97 Name of dataset to use.
98
99 Returns
100 -------
101 dataId : `dict`
102 Data ID for shard.
103 """
104 if shardId is None:
105 # NoneType doesn't format, so make dummy pixel
106 shardId = 0
107 return {'pixel_id': shardId, 'name': datasetName}

Member Data Documentation

◆ htm

lsst.meas.algorithms.htmIndexer.HtmIndexer.htm

Definition at line 39 of file htmIndexer.py.


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