File indexing completed on 2024-09-07 04:36:48
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014
0015
0016
0017
0018 #ifndef L1TriggerGlobalMuonTrigger_L1MuGMTLFSortRankEtaQLUT_h
0019 #define L1TriggerGlobalMuonTrigger_L1MuGMTLFSortRankEtaQLUT_h
0020
0021
0022
0023
0024
0025
0026
0027
0028 #include "L1Trigger/GlobalMuonTrigger/src/L1MuGMTLUT.h"
0029
0030
0031
0032
0033
0034
0035
0036
0037
0038 class L1MuGMTLFSortRankEtaQLUT : public L1MuGMTLUT {
0039 public:
0040 enum { DT, BRPC, CSC, FRPC };
0041
0042
0043 L1MuGMTLFSortRankEtaQLUT()
0044 : L1MuGMTLUT("LFSortRankEtaQ", "DT BRPC CSC FRPC", "eta(6) q(3)", "vlq(2) rank_etaq(2)", 7, false) {
0045 InitParameters();
0046 };
0047
0048
0049 ~L1MuGMTLFSortRankEtaQLUT() override {}
0050
0051
0052 unsigned SpecificLookup_vlq(int idx, unsigned eta, unsigned q) const {
0053 std::vector<unsigned> addr(2);
0054 addr[0] = eta;
0055 addr[1] = q;
0056 return Lookup(idx, addr)[0];
0057 };
0058
0059
0060 unsigned SpecificLookup_rank_etaq(int idx, unsigned eta, unsigned q) const {
0061 std::vector<unsigned> addr(2);
0062 addr[0] = eta;
0063 addr[1] = q;
0064 return Lookup(idx, addr)[1];
0065 };
0066
0067
0068 unsigned SpecificLookup(int idx, unsigned eta, unsigned q) const {
0069 std::vector<unsigned> addr(2);
0070 addr[0] = eta;
0071 addr[1] = q;
0072 return LookupPacked(idx, addr);
0073 };
0074
0075
0076
0077 unsigned LookupFunctionPacked(int idx, unsigned address) const override {
0078 std::vector<unsigned> addr = u2vec(address, m_Inputs);
0079 return TheLookupFunction(idx, addr[0], addr[1]);
0080 };
0081
0082 private:
0083
0084 void InitParameters();
0085
0086
0087 unsigned TheLookupFunction(int idx, unsigned eta, unsigned q) const;
0088
0089
0090 unsigned m_version;
0091 };
0092 #endif