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
|
//-------------------------------------------------
//
// Class L1MuDTChambPhContainer
//
// Description: input data for PHTF trigger
//
//
// Author List: Jorge Troconiz UAM Madrid
//
//
//--------------------------------------------------
//-----------------------
// This Class's Header --
//-----------------------
#include "DataFormats/L1DTTrackFinder/interface/L1MuDTChambPhContainer.h"
//-------------------------------
// Collaborating Class Headers --
//-------------------------------
//---------------
// C++ Headers --
//---------------
using namespace std;
//-------------------
// Initializations --
//-------------------
//----------------
// Constructors --
//----------------
L1MuDTChambPhContainer::L1MuDTChambPhContainer(Phi_Container c) : phiSegments(std::move(c)) {}
//--------------
// Operations --
//--------------
void L1MuDTChambPhContainer::setContainer(Phi_Container inputSegments) { phiSegments = std::move(inputSegments); }
L1MuDTChambPhContainer::Phi_Container const* L1MuDTChambPhContainer::getContainer() const { return &phiSegments; }
bool L1MuDTChambPhContainer::bxEmpty(int step) const {
bool empty = true;
for (Phi_iterator i = phiSegments.begin(); i != phiSegments.end(); i++) {
if (step == i->bxNum())
empty = false;
}
return (empty);
}
int L1MuDTChambPhContainer::bxSize(int step1, int step2) const {
int size = 0;
for (Phi_iterator i = phiSegments.begin(); i != phiSegments.end(); i++) {
if (step1 <= i->bxNum() && step2 >= i->bxNum() && i->Ts2Tag() == 0 && i->code() != 7)
size++;
if (step1 <= i->bxNum() - 1 && step2 >= i->bxNum() - 1 && i->Ts2Tag() == 1 && i->code() != 7)
size++;
}
return (size);
}
L1MuDTChambPhDigi const* L1MuDTChambPhContainer::chPhiSegm1(int wheel, int stat, int sect, int step) const {
L1MuDTChambPhDigi const* rT = nullptr;
for (Phi_iterator i = phiSegments.begin(); i != phiSegments.end(); i++) {
if (step == i->bxNum() && wheel == i->whNum() && sect == i->scNum() && stat == i->stNum() && i->Ts2Tag() == 0)
rT = &(*i);
}
return (rT);
}
L1MuDTChambPhDigi const* L1MuDTChambPhContainer::chPhiSegm2(int wheel, int stat, int sect, int step) const {
L1MuDTChambPhDigi const* rT = nullptr;
for (Phi_iterator i = phiSegments.begin(); i != phiSegments.end(); i++) {
if (step == i->bxNum() - 1 && wheel == i->whNum() && sect == i->scNum() && stat == i->stNum() && i->Ts2Tag() == 1)
rT = &(*i);
}
return (rT);
}
|