CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Private Attributes
l1t::MicroGMTMatchQualLUT Class Reference

#include <MicroGMTMatchQualLUT.h>

Inheritance diagram for l1t::MicroGMTMatchQualLUT:
l1t::MicroGMTLUT

Public Member Functions

int getDeltaEtaWidth () const
 
int getDeltaPhiWidth () const
 
int hashInput (int dEta, int dPhi) const
 
int lookup (int dEta, int dPhi) const
 
virtual int lookupPacked (int in) const
 
 MicroGMTMatchQualLUT ()
 
 MicroGMTMatchQualLUT (const edm::ParameterSet &, std::string, cancel_t cancelType)
 
void unHashInput (int input, int &dEta, int &dPhi) const
 
virtual ~MicroGMTMatchQualLUT ()
 
- Public Member Functions inherited from l1t::MicroGMTLUT
int checkedInput (unsigned in, unsigned maxWidth) const
 
void contentsToStream (std::stringstream &stream)
 
void headerToStream (std::stringstream &stream) const
 
void initialize ()
 
void load (const std::string &inFileName)
 
 MicroGMTLUT ()
 
void save (std::ofstream &output)
 
virtual ~MicroGMTLUT ()
 

Private Attributes

cancel_t m_cancelType
 
int m_dEtaRedInWidth
 
int m_dEtaRedMask
 
int m_dPhiRedInWidth
 
int m_dPhiRedMask
 
double m_etaScale
 
double m_phiScale
 

Additional Inherited Members

- Protected Attributes inherited from l1t::MicroGMTLUT
std::map< int, int > m_contents
 
std::string m_fname
 
bool m_initialized
 
std::vector
< MicroGMTConfiguration::input_t
m_inputs
 
unsigned m_outWidth
 
unsigned m_totalInWidth
 

Detailed Description

Definition at line 15 of file MicroGMTMatchQualLUT.h.

Constructor & Destructor Documentation

l1t::MicroGMTMatchQualLUT::MicroGMTMatchQualLUT ( )
l1t::MicroGMTMatchQualLUT::MicroGMTMatchQualLUT ( const edm::ParameterSet iConfig,
std::string  prefix,
cancel_t  cancelType 
)
explicit

Definition at line 4 of file MicroGMTMatchQualLUT.cc.

References HDQMDatabaseProducer::config, l1t::MicroGMTConfiguration::DELTA_ETA_RED, l1t::MicroGMTConfiguration::DELTA_PHI_RED, edm::ParameterSet::getParameter(), l1t::MicroGMTLUT::initialize(), l1t::MicroGMTLUT::load(), m_dEtaRedInWidth, m_dEtaRedMask, m_dPhiRedInWidth, m_dPhiRedMask, m_etaScale, l1t::MicroGMTLUT::m_fname, l1t::MicroGMTLUT::m_inputs, m_phiScale, l1t::MicroGMTLUT::m_totalInWidth, Pi, and AlCaHLTBitMon_QueryRunRegistry::string.

4  :
6 {
7  edm::ParameterSet config = iConfig.getParameter<edm::ParameterSet>(prefix+"MatchQualLUTSettings");
8  m_dPhiRedInWidth = config.getParameter<int>("deltaPhiRed_in_width");
9  m_dEtaRedInWidth = config.getParameter<int>("deltaEtaRed_in_width");
10 
11  m_totalInWidth = m_dPhiRedInWidth + m_dEtaRedInWidth;
12 
13  m_dEtaRedMask = (1 << m_dEtaRedInWidth) - 1;
14  m_dPhiRedMask = (1 << (m_totalInWidth - 1)) - m_dEtaRedMask - 1;
15 
18 
19  m_phiScale = 2*TMath::Pi()/576.0;
20  m_etaScale = 0.010875;
21 
22  std::string m_fname = config.getParameter<std::string>("filename");
23  if (m_fname != std::string("")) {
24  load(m_fname);
25  } else {
26  initialize();
27  }
28 }
const double Pi
T getParameter(std::string const &) const
unsigned m_totalInWidth
Definition: MicroGMTLUT.h:35
std::vector< MicroGMTConfiguration::input_t > m_inputs
Definition: MicroGMTLUT.h:37
std::string m_fname
Definition: MicroGMTLUT.h:39
void load(const std::string &inFileName)
Definition: MicroGMTLUT.cc:18
l1t::MicroGMTMatchQualLUT::~MicroGMTMatchQualLUT ( )
virtual

Definition at line 30 of file MicroGMTMatchQualLUT.cc.

31 {
32 
33 }

Member Function Documentation

int l1t::MicroGMTMatchQualLUT::getDeltaEtaWidth ( ) const
inline
int l1t::MicroGMTMatchQualLUT::getDeltaPhiWidth ( ) const
inline
int l1t::MicroGMTMatchQualLUT::hashInput ( int  dEta,
int  dPhi 
) const

Definition at line 72 of file MicroGMTMatchQualLUT.cc.

References query::result.

73 {
74 
75  int result = 0;
76  result += dEtaRed;
77  result += dPhiRed << m_dEtaRedInWidth;
78  return result;
79 }
tuple result
Definition: query.py:137
int l1t::MicroGMTMatchQualLUT::lookup ( int  dEta,
int  dPhi 
) const

Definition at line 37 of file MicroGMTMatchQualLUT.cc.

References dPhi(), PFRecoTauDiscriminationAgainstElectronDeadECAL_cfi::dR, and mathSSE::sqrt().

Referenced by l1t::MicroGMTCancelOutUnit::getCoordinateCancelBits().

38 {
39  // normalize these two to the same scale and then calculate?
40  if (m_initialized) {
42  }
43  double dEta = dEtaRed*m_etaScale;
44  double dPhi = dPhiRed*m_phiScale;
45 
46  double dR = std::sqrt(dEta*dEta + dPhi*dPhi);
47 
48  int retVal = dR < 0.1 ? 1 : 0;
49  // should we need customisation for the different track finder cancellations:
50  // switch (m_cancelType) {
51  // case bmtf_bmtf:
52  // retVal = dR < 0.1 ? 1 : 0;
53  // case default:
54  // retVal = dR < 0.1 ? 1 : 0
55  // }
56 
57  return retVal;
58 }
std::map< int, int > m_contents
Definition: MicroGMTLUT.h:38
int checkedInput(unsigned in, unsigned maxWidth) const
Definition: MicroGMTLUT.cc:70
double dPhi(double phi1, double phi2)
Definition: JetUtil.h:30
T sqrt(T t)
Definition: SSEVec.h:48
int hashInput(int dEta, int dPhi) const
int l1t::MicroGMTMatchQualLUT::lookupPacked ( int  in) const
virtual

Reimplemented from l1t::MicroGMTLUT.

Definition at line 60 of file MicroGMTMatchQualLUT.cc.

60  {
61  if (m_initialized) {
62  return m_contents.at(in);
63  }
64 
65  int dEtaRed = 0;
66  int dPhiRed = 0;
67  unHashInput(in, dEtaRed, dPhiRed);
68  return lookup(dEtaRed, dPhiRed);
69 }
std::map< int, int > m_contents
Definition: MicroGMTLUT.h:38
int lookup(int dEta, int dPhi) const
void unHashInput(int input, int &dEta, int &dPhi) const
void l1t::MicroGMTMatchQualLUT::unHashInput ( int  input,
int &  dEta,
int &  dPhi 
) const

Definition at line 82 of file MicroGMTMatchQualLUT.cc.

83 {
84  dEtaRed = input & m_dEtaRedMask;
85  dPhiRed = (input & m_dPhiRedMask) >> m_dEtaRedInWidth;
86 }
static std::string const input
Definition: EdmProvDump.cc:43

Member Data Documentation

cancel_t l1t::MicroGMTMatchQualLUT::m_cancelType
private

Definition at line 37 of file MicroGMTMatchQualLUT.h.

int l1t::MicroGMTMatchQualLUT::m_dEtaRedInWidth
private

Definition at line 31 of file MicroGMTMatchQualLUT.h.

Referenced by getDeltaEtaWidth(), and MicroGMTMatchQualLUT().

int l1t::MicroGMTMatchQualLUT::m_dEtaRedMask
private

Definition at line 29 of file MicroGMTMatchQualLUT.h.

Referenced by MicroGMTMatchQualLUT().

int l1t::MicroGMTMatchQualLUT::m_dPhiRedInWidth
private

Definition at line 32 of file MicroGMTMatchQualLUT.h.

Referenced by getDeltaPhiWidth(), and MicroGMTMatchQualLUT().

int l1t::MicroGMTMatchQualLUT::m_dPhiRedMask
private

Definition at line 30 of file MicroGMTMatchQualLUT.h.

Referenced by MicroGMTMatchQualLUT().

double l1t::MicroGMTMatchQualLUT::m_etaScale
private

Definition at line 34 of file MicroGMTMatchQualLUT.h.

Referenced by MicroGMTMatchQualLUT().

double l1t::MicroGMTMatchQualLUT::m_phiScale
private

Definition at line 35 of file MicroGMTMatchQualLUT.h.

Referenced by MicroGMTMatchQualLUT().