LSST Applications  21.0.0-172-gfb10e10a+18fedfabac,22.0.0+297cba6710,22.0.0+80564b0ff1,22.0.0+8d77f4f51a,22.0.0+a28f4c53b1,22.0.0+dcf3732eb2,22.0.1-1-g7d6de66+2a20fdde0d,22.0.1-1-g8e32f31+297cba6710,22.0.1-1-geca5380+7fa3b7d9b6,22.0.1-12-g44dc1dc+2a20fdde0d,22.0.1-15-g6a90155+515f58c32b,22.0.1-16-g9282f48+790f5f2caa,22.0.1-2-g92698f7+dcf3732eb2,22.0.1-2-ga9b0f51+7fa3b7d9b6,22.0.1-2-gd1925c9+bf4f0e694f,22.0.1-24-g1ad7a390+a9625a72a8,22.0.1-25-g5bf6245+3ad8ecd50b,22.0.1-25-gb120d7b+8b5510f75f,22.0.1-27-g97737f7+2a20fdde0d,22.0.1-32-gf62ce7b1+aa4237961e,22.0.1-4-g0b3f228+2a20fdde0d,22.0.1-4-g243d05b+871c1b8305,22.0.1-4-g3a563be+32dcf1063f,22.0.1-4-g44f2e3d+9e4ab0f4fa,22.0.1-42-gca6935d93+ba5e5ca3eb,22.0.1-5-g15c806e+85460ae5f3,22.0.1-5-g58711c4+611d128589,22.0.1-5-g75bb458+99c117b92f,22.0.1-6-g1c63a23+7fa3b7d9b6,22.0.1-6-g50866e6+84ff5a128b,22.0.1-6-g8d3140d+720564cf76,22.0.1-6-gd805d02+cc5644f571,22.0.1-8-ge5750ce+85460ae5f3,master-g6e05de7fdc+babf819c66,master-g99da0e417a+8d77f4f51a,w.2021.48
LSST Data Management Base Package
Functions | Variables
lsst.afw.table._match Namespace Reference

Functions

def __repr__ (self)
 
def __str__ (self)
 
def __getitem__ (self, i)
 
def __setitem__ (self, i, val)
 
def __len__ (self)
 
def clone (self)
 
def packMatches (matches)
 

Variables

 clone
 
 first
 
 second
 
 distance
 

Function Documentation

◆ __getitem__()

def lsst.afw.table._match.__getitem__ (   self,
  i 
)
Treat a Match as a tuple of length 3: (first, second, distance)

Definition at line 53 of file _match.py.

53 def __getitem__(self, i): # noqa: N807
54  """Treat a Match as a tuple of length 3: (first, second, distance)"""
55  if i > 2 or i < -3:
56  raise IndexError(i)
57  if i < 0:
58  i += 3
59  if i == 0:
60  return self.first
61  elif i == 1:
62  return self.second
63  else:
64  return self.distance
65 
66 
def __getitem__(self, i)
Definition: _match.py:53

◆ __len__()

def lsst.afw.table._match.__len__ (   self)

Definition at line 81 of file _match.py.

81 def __len__(self): # noqa: N807
82  return 3
83 
84 
def __len__(self)
Definition: _match.py:81

◆ __repr__()

def lsst.afw.table._match.__repr__ (   self)

Definition at line 31 of file _match.py.

31 def __repr__(self): # noqa: N807
32  return "Match(%s,\n %s,\n %g)" % \
33  (repr(self.first), repr(self.second), self.distance)
34 
35 
def __repr__(self)
Definition: _match.py:31

◆ __setitem__()

def lsst.afw.table._match.__setitem__ (   self,
  i,
  val 
)
Treat a Match as a tuple of length 3: (first, second, distance)

Definition at line 67 of file _match.py.

67 def __setitem__(self, i, val): # noqa: N807
68  """Treat a Match as a tuple of length 3: (first, second, distance)"""
69  if i > 2 or i < -3:
70  raise IndexError(i)
71  if i < 0:
72  i += 3
73  if i == 0:
74  self.first = val
75  elif i == 1:
76  self.second = val
77  else:
78  self.distance = val
79 
80 
def __setitem__(self, i, val)
Definition: _match.py:67

◆ __str__()

def lsst.afw.table._match.__str__ (   self)

Definition at line 36 of file _match.py.

36 def __str__(self): # noqa: N807
37  def sourceRaDec(s):
38  if hasattr(s, "getRa") and hasattr(s, "getDec"):
39  return " RA,Dec=(%g,%g) deg" % (s.getRa().asDegrees(), s.getDec().asDegrees())
40  return ""
41 
42  def sourceXy(s):
43  if hasattr(s, "getX") and hasattr(s, "getY"):
44  return " x,y=(%g,%g)" % (s.getX(), s.getY())
45  return ""
46 
47  def sourceStr(s):
48  return s.__class__.__name__ + ("(id %d" % s.getId()) + sourceRaDec(s) + sourceXy(s) + ")"
49 
50  return "Match(%s, %s, dist %g)" % (sourceStr(self.first), sourceStr(self.second), self.distance,)
51 
52 
def __str__(self)
Definition: _match.py:36

◆ clone()

def lsst.afw.table._match.clone (   self)

Definition at line 85 of file _match.py.

85 def clone(self):
86  return self.__class__(self.first, self.second, self.distance)
87 
88 
89 # Pickling support disabled for this type (see testSourceMatch comment for reasoning)
90 # def __getstate__(self):
91 # return self.first, self.second, self.distance
92 #
93 #
94 # def __setstate__(self, state):
95 # self.__init__(*state)
96 
97 

◆ packMatches()

def lsst.afw.table._match.packMatches (   matches)
Make a catalog of matches from a sequence of matches.

The catalog contains three fields:
- first: the ID of the first source record in each match
- second: the ID of the second source record in each match
- distance: the distance of each match

Parameters
----------
matches :
    Sequence of matches, typically of type SimpleMatch,
    ReferenceMatch or SourceMatch.  Each element must support:
    `.first.getId()`->int, `.second.getId()->int` and
    `.distance->float`.

Returns
-------
result :
    The catalog of matches.

Notes
-----
This pure python implementation exists as a historical artifact
related to SWIG limitations. It might be practical to wrap the
overloaded C++ functions with pybind11, but there didn't seem much
point.

Definition at line 109 of file _match.py.

109 def packMatches(matches):
110  """Make a catalog of matches from a sequence of matches.
111 
112  The catalog contains three fields:
113  - first: the ID of the first source record in each match
114  - second: the ID of the second source record in each match
115  - distance: the distance of each match
116 
117  Parameters
118  ----------
119  matches :
120  Sequence of matches, typically of type SimpleMatch,
121  ReferenceMatch or SourceMatch. Each element must support:
122  `.first.getId()`->int, `.second.getId()->int` and
123  `.distance->float`.
124 
125  Returns
126  -------
127  result :
128  The catalog of matches.
129 
130  Notes
131  -----
132  This pure python implementation exists as a historical artifact
133  related to SWIG limitations. It might be practical to wrap the
134  overloaded C++ functions with pybind11, but there didn't seem much
135  point.
136  """
137  schema = Schema()
138  outKey1 = schema.addField("first", type=np.int64,
139  doc="ID for first source record in match.")
140  outKey2 = schema.addField("second", type=np.int64,
141  doc="ID for second source record in match.")
142  keyD = schema.addField("distance", type=np.float64,
143  doc="Distance between matches sources.")
144  result = BaseCatalog(schema)
145  result.table.preallocate(len(matches))
146  for match in matches:
147  record = result.addNew()
148  record.set(outKey1, match.first.getId())
149  record.set(outKey2, match.second.getId())
150  record.set(keyD, match.distance)
151  return result
def packMatches(matches)
Definition: _match.py:109
CatalogT< BaseRecord > BaseCatalog
Definition: fwd.h:72

Variable Documentation

◆ clone

lsst.afw.table._match.clone

Definition at line 104 of file _match.py.

◆ distance

lsst.afw.table._match.distance

Definition at line 78 of file _match.py.

◆ first

lsst.afw.table._match.first

Definition at line 74 of file _match.py.

◆ second

lsst.afw.table._match.second

Definition at line 76 of file _match.py.