File indexing completed on 2023-03-29 01:42:58
0001 #ifndef L1Trigger_L1TMuonEndCap_SectorProcessorShower_h
0002 #define L1Trigger_L1TMuonEndCap_SectorProcessorShower_h
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013 #include "FWCore/ParameterSet/interface/ParameterSet.h"
0014 #include "DataFormats/L1TMuon/interface/RegionalMuonShower.h"
0015 #include "DataFormats/CSCDigi/interface/CSCShowerDigiCollection.h"
0016 #include "L1Trigger/L1TMuonEndCap/interface/Common.h"
0017
0018 #include "DataFormats/L1TMuon/interface/RegionalMuonCandFwd.h"
0019
0020 #include <vector>
0021
0022 class SectorProcessorShower {
0023 public:
0024 explicit SectorProcessorShower() {}
0025 ~SectorProcessorShower() {}
0026
0027 void configure(const edm::ParameterSet&, int endcap, int sector);
0028
0029 void process(const CSCShowerDigiCollection& showers, l1t::RegionalMuonShowerBxCollection& out_showers) const;
0030
0031 private:
0032 int select_shower(const CSCDetId&, const CSCShowerDigi&) const;
0033 int get_index_shower(int tp_endcap, int tp_sector, int tp_subsector, int tp_station, int tp_csc_ID) const;
0034 bool is_in_sector_csc(int tp_endcap, int tp_sector) const;
0035
0036 int verbose_, endcap_, sector_;
0037
0038 bool enableOneLooseShower_;
0039
0040 bool enableOneNominalShower_;
0041
0042 bool enableOneTightShower_;
0043
0044 bool enableTwoLooseShowers_;
0045 };
0046
0047 #endif