-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathLinearApproximation.py
121 lines (87 loc) · 2.71 KB
/
LinearApproximation.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
__author__ = 'mikhail91'
import numpy
coleventX = 4
class LinearApproximation(object):
def __init__(self, min_hits=4, window_width=0.03):
"""
Track Pattern Recognition based on the linear approximation.
Parameters
----------
min_hits : int
Minimum number of hits of one track.
window_width : float
Phi window width.
"""
self.min_hits = min_hits
self.window_width = window_width
def get_phi(self, x, y):
"""
Calculate hits phi coordinates in polar system.
Parameters
----------
x : array-like
X-coordinates of hits.
y : array-like
Y-coordinates of hits.
Returns
-------
phi : array-like
Phi coordinates of hits.
"""
x = numpy.array(x)
y = numpy.array(y)
phi = numpy.arctan(y / x) * (x != 0) + numpy.pi * (x < 0) + 0.5 * numpy.pi * (x==0) * (y>0) + 1.5 * numpy.pi * (x==0) * (y<0)
return phi
def fit(self, X, y):
pass
def predict_one_event(self, X):
"""
Track Pattern Recognition for one event.
Parameters
----------
X : ndarray-like
Hit features.
Returns
-------
labels : array-like
Recognized track labels.
"""
x, y, layer = X[:, 2], X[:, 3], X[:, 0]
used = numpy.zeros(len(x))
labels = -1. * numpy.ones(len(x))
track_id = 0
# calculate phi of the hits
phis = self.get_phi(x, y)
# Go through each hit
for first_id in numpy.arange(0, len(x)):
x1 = x[first_id]
y1 = y[first_id]
phi1 = self.get_phi(x1, y1)
track_inds = numpy.arange(len(x))[(numpy.abs(phis - phi1) <= self.window_width)*(used == 0)]
if len(track_inds) >= self.min_hits:
used[track_inds] = 1
labels[track_inds] = track_id
track_id += 1
return labels
def predict(self, X):
"""
Track Pattern Recognition for all event.
Parameters
----------
X : ndarray-like
Hit features.
Returns
-------
labels : array-like
Recognized track labels.
"""
event_ids = numpy.unique(X[:, coleventX])
y = numpy.zeros((len(X),2))
labels = []
for one_event_id in event_ids:
X_event = X[X[:, coleventX] == one_event_id]
labels_event = self.predict_one_event(X_event)
labels += list(labels_event)
y[:,0] = labels
y[:,1] = X[:, coleventX]
return y