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
|
//-------------------------------------------------
//
// Class L1MuDTTrackContainer
//
// Description: output data for DTTF trigger
//
//
// Author List: Jorge Troconiz UAM Madrid
//
//
//--------------------------------------------------
//-----------------------
// This Class's Header --
//-----------------------
#include "DataFormats/L1DTTrackFinder/interface/L1MuDTTrackContainer.h"
//-------------------------------
// Collaborating Class Headers --
//-------------------------------
//---------------
// C++ Headers --
//---------------
using namespace std;
//-------------------
// Initializations --
//-------------------
//----------------
// Constructors --
//----------------
L1MuDTTrackContainer::L1MuDTTrackContainer() {}
//--------------
// Destructor --
//--------------
L1MuDTTrackContainer::~L1MuDTTrackContainer() {}
//--------------
// Operations --
//--------------
void L1MuDTTrackContainer::setContainer(const TrackContainer& inputTracks) { dtTracks = inputTracks; }
L1MuDTTrackContainer::TrackContainer const* L1MuDTTrackContainer::getContainer() const { return &dtTracks; }
bool L1MuDTTrackContainer::bxEmpty(int step) const {
bool empty = true;
for (Trackiterator i = dtTracks.begin(); i != dtTracks.end(); i++) {
if (step == i->bx())
empty = false;
}
return (empty);
}
int L1MuDTTrackContainer::bxSize(int step1, int step2) const {
int size = 0;
for (Trackiterator i = dtTracks.begin(); i != dtTracks.end(); i++) {
if (step1 <= i->bx() && step2 >= i->bx() && i->quality_packed() != 0)
size++;
}
return (size);
}
L1MuDTTrackCand const* L1MuDTTrackContainer::dtTrackCand1(int wheel, int sect, int step) const {
L1MuDTTrackCand const* rT = nullptr;
for (Trackiterator i = dtTracks.begin(); i != dtTracks.end(); i++) {
if (step == i->bx() && wheel == i->whNum() && sect == i->scNum() && i->TrkTag() == 0)
rT = &(*i);
}
return (rT);
}
L1MuDTTrackCand const* L1MuDTTrackContainer::dtTrackCand2(int wheel, int sect, int step) const {
L1MuDTTrackCand const* rT = nullptr;
for (Trackiterator i = dtTracks.begin(); i != dtTracks.end(); i++) {
if (step == i->bx() && wheel == i->whNum() && sect == i->scNum() && i->TrkTag() == 1)
rT = &(*i);
}
return (rT);
}
|