CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
L1TExtCondProducer Class Reference
Inheritance diagram for L1TExtCondProducer:
edm::stream::EDProducer<>

Public Member Functions

 L1TExtCondProducer (const ParameterSet &)
 
 ~L1TExtCondProducer () override
 
- Public Member Functions inherited from edm::stream::EDProducer<>
 EDProducer ()=default
 
bool hasAbilityToProduceInBeginLumis () const final
 
bool hasAbilityToProduceInBeginRuns () const final
 
bool hasAbilityToProduceInEndLumis () const final
 
bool hasAbilityToProduceInEndRuns () const final
 

Static Public Member Functions

static void fillDescriptions (ConfigurationDescriptions &descriptions)
 

Private Member Functions

void produce (edm::Event &, const edm::EventSetup &) override
 

Private Attributes

int bxFirst_
 
int bxLast_
 
std::map< std::string, unsigned int > m_extBitMap
 
unsigned long long m_l1GtMenuCacheID
 
unsigned int m_triggerRulePrefireVetoBit
 
bool makeTriggerRulePrefireVetoBit_
 
bool setBptxAND_
 
bool setBptxMinus_
 
bool setBptxOR_
 
bool setBptxPlus_
 
edm::InputTag tcdsInputTag_
 
edm::EDGetTokenT< TCDSRecordtcdsRecordToken_
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDProducer<>
typedef CacheContexts< T... > CacheTypes
 
typedef CacheTypes::GlobalCache GlobalCache
 
typedef AbilityChecker< T... > HasAbility
 
typedef CacheTypes::LuminosityBlockCache LuminosityBlockCache
 
typedef LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCacheLuminosityBlockContext
 
typedef CacheTypes::LuminosityBlockSummaryCache LuminosityBlockSummaryCache
 
typedef CacheTypes::RunCache RunCache
 
typedef RunContextT< RunCache, GlobalCacheRunContext
 
typedef CacheTypes::RunSummaryCache RunSummaryCache
 

Detailed Description

Definition at line 47 of file L1TExtCondProducer.cc.

Constructor & Destructor Documentation

L1TExtCondProducer::L1TExtCondProducer ( const ParameterSet iConfig)
explicit

Definition at line 85 of file L1TExtCondProducer.cc.

References m_l1GtMenuCacheID, m_triggerRulePrefireVetoBit, makeTriggerRulePrefireVetoBit_, GlobalExtBlk::maxExternalConditions, tcdsInputTag_, and tcdsRecordToken_.

86  : bxFirst_(iConfig.getParameter<int>("bxFirst")),
87  bxLast_(iConfig.getParameter<int>("bxLast")),
88  setBptxAND_(iConfig.getParameter<bool>("setBptxAND")),
89  setBptxPlus_(iConfig.getParameter<bool>("setBptxPlus")),
90  setBptxMinus_(iConfig.getParameter<bool>("setBptxMinus")),
91  setBptxOR_(iConfig.getParameter<bool>("setBptxOR")),
92  tcdsInputTag_(iConfig.getParameter<edm::InputTag>("tcdsRecordLabel")) {
94 
98  edm::LogWarning("L1TExtCondProducer")
99  << "Default trigger rule prefire veto bit number too large. Resetting to " << m_triggerRulePrefireVetoBit;
100  }
101 
102  if (!(tcdsInputTag_ == edm::InputTag(""))) {
103  tcdsRecordToken_ = consumes<TCDSRecord>(tcdsInputTag_);
105  }
106 
107  // register what you produce
108  produces<GlobalExtBlkBxCollection>();
109 
110  // Initialize parameters
111  m_l1GtMenuCacheID = 0ULL;
112 }
T getParameter(std::string const &) const
edm::EDGetTokenT< TCDSRecord > tcdsRecordToken_
static const unsigned int maxExternalConditions
Definition: GlobalExtBlk.h:43
unsigned int m_triggerRulePrefireVetoBit
edm::InputTag tcdsInputTag_
unsigned long long m_l1GtMenuCacheID
L1TExtCondProducer::~L1TExtCondProducer ( )
override

Definition at line 114 of file L1TExtCondProducer.cc.

114 {}

Member Function Documentation

void L1TExtCondProducer::fillDescriptions ( ConfigurationDescriptions descriptions)
static

Definition at line 244 of file L1TExtCondProducer.cc.

References edm::ConfigurationDescriptions::add(), edm::ParameterSetDescription::add(), DEFINE_FWK_MODULE, and HLT_2018_cff::InputTag.

244  {
245  // simGtExtFakeProd
247  desc.add<bool>("setBptxMinus", true);
248  desc.add<bool>("setBptxAND", true);
249  desc.add<int>("bxFirst", -2);
250  desc.add<bool>("setBptxOR", true);
251  desc.add<int>("bxLast", 2);
252  desc.add<bool>("setBptxPlus", true);
253  desc.add<edm::InputTag>("tcdsRecordLabel", edm::InputTag(""));
254  descriptions.add("simGtExtFakeProd", desc);
255 }
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
void L1TExtCondProducer::produce ( edm::Event iEvent,
const edm::EventSetup iSetup 
)
overrideprivate

Definition at line 121 of file L1TExtCondProducer.cc.

References bxFirst_, bxLast_, edm::EventSetup::get(), edm::Event::getByToken(), l1t::TriggerMenuParser::getExternalSignals(), LogDebug, m_extBitMap, m_l1GtMenuCacheID, m_triggerRulePrefireVetoBit, makeTriggerRulePrefireVetoBit_, eostools::move(), edm::Handle< T >::product(), edm::ESHandle< T >::product(), edm::Event::put(), setBptxAND_, setBptxMinus_, setBptxOR_, setBptxPlus_, GlobalExtBlk::setExternalDecision(), and tcdsRecordToken_.

121  {
122  LogDebug("L1TExtCondProducer") << "L1TExtCondProducer::produce function called...\n";
123 
124  // get / update the trigger menu from the EventSetup
125  // local cache & check on cacheIdentifier
126  unsigned long long l1GtMenuCacheID = iSetup.get<L1TUtmTriggerMenuRcd>().cacheIdentifier();
127 
128  if (m_l1GtMenuCacheID != l1GtMenuCacheID) {
130  iSetup.get<L1TUtmTriggerMenuRcd>().get(l1GtMenu);
131  const L1TUtmTriggerMenu* utml1GtMenu = l1GtMenu.product();
132 
133  // Instantiate Parser
135 
136  std::map<std::string, unsigned int> extBitMap = gtParser.getExternalSignals(utml1GtMenu);
137 
138  m_l1GtMenuCacheID = l1GtMenuCacheID;
139  m_extBitMap = extBitMap;
140  }
141 
142  bool TriggerRulePrefireVetoBit(false);
144  // code taken from Nick Smith's EventFilter/L1TRawToDigi/plugins/TriggerRulePrefireVetoFilter.cc
145 
146  edm::Handle<TCDSRecord> tcdsRecordH;
147  iEvent.getByToken(tcdsRecordToken_, tcdsRecordH);
148  const auto& tcdsRecord = *tcdsRecordH.product();
149 
150  uint64_t thisEvent = (tcdsRecord.getBXID() - 1) + tcdsRecord.getOrbitNr() * 3564ull;
151 
152  std::vector<uint64_t> eventHistory;
153  for (auto&& l1a : tcdsRecord.getFullL1aHistory()) {
154  eventHistory.push_back(thisEvent - ((l1a.getBXID() - 1) + l1a.getOrbitNr() * 3564ull));
155  }
156 
157  // should be 16 according to TCDSRecord.h, we only care about the last 4
158  if (eventHistory.size() < 4) {
159  edm::LogError("L1TExtCondProducer") << "Unexpectedly small L1A history from TCDSRecord";
160  }
161 
162  // No more than 1 L1A in 3 BX
163  if (eventHistory[0] < 3ull) {
164  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (1 in 3)";
165  }
166 
167  if (eventHistory[0] == 3ull)
168  TriggerRulePrefireVetoBit = true;
169 
170  // No more than 2 L1As in 25 BX
171  if (eventHistory[0] < 25ull and eventHistory[1] < 25ull) {
172  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (2 in 25)";
173  }
174  if (eventHistory[0] < 25ull and eventHistory[1] == 25ull)
175  TriggerRulePrefireVetoBit = true;
176 
177  // No more than 3 L1As in 100 BX
178  if (eventHistory[0] < 100ull and eventHistory[1] < 100ull and eventHistory[2] < 100ull) {
179  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (3 in 100)";
180  }
181  if (eventHistory[0] < 100ull and eventHistory[1] < 100ull and eventHistory[2] == 100ull)
182  TriggerRulePrefireVetoBit = true;
183 
184  // No more than 4 L1As in 240 BX
185  if (eventHistory[0] < 240ull and eventHistory[1] < 240ull and eventHistory[2] < 240ull and
186  eventHistory[3] < 240ull) {
187  edm::LogError("L1TExtCondProducer") << "Found an L1A in an impossible location?! (4 in 240)";
188  }
189  if (eventHistory[0] < 240ull and eventHistory[1] < 240ull and eventHistory[2] < 240ull and
190  eventHistory[3] == 240ull)
191  TriggerRulePrefireVetoBit = true;
192  }
193 
194  // Setup vectors
195  GlobalExtBlk extCond_bx;
196 
197  //outputs
198  std::unique_ptr<GlobalExtBlkBxCollection> extCond(new GlobalExtBlkBxCollection(0, bxFirst_, bxLast_));
199 
200  bool foundBptxAND = (m_extBitMap.find("BPTX_plus_AND_minus.v0") != m_extBitMap.end());
201  bool foundBptxPlus = (m_extBitMap.find("BPTX_plus.v0") != m_extBitMap.end());
202  bool foundBptxMinus = (m_extBitMap.find("BPTX_minus.v0") != m_extBitMap.end());
203  bool foundBptxOR = (m_extBitMap.find("BPTX_plus_OR_minus.v0") != m_extBitMap.end());
204 
205  // Fill in some external conditions for testing
206  if (setBptxAND_ && foundBptxAND)
207  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus_AND_minus.v0"], true);
208  if (setBptxPlus_ && foundBptxPlus)
209  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus.v0"], true);
210  if (setBptxMinus_ && foundBptxMinus)
211  extCond_bx.setExternalDecision(m_extBitMap["BPTX_minus.v0"], true);
212  if (setBptxOR_ && foundBptxOR)
213  extCond_bx.setExternalDecision(m_extBitMap["BPTX_plus_OR_minus.v0"], true);
214 
215  //check for updated Bptx names as well
216  foundBptxAND = (m_extBitMap.find("ZeroBias_BPTX_AND_VME") != m_extBitMap.end());
217  foundBptxPlus = (m_extBitMap.find("BPTX_B1_VME") != m_extBitMap.end());
218  foundBptxMinus = (m_extBitMap.find("BPTX_B2_VME") != m_extBitMap.end());
219  foundBptxOR = (m_extBitMap.find("BPTX_OR_VME") != m_extBitMap.end());
220 
221  // Fill in some external conditions for testing
222  if (setBptxAND_ && foundBptxAND)
223  extCond_bx.setExternalDecision(m_extBitMap["ZeroBias_BPTX_AND_VME"], true);
224  if (setBptxPlus_ && foundBptxPlus)
225  extCond_bx.setExternalDecision(m_extBitMap["BPTX_B1_VME"], true);
226  if (setBptxMinus_ && foundBptxMinus)
227  extCond_bx.setExternalDecision(m_extBitMap["BPTX_B2_VME"], true);
228  if (setBptxOR_ && foundBptxOR)
229  extCond_bx.setExternalDecision(m_extBitMap["BPTX_OR_VME"], true);
230 
231  // set the bit for the TriggerRulePrefireVeto if true
232  if (TriggerRulePrefireVetoBit)
234 
235  // Fill Externals
236  for (int iBx = bxFirst_; iBx <= bxLast_; iBx++) {
237  extCond->push_back(iBx, extCond_bx);
238  }
239 
240  iEvent.put(std::move(extCond));
241 }
#define LogDebug(id)
BXVector< GlobalExtBlk > GlobalExtBlkBxCollection
Definition: GlobalExtBlk.h:29
OrphanHandle< PROD > put(std::unique_ptr< PROD > product)
Put a new product.
Definition: Event.h:131
edm::EDGetTokenT< TCDSRecord > tcdsRecordToken_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:525
std::map< std::string, unsigned int > getExternalSignals(const L1TUtmTriggerMenu *utmMenu)
unsigned int m_triggerRulePrefireVetoBit
void setExternalDecision(unsigned int bit, bool val)
Set decision bits.
Definition: GlobalExtBlk.cc:40
unsigned long long m_l1GtMenuCacheID
T const * product() const
Definition: Handle.h:69
unsigned long long uint64_t
Definition: Time.h:13
T get() const
Definition: EventSetup.h:73
std::map< std::string, unsigned int > m_extBitMap
T const * product() const
Definition: ESHandle.h:86
def move(src, dest)
Definition: eostools.py:511

Member Data Documentation

int L1TExtCondProducer::bxFirst_
private

Definition at line 64 of file L1TExtCondProducer.cc.

Referenced by produce().

int L1TExtCondProducer::bxLast_
private

Definition at line 65 of file L1TExtCondProducer.cc.

Referenced by produce().

std::map<std::string, unsigned int> L1TExtCondProducer::m_extBitMap
private

Definition at line 73 of file L1TExtCondProducer.cc.

Referenced by produce().

unsigned long long L1TExtCondProducer::m_l1GtMenuCacheID
private

Definition at line 72 of file L1TExtCondProducer.cc.

Referenced by L1TExtCondProducer(), and produce().

unsigned int L1TExtCondProducer::m_triggerRulePrefireVetoBit
private

Definition at line 75 of file L1TExtCondProducer.cc.

Referenced by L1TExtCondProducer(), and produce().

bool L1TExtCondProducer::makeTriggerRulePrefireVetoBit_
private

Definition at line 77 of file L1TExtCondProducer.cc.

Referenced by L1TExtCondProducer(), and produce().

bool L1TExtCondProducer::setBptxAND_
private

Definition at line 67 of file L1TExtCondProducer.cc.

Referenced by produce().

bool L1TExtCondProducer::setBptxMinus_
private

Definition at line 69 of file L1TExtCondProducer.cc.

Referenced by produce().

bool L1TExtCondProducer::setBptxOR_
private

Definition at line 70 of file L1TExtCondProducer.cc.

Referenced by produce().

bool L1TExtCondProducer::setBptxPlus_
private

Definition at line 68 of file L1TExtCondProducer.cc.

Referenced by produce().

edm::InputTag L1TExtCondProducer::tcdsInputTag_
private

Definition at line 79 of file L1TExtCondProducer.cc.

Referenced by L1TExtCondProducer().

edm::EDGetTokenT<TCDSRecord> L1TExtCondProducer::tcdsRecordToken_
private

Definition at line 78 of file L1TExtCondProducer.cc.

Referenced by L1TExtCondProducer(), and produce().