50 l1t::RegionalMuonCand(),
53 m_addArray(), m_tsphiList(), m_tsetaList() {
67 l1t::RegionalMuonCand(),
68 m_spid(spid), m_name(
"L1MuBMTrack"), m_empty(
true),
70 m_addArray(), m_tsphiList(), m_tsetaList() {
83 l1t::RegionalMuonCand(id),
84 m_spid(id.m_spid), m_name(id.m_name), m_empty(id.m_empty),
86 m_addArray(id.m_addArray),
87 m_tsphiList(id.m_tsphiList), m_tsetaList(id.m_tsetaList) {}
173 if ( !tsList.empty() ) {
174 vector<const L1MuBMTrackSegPhi*>::const_iterator iter;
175 for ( iter = tsList.begin(); iter != tsList.end(); iter++ ) {
188 if ( !tsList.empty() ) {
189 vector<const L1MuBMTrackSegEta*>::const_iterator iter;
190 for ( iter = tsList.begin(); iter != tsList.end(); iter++ ) {
203 const float eps = 1.e-5;
207 unsigned int t_Scale = theTriggerScales->getPtScale()->getPacked( value + eps );
218 if (
this != &track ) {
241 if (
m_tc != track.
m_tc )
return false;
242 if (
bx() != track.
bx() )
return false;
243 if (
phi() != track.
phi() )
return false;
244 if (
eta() != track.
eta() )
return false;
246 if (
pt() != track.
pt() )
return false;
262 if (
m_tc != track.
m_tc )
return true;
263 if (
bx() != track.
bx() )
return true;
264 if (
phi() != track.
phi() )
return true;
265 if (
eta() != track.
eta() )
return true;
267 if (
pt() != track.
pt() )
return true;
282 cout.setf(ios::showpoint);
283 cout.setf(ios::right,ios::adjustfield);
284 cout << setiosflags(ios::showpoint | ios::fixed);
286 <<
"pt = " << setw(3) <<
hwPt() <<
" "
287 <<
"charge = " << setw(2) <<
hwSign() <<
" "
288 <<
"eta = " << setw(2) <<
hwEta()
290 <<
"phi = " << setw(3) <<
hwPhi() <<
" "
291 <<
"quality = " << setw(1) <<
hwQual() <<
'\t'
292 <<
"class = " <<
tc() <<
" "
293 <<
"bx = " << setw(2) <<
bx() << endl;
294 cout <<
" found in " <<
m_spid <<
" with phi track segments :" << endl;
295 vector<L1MuBMTrackSegPhi>::const_iterator iter;
297 cout <<
" " << (*iter) << endl;
310 s << setiosflags(ios::showpoint | ios::fixed)
311 <<
"pt = " << setw(3) <<
id.hwPt() <<
" "
312 <<
"charge = " << setw(2) <<
id.hwSign() <<
" "
313 <<
"eta = " << setw(2) <<
id.hwEta()
315 <<
"phi = " << setw(3) <<
id.hwPhi() <<
" "
316 <<
"quality = " << setw(1) <<
id.hwQual() <<
'\t'
317 <<
"bx = " << setw(2) <<
id.bx();
unsigned int pt() const
get pt-code (5 bits)
bool operator!=(const L1MuBMTrack &) const
unequal operator
L1MuBMTrack & operator=(const L1MuBMTrack &)
assignment operator
const L1MuBMTrackSegPhi & getStartTSphi() const
return start phi track segment of muon candidate
const L1MuBMTrackSegEta & getEndTSeta() const
return end eta track segment of muon candidate
std::ostream & operator<<(std::ostream &out, const ALILine &li)
std::vector< L1MuBMTrackSegEta > m_tsetaList
int charge() const
get charge (1 bit)
const int hwQual() const
Get quality code.
TrackClass tc() const
get track-class
unsigned int triggerScale(float value, const edm::EventSetup &c) const
convert pt value in GeV to pt code
void setTSeta(const std::vector< const L1MuBMTrackSegEta * > &tsList)
set eta track segments used to form the muon candidate
virtual ~L1MuBMTrack()
destructor
unsigned int phi() const
get phi-code (8 bits)
void setHwHF(bool bit)
Set HF (halo / fine eta) bit (EMTF: halo -> 1; BMTF: fine eta -> 1)
void setBx(int bx)
set charge of muon candidate
const int hwEta() const
Get compressed eta (returned int * 0.010875 = eta)
const int hwPhi() const
Get compressed local phi (returned int * 2*pi/576 = local phi in rad)
int bx() const
get the bunch crossing for this muon candidate
unsigned int quality() const
get quality
void setHwEta(int bits)
Set compressed eta as transmitted by hardware LSB = 0.010875 (9 bits)
void setTSphi(const std::vector< const L1MuBMTrackSegPhi * > &tsList)
set phi track segments used to form the muon candidate
void reset()
reset address array
void reset()
reset muon candidate
void setEta(int eta)
set eta-code of muon candidate
const L1MuBMTrackSegPhi & getEndTSphi() const
return end phi track segment of muon candidate
const int hwPt() const
Get compressed pT (returned int * 0.5 = pT (GeV))
const int hwSign() const
Get charge sign bit (charge = (-1)^(sign))
void setHwSignValid(int bits)
Set whether charge measurement is valid (0 for high pT muons)
bool operator==(const L1MuBMTrack &) const
equal operator
int eta() const
get eta-code (6 bits)
std::vector< L1MuBMTrackSegPhi > m_tsphiList
void print() const
print parameters of muon candidate
bool fineEtaBit() const
get fine eta bit
bool empty() const
is it an empty muon candidate?
const L1MuBMTrackSegEta & getStartTSeta() const
return start eta track segment of muon candidate
L1MuBMAddressArray m_addArray
L1MuBMTrack()
default constructor