-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathKDTreeLinkerTools.h
104 lines (83 loc) · 2.21 KB
/
KDTreeLinkerTools.h
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
#ifndef KDTreeLinkerToolsTemplated_h
#define KDTreeLinkerToolsTemplated_h
#include <algorithm>
using VALUE=unsigned int;
// Box structure used to define 2D field.
// It's used in KDTree building step to divide the detector
// space (ECAL, HCAL...) and in searching step to create a bounding
// box around the demanded point (Track collision point, PS projection...).
struct KDTreeBox
{
VALUE dim1min, dim1max;
VALUE dim2min, dim2max;
public:
KDTreeBox(VALUE d1min, VALUE d1max,
VALUE d2min, VALUE d2max)
: dim1min (d1min), dim1max(d1max)
, dim2min (d2min), dim2max(d2max)
{}
KDTreeBox()
: dim1min (0), dim1max(0)
, dim2min (0), dim2max(0)
{}
};
// Data stored in each KDTree node.
// The dim1/dim2 fields are usually the duplication of some PFRecHit values
// (eta/phi or x/y). But in some situations, phi field is shifted by +-2.Pi
template <typename DATA>
struct KDTreeNodeInfo
{
DATA data;
VALUE dim[2];
enum {kDim1=0, kDim2=1};
public:
KDTreeNodeInfo()
{}
KDTreeNodeInfo(const DATA& d,
VALUE dim_1,
VALUE dim_2)
: data(d), dim{dim_1, dim_2}
{}
};
template <typename DATA>
struct KDTreeNodes {
std::vector<VALUE> median; // or dimCurrent;
std::vector<int> right;
std::vector<VALUE> dimOther;
std::vector<DATA> data;
int poolSize;
int poolPos;
constexpr KDTreeNodes(): poolSize(-1), poolPos(-1) {}
bool empty() const { return poolPos == -1; }
int size() const { return poolPos + 1; }
void clear() {
median.clear();
right.clear();
dimOther.clear();
data.clear();
poolSize = -1;
poolPos = -1;
}
int getNextNode() {
++poolPos;
return poolPos;
}
void build(int sizeData) {
poolSize = sizeData*2-1;
median.resize(poolSize);
right.resize(poolSize);
dimOther.resize(poolSize);
data.resize(poolSize);
};
constexpr bool isLeaf(int right) const {
// Valid values of right are always >= 2
// index 0 is the root, and 1 is the first left node
// Exploit index values 0 and 1 to mark which of dim1/dim2 is the
// current one in recSearch() at the depth of the leaf.
return right < 2;
}
bool isLeafIndex(int index) const {
return isLeaf(right[index]);
}
};
#endif