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_L1MuGMTMIAUEtaConvLUT_h
0019 #define L1TriggerGlobalMuonTrigger_L1MuGMTMIAUEtaConvLUT_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 L1MuGMTMIAUEtaConvLUT : public L1MuGMTLUT {
0039 public:
0040 enum { MIP_DT, MIP_BRPC, ISO_DT, ISO_BRPC, MIP_CSC, MIP_FRPC, ISO_CSC, ISO_FRPC };
0041
0042
0043 L1MuGMTMIAUEtaConvLUT()
0044 : L1MuGMTLUT("MIAUEtaConv",
0045 "MIP_DT MIP_BRPC ISO_DT ISO_BRPC MIP_CSC MIP_FRPC ISO_CSC ISO_FRPC",
0046 "eta_in(6)",
0047 "eta_out(4)",
0048 6,
0049 true) {
0050 InitParameters();
0051 };
0052
0053
0054 ~L1MuGMTMIAUEtaConvLUT() override {}
0055
0056
0057 unsigned SpecificLookup_eta_out(int idx, unsigned eta_in) const {
0058 std::vector<unsigned> addr(1);
0059 addr[0] = eta_in;
0060 return Lookup(idx, addr)[0];
0061 };
0062
0063
0064 unsigned SpecificLookup(int idx, unsigned eta_in) const {
0065 std::vector<unsigned> addr(1);
0066 addr[0] = eta_in;
0067 return LookupPacked(idx, addr);
0068 };
0069
0070
0071
0072 unsigned LookupFunctionPacked(int idx, unsigned address) const override {
0073 std::vector<unsigned> addr = u2vec(address, m_Inputs);
0074 return TheLookupFunction(idx, addr[0]);
0075 };
0076
0077 private:
0078
0079 void InitParameters();
0080
0081
0082 unsigned TheLookupFunction(int idx, unsigned eta_in) const;
0083
0084
0085 };
0086 #endif