Go to the documentation of this file.00001 #ifndef L1RCTProducer_h
00002 #define L1RCTProducer_h
00003
00004 #include "FWCore/Framework/interface/EDProducer.h"
00005
00006 #include "DataFormats/Common/interface/Handle.h"
00007 #include "FWCore/ParameterSet/interface/ParameterSet.h"
00008 #include "FWCore/Framework/interface/EventSetup.h"
00009 #include "FWCore/Framework/interface/Event.h"
00010 #include "FWCore/Framework/interface/ESHandle.h"
00011
00012 #include "DataFormats/L1CaloTrigger/interface/L1CaloCollections.h"
00013 #include "DataFormats/EcalDigi/interface/EcalDigiCollections.h"
00014 #include "DataFormats/HcalDigi/interface/HcalDigiCollections.h"
00015
00016
00017 #include "CondFormats/L1TObjects/interface/L1CaloEcalScale.h"
00018 #include "CondFormats/DataRecord/interface/L1CaloEcalScaleRcd.h"
00019 #include "CondFormats/L1TObjects/interface/L1CaloHcalScale.h"
00020 #include "CondFormats/DataRecord/interface/L1CaloHcalScaleRcd.h"
00021
00022
00023 #include "CondFormats/L1TObjects/interface/L1RCTParameters.h"
00024 #include "CondFormats/DataRecord/interface/L1RCTParametersRcd.h"
00025 #include "CondFormats/L1TObjects/interface/L1RCTChannelMask.h"
00026 #include "CondFormats/DataRecord/interface/L1RCTChannelMaskRcd.h"
00027 #include "CondFormats/L1TObjects/interface/L1RCTNoisyChannelMask.h"
00028 #include "CondFormats/DataRecord/interface/L1RCTNoisyChannelMaskRcd.h"
00029
00030 #include "CondFormats/RunInfo/interface/RunInfo.h"
00031 #include "CondFormats/DataRecord/interface/RunSummaryRcd.h"
00032
00033
00034 #include "L1Trigger/RegionalCaloTrigger/interface/L1RCT.h"
00035 #include "L1Trigger/RegionalCaloTrigger/interface/L1RCTLookupTables.h"
00036
00037 #include "CondFormats/L1TObjects/interface/L1CaloEtScale.h"
00038 #include "CondFormats/DataRecord/interface/L1EmEtScaleRcd.h"
00039
00040
00041 #include "FWCore/MessageLogger/interface/MessageLogger.h"
00042 #include <string>
00043
00044 class L1RCT;
00045 class L1RCTLookupTables;
00046
00047 class L1RCTProducer : public edm::EDProducer
00048 {
00049 public:
00050 explicit L1RCTProducer(const edm::ParameterSet& ps);
00051 virtual ~L1RCTProducer();
00052 virtual void beginRun(edm::Run const& r, const edm::EventSetup& c) override final;
00053 virtual void beginLuminosityBlock(edm::LuminosityBlock const& lumiSeg, const edm::EventSetup& context) override final;
00054 virtual void produce(edm::Event& e, const edm::EventSetup& c) override final;
00055
00056
00057 void updateConfiguration(const edm::EventSetup&);
00058
00059 void updateFedVector(const edm::EventSetup&, bool getFromOmds, int);
00060 const std::vector<int> getFedVectorFromRunInfo(const edm::EventSetup&);
00061 const std::vector<int> getFedVectorFromOmds(const edm::EventSetup&);
00062
00063 void printFedVector(const std::vector<int>&);
00064 void printUpdatedFedMask();
00065 void printUpdatedFedMaskVerbose();
00066
00067 private:
00068 L1RCTLookupTables* rctLookupTables;
00069 L1RCT* rct;
00070 bool useEcal;
00071 bool useHcal;
00072 std::vector<edm::InputTag> ecalDigis;
00073 std::vector<edm::InputTag> hcalDigis;
00074 std::vector<int> bunchCrossings;
00075 bool getFedsFromOmds;
00076 unsigned int queryDelayInLS;
00077 unsigned int queryIntervalInLS;
00078
00079
00080 L1RCTChannelMask* fedUpdatedMask;
00081
00082
00083 enum crateSection{
00084 c_min,
00085 ebOddFed = c_min,
00086 ebEvenFed,
00087 eeFed,
00088 hbheFed,
00089 hfFed,
00090 c_max = hfFed
00091 };
00092
00093
00094
00095 static const int crateFED[18][5];
00096 static const int minBarrel = 1;
00097 static const int maxBarrel = 17;
00098 static const int minEndcap = 17;
00099 static const int maxEndcap = 28;
00100 static const int minHF = 29;
00101 static const int maxHF =32;
00102
00103
00104 };
00105
00106
00107 #endif