CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Types | Public Member Functions | Private Member Functions
L1MuGMTLFMergeRankCombineLUT Class Reference

#include <L1MuGMTLFMergeRankCombineLUT.h>

Inheritance diagram for L1MuGMTLFMergeRankCombineLUT:
L1MuGMTLUT

Public Types

enum  { DT, BRPC, CSC, FRPC }
 
- Public Types inherited from L1MuGMTLUT
typedef std::pair< std::string,
unsigned > 
port
 

Public Member Functions

 L1MuGMTLFMergeRankCombineLUT ()
 constuctor using function-lookup More...
 
virtual unsigned LookupFunctionPacked (int idx, unsigned address) const
 access to lookup function with packed input and output More...
 
unsigned SpecificLookup (int idx, unsigned rank_etaq, unsigned rank_ptq, unsigned rank_etaphi) const
 specific lookup function for entire output field More...
 
unsigned SpecificLookup_merge_rank (int idx, unsigned rank_etaq, unsigned rank_ptq, unsigned rank_etaphi) const
 specific lookup function for merge_rank More...
 
virtual ~L1MuGMTLFMergeRankCombineLUT ()
 destructor More...
 
- Public Member Functions inherited from L1MuGMTLUT
 L1MuGMTLUT ()
 Init and Destruct. More...
 
 L1MuGMTLUT (const char *name, const std::vector< std::string > &instances, const std::vector< port > &in_widths, const std::vector< port > &out_widths, unsigned vme_addr_width=0, bool distrRAM=false)
 constructor with init More...
 
 L1MuGMTLUT (const char *name, const std::string &instances, const std::string &inputs, const std::string &outputs, unsigned vme_addr_width=0, bool distrRAM=false)
 
void Load (const char *path)
 I/O functions. More...
 
std::vector< unsigned > Lookup (int idx, const std::vector< unsigned > &address) const
 additional lookup function (std::vector -> vector) More...
 
std::vector< unsigned > Lookup (int idx, unsigned address) const
 additional lookup function (unsigned -> std::vector) More...
 
unsigned LookupPacked (int idx, unsigned) const
 
unsigned LookupPacked (int idx, const std::vector< unsigned > &address) const
 additional lookup function (std::vector -> unisgned) More...
 
void MakeSubClass (const char *fname="", const char *template_file_h="../interface/L1MuGMTLUT_SubClass.h_template", const char *template_file_cc="../interface/L1MuGMTLUT_SubClass.cc_template")
 Add Generate SubClass method. More...
 
std::string Name ()
 
int numberOfInstances ()
 get the number of Instances More...
 
void Save (const char *path)
 save to LUT file More...
 
virtual ~L1MuGMTLUT ()
 destructor More...
 

Private Member Functions

void InitParameters ()
 Initialize scales, configuration parameters, alignment constants, ... More...
 
unsigned TheLookupFunction (int idx, unsigned rank_etaq, unsigned rank_ptq, unsigned rank_etaphi) const
 The lookup function - here the functionality of the LUT is implemented. More...
 

Additional Inherited Members

- Protected Member Functions inherited from L1MuGMTLUT
void Init (const char *name, const std::vector< std::string > &instances, const std::vector< port > &in_widths, const std::vector< port > &out_widths, unsigned vme_addr_width=0, bool distrRAM=false)
 Initialize the LUT. More...
 
void Set (int idx, unsigned address, unsigned value)
 set with single address and value More...
 
std::vector< unsigned > u2vec (unsigned value, const std::vector< port > &widths) const
 generate composite address or value from compact unsigned More...
 
unsigned vec2u (const std::vector< unsigned > &vec, const std::vector< port > &widths) const
 generate address or value from composite address or value More...
 
- Protected Attributes inherited from L1MuGMTLUT
std::vector< std::vector
< unsigned > > 
m_Contents
 
bool m_distrRAM
 
unsigned m_GeneralLUTVersion
 
bool m_initialized
 
std::vector< portm_Inputs
 
std::vector< std::string > m_InstNames
 
std::string m_name
 
int m_NLUTS
 
std::vector< portm_Outputs
 
bool m_saveFlag
 
unsigned m_TotalInWidth
 
unsigned m_TotalOutWidth
 
bool m_UseLookupFunction
 
unsigned m_vme_addr_width
 

Detailed Description

LFMergeRankCombine look-up table

this class was automatically generated by L1MuGMTLUT::MakeSubClass()

Definition at line 42 of file L1MuGMTLFMergeRankCombineLUT.h.

Member Enumeration Documentation

anonymous enum

Constructor & Destructor Documentation

L1MuGMTLFMergeRankCombineLUT::L1MuGMTLFMergeRankCombineLUT ( )
inline

constuctor using function-lookup

Definition at line 48 of file L1MuGMTLFMergeRankCombineLUT.h.

References InitParameters().

48  : L1MuGMTLUT("LFMergeRankCombine",
49  "DT BRPC CSC FRPC",
50  "rank_etaq(7) rank_ptq(2) rank_etaphi(1)",
51  "merge_rank(8)", 9, false) {
53  } ;
L1MuGMTLUT()
Init and Destruct.
Definition: L1MuGMTLUT.h:85
void InitParameters()
Initialize scales, configuration parameters, alignment constants, ...
virtual L1MuGMTLFMergeRankCombineLUT::~L1MuGMTLFMergeRankCombineLUT ( )
inlinevirtual

destructor

Definition at line 56 of file L1MuGMTLFMergeRankCombineLUT.h.

56 {};

Member Function Documentation

void L1MuGMTLFMergeRankCombineLUT::InitParameters ( )
private

Initialize scales, configuration parameters, alignment constants, ...

Definition at line 34 of file L1MuGMTLFMergeRankCombineLUT.cc.

Referenced by L1MuGMTLFMergeRankCombineLUT().

34  {
35 }
virtual unsigned L1MuGMTLFMergeRankCombineLUT::LookupFunctionPacked ( int  idx,
unsigned  address 
) const
inlinevirtual

access to lookup function with packed input and output

Reimplemented from L1MuGMTLUT.

Definition at line 80 of file L1MuGMTLFMergeRankCombineLUT.h.

References L1MuGMTLUT::m_Inputs, TheLookupFunction(), and L1MuGMTLUT::u2vec().

80  {
81  std::vector<unsigned> addr = u2vec(address, m_Inputs);
82  return TheLookupFunction(idx ,addr[0] ,addr[1] ,addr[2]);
83 
84  };
char * address
Definition: mlp_lapack.h:14
unsigned TheLookupFunction(int idx, unsigned rank_etaq, unsigned rank_ptq, unsigned rank_etaphi) const
The lookup function - here the functionality of the LUT is implemented.
std::vector< port > m_Inputs
Definition: L1MuGMTLUT.h:203
tuple idx
DEBUGGING if hasattr(process,&quot;trackMonIterativeTracking2012&quot;): print &quot;trackMonIterativeTracking2012 D...
std::vector< unsigned > u2vec(unsigned value, const std::vector< port > &widths) const
generate composite address or value from compact unsigned
Definition: L1MuGMTLUT.h:241
unsigned L1MuGMTLFMergeRankCombineLUT::SpecificLookup ( int  idx,
unsigned  rank_etaq,
unsigned  rank_ptq,
unsigned  rank_etaphi 
) const
inline

specific lookup function for entire output field

Definition at line 68 of file L1MuGMTLFMergeRankCombineLUT.h.

References L1MuGMTLUT::LookupPacked().

68  {
69  std::vector<unsigned> addr(3);
70  addr[0] = rank_etaq;
71  addr[1] = rank_ptq;
72  addr[2] = rank_etaphi;
73  return LookupPacked(idx, addr);
74  };
tuple idx
DEBUGGING if hasattr(process,&quot;trackMonIterativeTracking2012&quot;): print &quot;trackMonIterativeTracking2012 D...
unsigned LookupPacked(int idx, unsigned) const
Definition: L1MuGMTLUT.h:262
unsigned L1MuGMTLFMergeRankCombineLUT::SpecificLookup_merge_rank ( int  idx,
unsigned  rank_etaq,
unsigned  rank_ptq,
unsigned  rank_etaphi 
) const
inline

specific lookup function for merge_rank

Definition at line 59 of file L1MuGMTLFMergeRankCombineLUT.h.

References L1MuGMTLUT::Lookup().

Referenced by L1MuGMTMerger::merge_rank().

59  {
60  std::vector<unsigned> addr(3);
61  addr[0] = rank_etaq;
62  addr[1] = rank_ptq;
63  addr[2] = rank_etaphi;
64  return Lookup(idx, addr) [0];
65  };
std::vector< unsigned > Lookup(int idx, const std::vector< unsigned > &address) const
additional lookup function (std::vector -&gt; vector)
Definition: L1MuGMTLUT.h:117
tuple idx
DEBUGGING if hasattr(process,&quot;trackMonIterativeTracking2012&quot;): print &quot;trackMonIterativeTracking2012 D...
unsigned L1MuGMTLFMergeRankCombineLUT::TheLookupFunction ( int  idx,
unsigned  rank_etaq,
unsigned  rank_ptq,
unsigned  rank_etaphi 
) const
private

The lookup function - here the functionality of the LUT is implemented.

Definition at line 41 of file L1MuGMTLFMergeRankCombineLUT.cc.

Referenced by LookupFunctionPacked().

41  {
42  // idx is DT, BRPC, CSC, FRPC
43  // INPUTS: rank_etaq(7) rank_ptq(2) rank_etaphi(1)
44  // OUTPUTS: merge_rank(8)
45 
46  return rank_etaq + 128*rank_etaphi;
47 }