CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
L1TExtCondProducer.cc
Go to the documentation of this file.
1 
10 // system include files
11 
12 // user include files
13 
25 
29 
32 
33 //#include <vector>
35 
37 
39 
40 using namespace std;
41 using namespace edm;
42 using namespace l1t;
43 
44 //
45 // class declaration
46 //
47 
49 public:
50  explicit L1TExtCondProducer(const ParameterSet&);
51  ~L1TExtCondProducer() override;
52 
53  static void fillDescriptions(ConfigurationDescriptions& descriptions);
54 
55 private:
56  void produce(edm::Event&, const edm::EventSetup&) override;
57 
58  // ----------member data ---------------------------
59  // unsigned long long m_paramsCacheId; // Cache-ID from current parameters, to check if needs to be updated.
60  //std::shared_ptr<const CaloParams> m_dbpars; // Database parameters for the trigger, to be updated as needed.
61  //std::shared_ptr<const FirmwareVersion> m_fwv;
62  //std::shared_ptr<FirmwareVersion> m_fwv; //not const during testing.
63 
64  // BX parameters
65  int bxFirst_;
66  int bxLast_;
67 
71  bool setBptxOR_;
72 
73  unsigned long long m_l1GtMenuCacheID;
74  std::map<std::string, unsigned int> m_extBitMap;
75 
77 
82 };
83 
84 //
85 // constructors and destructor
86 //
88  : bxFirst_(iConfig.getParameter<int>("bxFirst")),
89  bxLast_(iConfig.getParameter<int>("bxLast")),
90  setBptxAND_(iConfig.getParameter<bool>("setBptxAND")),
91  setBptxPlus_(iConfig.getParameter<bool>("setBptxPlus")),
92  setBptxMinus_(iConfig.getParameter<bool>("setBptxMinus")),
93  setBptxOR_(iConfig.getParameter<bool>("setBptxOR")),
94  tcdsInputTag_(iConfig.getParameter<edm::InputTag>("tcdsRecordLabel")),
97 
99 
100  if (!(tcdsInputTag_ == edm::InputTag(""))) {
101  tcdsRecordToken_ = consumes<TCDSRecord>(tcdsInputTag_);
103  }
104 
105  // register what you produce
106  produces<GlobalExtBlkBxCollection>();
107 
108  // Initialize parameters
109  m_l1GtMenuCacheID = 0ULL;
110 }
111 
113 
114 //
115 // member functions
116 //
117 
118 // ------------ method called to produce the data ------------
120  LogDebug("L1TExtCondProducer") << "L1TExtCondProducer::produce function called...\n";
121 
122  // get / update the trigger menu from the EventSetup
123  // local cache & check on cacheIdentifier
124  unsigned long long l1GtMenuCacheID = iSetup.get<L1TUtmTriggerMenuRcd>().cacheIdentifier();
125 
126  if (m_l1GtMenuCacheID != l1GtMenuCacheID) {
127  edm::ESHandle<L1TUtmTriggerMenu> l1GtMenu = iSetup.getHandle(l1GtMenuToken_);
128  const L1TUtmTriggerMenu* utml1GtMenu = l1GtMenu.product();
129 
130  // Instantiate Parser
132 
133  std::map<std::string, unsigned int> extBitMap = gtParser.getExternalSignals(utml1GtMenu);
134 
135  m_l1GtMenuCacheID = l1GtMenuCacheID;
136  m_extBitMap = extBitMap;
137  }
138 
139  bool TriggerRulePrefireVetoBit(false);
140  if (makeTriggerRulePrefireVetoBit_) {
141  // code taken from Nick Smith's EventFilter/L1TRawToDigi/plugins/TriggerRulePrefireVetoFilter.cc
142 
143  edm::Handle<TCDSRecord> tcdsRecordH;
144  iEvent.getByToken(tcdsRecordToken_, tcdsRecordH);
145  const auto& tcdsRecord = *tcdsRecordH.product();
146 
147  uint64_t thisEvent = (tcdsRecord.getBXID() - 1) + tcdsRecord.getOrbitNr() * 3564ull;
148 
149  std::vector<uint64_t> eventHistory;
150  for (auto&& l1a : tcdsRecord.getFullL1aHistory()) {
151  eventHistory.push_back(thisEvent - ((l1a.getBXID() - 1) + l1a.getOrbitNr() * 3564ull));
152  }
153 
154  // should be 16 according to TCDSRecord.h, we only care about the last 4
155  if (eventHistory.size() < 4) {
156  edm::LogError("L1TExtCondProducer") << "Unexpectedly small L1A history from TCDSRecord";
157  }
158 
159  // No more than 1 L1A in 3 BX
160  if (eventHistory[0] < 3ull) {
161  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (1 in 3)";
162  }
163 
164  if (eventHistory[0] == 3ull)
165  TriggerRulePrefireVetoBit = true;
166 
167  // No more than 2 L1As in 25 BX
168  if (eventHistory[0] < 25ull and eventHistory[1] < 25ull) {
169  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (2 in 25)";
170  }
171  if (eventHistory[0] < 25ull and eventHistory[1] == 25ull)
172  TriggerRulePrefireVetoBit = true;
173 
174  // No more than 3 L1As in 100 BX
175  if (eventHistory[0] < 100ull and eventHistory[1] < 100ull and eventHistory[2] < 100ull) {
176  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (3 in 100)";
177  }
178  if (eventHistory[0] < 100ull and eventHistory[1] < 100ull and eventHistory[2] == 100ull)
179  TriggerRulePrefireVetoBit = true;
180 
181  // No more than 4 L1As in 240 BX
182  if (eventHistory[0] < 240ull and eventHistory[1] < 240ull and eventHistory[2] < 240ull and
183  eventHistory[3] < 240ull) {
184  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (4 in 240)";
185  }
186  if (eventHistory[0] < 240ull and eventHistory[1] < 240ull and eventHistory[2] < 240ull and
187  eventHistory[3] == 240ull)
188  TriggerRulePrefireVetoBit = true;
189  }
190 
191  // Setup vectors
192  GlobalExtBlk extCond_bx;
193 
194  //outputs
195  std::unique_ptr<GlobalExtBlkBxCollection> extCond(new GlobalExtBlkBxCollection(0, bxFirst_, bxLast_));
196 
197  bool foundBptxAND = (m_extBitMap.find("BPTX_plus_AND_minus.v0") != m_extBitMap.end());
198  bool foundBptxPlus = (m_extBitMap.find("BPTX_plus.v0") != m_extBitMap.end());
199  bool foundBptxMinus = (m_extBitMap.find("BPTX_minus.v0") != m_extBitMap.end());
200  bool foundBptxOR = (m_extBitMap.find("BPTX_plus_OR_minus.v0") != m_extBitMap.end());
201 
202  // Fill in some external conditions for testing
203  if (setBptxAND_ && foundBptxAND)
204  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus_AND_minus.v0"], true);
205  if (setBptxPlus_ && foundBptxPlus)
206  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus.v0"], true);
207  if (setBptxMinus_ && foundBptxMinus)
208  extCond_bx.setExternalDecision(m_extBitMap["BPTX_minus.v0"], true);
209  if (setBptxOR_ && foundBptxOR)
210  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus_OR_minus.v0"], true);
211 
212  //check for updated Bptx names as well
213  foundBptxAND = (m_extBitMap.find("ZeroBias_BPTX_AND_VME") != m_extBitMap.end());
214  foundBptxPlus = (m_extBitMap.find("BPTX_B1_VME") != m_extBitMap.end());
215  foundBptxMinus = (m_extBitMap.find("BPTX_B2_VME") != m_extBitMap.end());
216  foundBptxOR = (m_extBitMap.find("BPTX_OR_VME") != m_extBitMap.end());
217 
218  // Fill in some external conditions for testing
219  if (setBptxAND_ && foundBptxAND)
220  extCond_bx.setExternalDecision(m_extBitMap["ZeroBias_BPTX_AND_VME"], true);
221  if (setBptxPlus_ && foundBptxPlus)
222  extCond_bx.setExternalDecision(m_extBitMap["BPTX_B1_VME"], true);
223  if (setBptxMinus_ && foundBptxMinus)
224  extCond_bx.setExternalDecision(m_extBitMap["BPTX_B2_VME"], true);
225  if (setBptxOR_ && foundBptxOR)
226  extCond_bx.setExternalDecision(m_extBitMap["BPTX_OR_VME"], true);
227 
228  // set the bit for the TriggerRulePrefireVeto if true
229  if (TriggerRulePrefireVetoBit)
230  extCond_bx.setExternalDecision(m_triggerRulePrefireVetoBit, true);
231 
232  // Fill Externals
233  for (int iBx = bxFirst_; iBx <= bxLast_; iBx++) {
234  extCond->push_back(iBx, extCond_bx);
235  }
236 
237  iEvent.put(std::move(extCond));
238 }
239 
240 // ------------ method fills 'descriptions' with the allowed parameters for the module ------------
242  // simGtExtFakeProd
244  desc.add<bool>("setBptxMinus", true);
245  desc.add<bool>("setBptxAND", true);
246  desc.add<int>("bxFirst", -2);
247  desc.add<bool>("setBptxOR", true);
248  desc.add<int>("bxLast", 2);
249  desc.add<bool>("setBptxPlus", true);
250  desc.add<edm::InputTag>("tcdsRecordLabel", edm::InputTag(""));
251  descriptions.add("simGtExtFakeProd", desc);
252 }
253 
254 //define this as a plug-in
edm::ESGetToken< L1TUtmTriggerMenu, L1TUtmTriggerMenuRcd > l1GtMenuToken_
BXVector< GlobalExtBlk > GlobalExtBlkBxCollection
Definition: GlobalExtBlk.h:29
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:133
edm::EDGetTokenT< TCDSRecord > tcdsRecordToken_
static const unsigned int maxExternalConditions
Definition: GlobalExtBlk.h:43
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:539
#define DEFINE_FWK_MODULE(type)
Definition: MakerMacros.h:16
std::map< std::string, unsigned int > getExternalSignals(const L1TUtmTriggerMenu *utmMenu)
Log< level::Error, false > LogError
int iEvent
Definition: GenABIO.cc:224
unsigned int m_triggerRulePrefireVetoBit
def move
Definition: eostools.py:511
edm::InputTag tcdsInputTag_
ParameterDescriptionBase * add(U const &iLabel, T const &value)
static void fillDescriptions(ConfigurationDescriptions &descriptions)
L1TExtCondProducer(const ParameterSet &)
void setExternalDecision(unsigned int bit, bool val)
Set decision bits.
Definition: GlobalExtBlk.cc:40
unsigned long long m_l1GtMenuCacheID
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
T const * product() const
Definition: Handle.h:70
unsigned long long uint64_t
Definition: Time.h:13
T const * product() const
Definition: ESHandle.h:86
void add(std::string const &label, ParameterSetDescription const &psetDescription)
T get() const
Definition: EventSetup.h:88
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
Definition: EventSetup.h:157
std::map< std::string, unsigned int > m_extBitMap
void produce(edm::Event &, const edm::EventSetup &) override
ESGetTokenH3DDVariant esConsumes(std::string const &Reccord, edm::ConsumesCollector &)
Definition: DeDxTools.cc:283
#define LogDebug(id)