ATLAS Offline Software
Loading...
Searching...
No Matches
TrigEDMChecker.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3*/
4
6
7#include "GaudiKernel/IToolSvc.h"
8
13
19
20#include "AthContainers/debug.h"
56#include "tauEvent/TauJet.h"
57
59
62
69
71#include "xAODEgamma/Electron.h"
73#include "xAODEgamma/Photon.h"
74
75
78#include "xAODTau/TauDefs.h"
79#include "xAODTau/TauJet.h"
80
81
82#include "TrigEDMChecker.h"
83
92
96
98
99
100
101#include "AthViews/ViewHelper.h"
102#include "AthViews/View.h"
103
104
105#include <iostream>
106#include <fstream>
107#include <queue>
108
109static const int maxRepWarnings = 5;
110
111
112TrigEDMChecker::TrigEDMChecker(const std::string& name, ISvcLocator* pSvcLocator)
113 : AthAnalysisAlgorithm(name, pSvcLocator),
114 m_clidSvc( "ClassIDSvc", name )
115{
117
118 declareProperty("doDumpAll", m_doDumpAll = true);
119 declareProperty("doDumpTrigPassBits", m_doDumpTrigPassBits = false);
120 declareProperty("doDumpLVL1_ROI", m_doDumpLVL1_ROI = false);
121 declareProperty("doDumpTrigMissingET", m_doDumpTrigMissingET = false);
122 declareProperty("doDumpxAODTrigMissingET", m_doDumpxAODTrigMissingET = false);
123 declareProperty("doDumpMuonFeature", m_doDumpMuonFeature = false);
124 declareProperty("doDumpCombinedMuonFeature", m_doDumpCombinedMuonFeature = false);
125 declareProperty("doDumpTileMuFeature", m_doDumpTileMuFeature = false);
126 declareProperty("doDumpTileTrackMuFeature", m_doDumpTileTrackMuFeature = false);
127 declareProperty("doDumpTrigPhotonContainer", m_doDumpTrigPhotonContainer = false);
128 declareProperty("doDumpTrigL2BphysContainer", m_doDumpTrigL2BphysContainer = false);
129 declareProperty("doDumpTrigEFBphysContainer", m_doDumpTrigEFBphysContainer = false);
130 declareProperty("doDumpTrigEFBjetContainer", m_doDumpTrigEFBjetContainer = false);
131 declareProperty("doDumpTrigL2BjetContainer", m_doDumpTrigL2BjetContainer = false);
132 declareProperty("doDumpxAODJetContainer", m_doDumpxAODJetContainer = false);
133 declareProperty("doDumpTrigMuonEFContainer", m_doDumpTrigMuonEFContainer = false);
134 declareProperty("doDumpTrigMuonEFInfoContainer", m_doDumpTrigMuonEFInfoContainer = false);
135 declareProperty("doDumpTrigMuonEFIsolationContainer", m_doDumpTrigMuonEFIsolationContainer = false);
136 declareProperty("doDumpxAODMuonContainer", m_doDumpxAODMuonContainer = false);
137 declareProperty("doDumpTrigElectronContainer", m_doDumpTrigElectronContainer = false);
138 declareProperty("doDumpxAODTrigElectronContainer", m_doDumpxAODTrigElectronContainer = false);
139 declareProperty("doDumpxAODTrigPhotonContainer", m_doDumpxAODTrigPhotonContainer = false);
140 declareProperty("doDumpxAODElectronContainer", m_doDumpxAODElectronContainer = false);
141 declareProperty("doDumpxAODPhotonContainer", m_doDumpxAODPhotonContainer = false);
142 declareProperty("doDumpHLTResult", m_doDumpHLTResult = false);
143 declareProperty("doDumpTrigTauContainer", m_doDumpTrigTauContainer = false);
144 declareProperty("doDumpTrigTauTracksInfo", m_doDumpTrigTauTracksInfo = false);
145 declareProperty("doDumpTrigInDetTrackCollection", m_doDumpTrigInDetTrackCollection = false);
146 declareProperty("doDumpTrigVertexCollection", m_doDumpTrigVertexCollection = false);
147 declareProperty("doDumpTrigEMCluster", m_doDumpTrigEMCluster = false);
148 declareProperty("doDumpTrigEMClusterContainer", m_doDumpTrigEMClusterContainer = false);
149 declareProperty("doDumpxAODTrigEMCluster", m_doDumpxAODTrigEMCluster = false);
150 declareProperty("doDumpxAODTrigEMClusterContainer", m_doDumpxAODTrigEMClusterContainer = false);
151 declareProperty("doDumpTrigTauClusterContainer", m_doDumpTrigTauClusterContainer = false);
152 declareProperty("doDumpTrackParticleContainer", m_doDumpTrackParticleContainer = false);
153 declareProperty("doDumpTauJetContainer", m_doDumpTauJetContainer = false);
154 declareProperty("doDumpxAODTrackParticle", m_doDumpxAODTrackParticle = false);
155 declareProperty("doDumpxAODVertex", m_doDumpxAODVertex = false);
156 declareProperty("doDumpxAODTauJetContainer", m_doDumpxAODTauJetContainer = false);
157 declareProperty("doDumpxAODTrigMinBias", m_doDumpxAODTrigMinBias = false);
158 declareProperty("doDumpStoreGate", m_doDumpStoreGate = false );
159 declareProperty("doDumpAllTrigComposite", m_doDumpAllTrigComposite = false );
160 declareProperty("dumpTrigCompositeContainers", m_dumpTrigCompositeContainers, "List of TC to dump" );
161 declareProperty("doDumpTrigCompsiteNavigation", m_doDumpTrigCompsiteNavigation = false );
162 declareProperty("doDumpNavigation", m_doDumpNavigation = false );
163 declareProperty("doTDTCheck", m_doTDTCheck = false );
164 declareProperty( "ClassIDSvc", m_clidSvc, "Service providing CLID info" );
165}
166
167
168
170
172
173 ATH_CHECK( m_navigationHandleKey.initialize() );
174 ATH_CHECK( m_decisionsKey.initialize() );
175 ATH_CHECK( m_navigationTool.retrieve() );
176
177 ATH_MSG_DEBUG("Initializing TrigEDMChecker");
178
179 ATH_MSG_INFO("REGTEST Initializing...");
180 ATH_MSG_INFO("REGTEST m_doDumpAll = " << m_doDumpAll );
181 ATH_MSG_INFO("REGTEST m_doDumpLVL1_ROI = " << m_doDumpLVL1_ROI);
182 ATH_MSG_INFO("REGTEST m_doDumpTrigMissingET = " << m_doDumpTrigMissingET );
183 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigMissingET = " << m_doDumpxAODTrigMissingET );
184 ATH_MSG_INFO("REGTEST m_doDumpMuonFeature = " << m_doDumpMuonFeature );
185 ATH_MSG_INFO("REGTEST m_doDumpCombinedMuonFeature = " << m_doDumpCombinedMuonFeature );
186 ATH_MSG_INFO("REGTEST m_doDumpTileMuFeature = " << m_doDumpTileMuFeature);
187 ATH_MSG_INFO("REGTEST m_doDumpTileTrackMuFeature = " << m_doDumpTileTrackMuFeature);
188 ATH_MSG_INFO("REGTEST m_doDumpTrigPhotonContainer = " << m_doDumpTrigPhotonContainer );
189 ATH_MSG_INFO("REGTEST m_doDumpTrigL2BphysContainer = " << m_doDumpTrigL2BphysContainer );
190 ATH_MSG_INFO("REGTEST m_doDumpTrigEFBphysContainer = " << m_doDumpTrigEFBphysContainer );
191 ATH_MSG_INFO("REGTEST m_doDumpTrigEFBjetContainer = " << m_doDumpTrigEFBjetContainer );
192 ATH_MSG_INFO("REGTEST m_doDumpTrigL2BjetContainer = " << m_doDumpTrigL2BjetContainer );
193 ATH_MSG_INFO("REGTEST m_doDumpxAODJetContainer = " << m_doDumpxAODJetContainer );
194 ATH_MSG_INFO("REGTEST m_doDumpTrigMuonEFContainer = " << m_doDumpTrigMuonEFContainer );
195 ATH_MSG_INFO("REGTEST m_doDumpTrigMuonEFInfoContainer = " << m_doDumpTrigMuonEFInfoContainer );
196 ATH_MSG_INFO("REGTEST m_doDumpxAODMuonContainer = " << m_doDumpxAODMuonContainer );
197 ATH_MSG_INFO("REGTEST m_doDumpTrigElectronContainer = " << m_doDumpTrigElectronContainer );
198 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigElectronContainer= " << m_doDumpxAODTrigElectronContainer );
199 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigPhotonContainer = " << m_doDumpxAODTrigPhotonContainer );
200 ATH_MSG_INFO("REGTEST m_doDumpxAODElectronContainer = " << m_doDumpxAODElectronContainer );
201 ATH_MSG_INFO("REGTEST m_doDumpxAODPhotonContainer = " << m_doDumpxAODPhotonContainer );
202 ATH_MSG_INFO("REGTEST m_doDumpHLTResult = " << m_doDumpHLTResult );
203 ATH_MSG_INFO("REGTEST m_doDumpTrigTauContainer = " << m_doDumpTrigTauContainer );
204 ATH_MSG_INFO("REGTEST m_doDumpTrigTauTracksInfo = " << m_doDumpTrigTauTracksInfo );
205 ATH_MSG_INFO("REGTEST m_doDumpTrigInDetTrackCollection = " << m_doDumpTrigInDetTrackCollection );
206 ATH_MSG_INFO("REGTEST m_doDumpTrigVertexCollection = " << m_doDumpTrigVertexCollection );
207 ATH_MSG_INFO("REGTEST m_doDumpTrigEMCluster = " << m_doDumpTrigEMCluster );
208 ATH_MSG_INFO("REGTEST m_doDumpTrigEMClusterContainer = " << m_doDumpTrigEMClusterContainer );
209 ATH_MSG_INFO("REGTEST m_doDumpTrigTauClusterContainer = " << m_doDumpTrigTauClusterContainer );
210 ATH_MSG_INFO("REGTEST m_doDumpTrackParticleContainer = " << m_doDumpTrackParticleContainer );
211 ATH_MSG_INFO("REGTEST m_doDumpTauJetContainer = " << m_doDumpTauJetContainer );
212 ATH_MSG_INFO("REGTEST m_doDumpxAODTrackParticle = " << m_doDumpxAODTrackParticle );
213 ATH_MSG_INFO("REGTEST m_doDumpxAODVertex = " << m_doDumpxAODVertex );
214 ATH_MSG_INFO("REGTEST m_doDumpxAODTauJetContainer = " << m_doDumpxAODTauJetContainer );
215 ATH_MSG_INFO("REGTEST m_doDumpxAODTrigMinBias = " << m_doDumpxAODTrigMinBias );
216 ATH_MSG_INFO("REGTEST m_doDumpStoreGate = " << m_doDumpStoreGate );
217 ATH_MSG_INFO("REGTEST m_doDumpAllTrigComposite = " << m_doDumpAllTrigComposite );
218 ATH_MSG_INFO("REGTEST m_dumpTrigCompositeContainers = " << m_dumpTrigCompositeContainers );
219 ATH_MSG_INFO("REGTEST m_doDumpTrigCompsiteNavigation = " << m_doDumpTrigCompsiteNavigation );
220 ATH_MSG_INFO("REGTEST m_doTDTCheck = " << m_doTDTCheck );
221
222 ATH_MSG_INFO("maxRepWarning = " << maxRepWarnings );
223
225 ATH_CHECK( m_muonPrinter.retrieve() );
226 }
227 else m_muonPrinter.disable(); // to avoid auto-retrieval
228
230 ATH_CHECK( m_clidSvc.retrieve() );
231 }
232
234 ATH_CHECK( m_trigDec.retrieve() );
235 ATH_MSG_INFO("TDT Executing with navigation format: " << m_trigDec->getNavigationFormat());
236 }
238
239 return StatusCode::SUCCESS;
240}
241
242
243StatusCode TrigEDMChecker::execute(const EventContext& ctx) {
244
245 /* fwinkl, Mar 20222:
246 Some attempt was made to make the code pass the thread-checker. Methods that
247 are clearly not thread-safe (e.g. use of DataHandle) are marked as such. Calling
248 these methods from within execute would still trigger a thread-checker warning.
249 Since this algorithm is only ever used for validation and in single-threaded athena,
250 we suppress these warnings by the following assignment. This has the advantage
251 (as opposed to disabling the checking for the entire file) that new code is still
252 being checked and will hopefully be written in a thread-safe manner, i.e. using
253 ReadHandleKeys. If someone is very eager they could migrate all uses of DataHandles...
254 */
255 StatusCode sc ATLAS_THREAD_SAFE = do_execute(ctx);
256 return sc;
257}
258
259StatusCode TrigEDMChecker::do_execute ATLAS_NOT_THREAD_SAFE(const EventContext& ctx) {
260
261 ATH_MSG_INFO( " ==========START of event===========" );
262
263 if(m_doDumpTrackParticleContainer){
264 StatusCode sc = dumpTrackParticleContainer();
265 if (sc.isFailure()) {
266 ATH_MSG_ERROR("The method dumpTrackParticleContainer() failed");
267 }
268 }
269
270 if(m_doDumpAll || m_doDumpLVL1_ROI ){
271 StatusCode sc = dumpLVL1_ROI();
272 if (sc.isFailure()) {
273 ATH_MSG_ERROR("The method dumpLVL1_ROI() failed");
274 }
275 }
276
277 /*
278 if(m_doDumpAll || m_doDumpTrigMissingET){
279 StatusCode sc = dumpTrigMissingET();
280 if (sc.isFailure()) {
281 mLog << MSG::ERROR << "The method dumpTrigMissingET() failed" << endmsg;
282
283 }
284 }
285 */
286
287 if(m_doDumpAll || m_doDumpxAODTrigMissingET){
288 StatusCode sc = dumpxAODTrigMissingET();
289 if (sc.isFailure()) {
290 ATH_MSG_ERROR("The method dumpxAODTrigMissingET() failed");
291 }
292 }
293
294 if(m_doDumpAll || m_doDumpMuonFeature){
295 StatusCode sc = dumpMuonFeature();
296 if (sc.isFailure()) {
297 ATH_MSG_ERROR("The method dumpMuonFeature() failed");
298 }
299 }
300
301 if(m_doDumpAll || m_doDumpCombinedMuonFeature){
302 StatusCode sc = dumpCombinedMuonFeature();
303 if (sc.isFailure()) {
304 ATH_MSG_ERROR("The method dumpCombinedMuonFeature() failed");
305 }
306 sc = dumpCombinedMuonFeatureContainer();
307 if (sc.isFailure()) {
308 ATH_MSG_ERROR("The method dumpCombinedMuonFeatureContainer() failed");
309 return StatusCode::SUCCESS;
310 }
311 }
312
313 if(m_doDumpAll || m_doDumpTileMuFeature) {
314 StatusCode sc = dumpTileMuFeatureContainer();
315 if (sc.isFailure()) {
316 ATH_MSG_ERROR("The method dumpTileMuFeatureContainer() failed");
317 }
318 }
319
320 if(m_doDumpAll || m_doDumpTileTrackMuFeature) {
321 StatusCode sc = dumpTileTrackMuFeatureContainer();
322 if (sc.isFailure()) {
323 ATH_MSG_ERROR("The method dumpTileTrackMuFeatureContainer() failed");
324 }
325 }
326
327 if(m_doDumpAll || m_doDumpTrigEMCluster){
328 StatusCode sc = dumpTrigEMCluster();
329 if (sc.isFailure()) {
330 ATH_MSG_ERROR("The method dumpTrigEMCluster() failed");
331 }
332 }
333
334 if(m_doDumpAll || m_doDumpTrigEMClusterContainer){
335 StatusCode sc = dumpTrigEMClusterContainer();
336 if (sc.isFailure()) {
337 ATH_MSG_ERROR("The method dumpTrigEMClusterContainer() failed");
338 }
339 }
340
341 if(m_doDumpAll || m_doDumpxAODTrigEMCluster){
342 StatusCode sc = dumpxAODTrigEMCluster();
343 if (sc.isFailure()) {
344 ATH_MSG_ERROR("The method dumpxAODTrigEMCluster() failed");
345 }
346 }
347
348 if(m_doDumpAll || m_doDumpxAODTrigEMClusterContainer){
349 StatusCode sc = dumpxAODTrigEMClusterContainer();
350 if (sc.isFailure()) {
351 ATH_MSG_ERROR("The method dumpxAODTrigEMClusterContainer() failed");
352 }
353 }
354
355 if(m_doDumpTrigTauClusterContainer){
356 StatusCode sc = dumpTrigTauClusterContainer();
357 if (sc.isFailure()) {
358 ATH_MSG_ERROR("The method dumpTrigTauClusterContainer() failed");
359 }
360 }
361
362 if(m_doDumpAll || m_doDumpTrigPhotonContainer){
363 StatusCode sc = dumpTrigPhotonContainer();
364 if (sc.isFailure()) {
365 ATH_MSG_ERROR("The method dumpTrigPhotonContainer() failed");
366 }
367 }
368
369 if(m_doDumpAll || m_doDumpxAODJetContainer){
370 StatusCode sc = dumpxAODJetContainer();
371 if (sc.isFailure()) {
372 ATH_MSG_ERROR("The method dumpxAODJetContainer() failed");
373 }
374 }
375
376 if(m_doDumpAll || m_doDumpTrigL2BphysContainer){
377 StatusCode sc = dumpTrigL2BphysContainer();
378 if (sc.isFailure()) {
379 ATH_MSG_ERROR("The method dumpTrigL2BphysContainer() failed");
380 }
381 }
382
383 if(m_doDumpAll || m_doDumpTrigEFBphysContainer){
384 StatusCode sc = dumpTrigEFBphysContainer();
385 if (sc.isFailure()) {
386 ATH_MSG_ERROR("The method dumpTrigEFBphysContainer() failed");
387 }
388 }
389
390 if(m_doDumpAll || m_doDumpTrigEFBjetContainer){
391 StatusCode sc = dumpTrigEFBjetContainer();
392 if (sc.isFailure()) {
393 ATH_MSG_ERROR("The method dumpTrigEFBjetContainer() failed");
394 }
395 }
396
397 if(m_doDumpAll || m_doDumpTrigL2BjetContainer){
398 StatusCode sc = dumpTrigL2BjetContainer();
399 if (sc.isFailure()) {
400 ATH_MSG_ERROR("The method dumpTrigL2BjetContainer() failed");
401 }
402 }
403
404 if(m_doDumpAll || m_doDumpTrigMuonEFContainer){
405 StatusCode sc = dumpTrigMuonEFContainer();
406 if (sc.isFailure()) {
407 ATH_MSG_ERROR("The method dumpTrigMuonEFContainer() failed");
408 }
409 }
410
411 if(m_doDumpAll || m_doDumpTrigMuonEFInfoContainer){
412 StatusCode sc = dumpTrigMuonEFInfoContainer();
413 if (sc.isFailure()) {
414 ATH_MSG_ERROR("The method dumpTrigMuonEFInfoContainer() failed");
415 }
416 }
417
418 if(m_doDumpAll || m_doDumpTrigMuonEFIsolationContainer) {
419 StatusCode sc = dumpTrigMuonEFIsolationContainer();
420 if(sc.isFailure()) {
421 ATH_MSG_ERROR("The method dumpTrigMuonEFIsolationContainer() failed");
422 }
423 }
424
425 if(m_doDumpAll || m_doDumpxAODMuonContainer) {
426 StatusCode sc = dumpxAODMuonContainer();
427 if(sc.isFailure()) {
428 ATH_MSG_ERROR("The method dumpxAODMuonContainer() failed");
429 }
430 }
431
432 if(m_doDumpAll || m_doDumpTrigElectronContainer){
433 StatusCode sc = dumpTrigElectronContainer();
434 if (sc.isFailure()) {
435 ATH_MSG_ERROR("The method dumpTrigElectronContainer() failed");
436 }
437 }
438
439 if(m_doDumpAll || m_doDumpxAODTrigElectronContainer){
440 StatusCode sc = dumpxAODTrigElectronContainer();
441 if (sc.isFailure()) {
442 ATH_MSG_ERROR("The method dumpxAODTrigElectronContainer() failed");
443 }
444 }
445
446 if(m_doDumpAll || m_doDumpxAODTrigPhotonContainer){
447 StatusCode sc = dumpxAODTrigPhotonContainer();
448 if (sc.isFailure()) {
449 ATH_MSG_ERROR("The method dumpxAODTrigElectronContainer() failed");
450 }
451 }
452
453 if(m_doDumpAll || m_doDumpxAODElectronContainer){
454 StatusCode sc = dumpxAODElectronContainer();
455 if (sc.isFailure()) {
456 ATH_MSG_ERROR("The method dumpxAODTrigElectronContainer() failed");
457 }
458 }
459
460 if(m_doDumpAll || m_doDumpxAODPhotonContainer){
461 StatusCode sc = dumpxAODPhotonContainer();
462 if (sc.isFailure()) {
463 ATH_MSG_ERROR("The method dumpxAODTrigElectronContainer() failed");
464 }
465 }
466
467 if(m_doDumpTrigTauContainer){
468 StatusCode sc = dumpTrigTauContainer();
469 if (sc.isFailure()) {
470 ATH_MSG_ERROR("The method dumpTrigTauContainer() failed");
471 }
472 }
473
474 if(m_doDumpTrigTauTracksInfo){
475 StatusCode sc = dumpTrigTauTracksInfo();
476 if (sc.isFailure()) {
477 ATH_MSG_ERROR("The method dumpTrigTauTracksInfo() failed");
478 }
479 }
480
481 if(m_doDumpAll || m_doDumpHLTResult){
482 StatusCode sc = dumpHLTResult();
483 if (sc.isFailure()) {
484 ATH_MSG_ERROR("The method dumpHLTResult() failed");
485 }
486 }
487
488 if(m_doDumpTrigInDetTrackCollection){
489 StatusCode sc = dumpTrigInDetTrackCollection();
490 if (sc.isFailure()) {
491 ATH_MSG_ERROR("The method dumpTrigInDetTrackCollection() failed");
492 }
493 }
494
495 if(m_doDumpAll || m_doDumpTrigVertexCollection){
496 StatusCode sc = dumpTrigVertexCollection();
497 if (sc.isFailure()) {
498 ATH_MSG_ERROR("The method dumpTrigVertexCollection() failed");
499 }
500 }
501
502 if(m_doDumpAll || m_doDumpxAODTauJetContainer){
503 StatusCode sc = dumpxAODTauJetContainer();
504 if (sc.isFailure()) {
505 ATH_MSG_ERROR("The method dumpxAODTauJetContainer() failed");
506 }
507 }
508
509 if(m_doDumpTauJetContainer){
510 StatusCode sc = dumpTauJetContainer();
511 if (sc.isFailure()) {
512 ATH_MSG_ERROR("The method dumpTauJetContainer() failed");
513 }
514 }
515
516 if(m_doDumpAll || m_doDumpxAODTrackParticle){
517 StatusCode sc = dumpxAODTrackParticle();
518 if (sc.isFailure()) {
519 ATH_MSG_ERROR("The method dumpxAODTrackParticle() failed");
520 }
521 }
522
523 if(m_doDumpAll || m_doDumpxAODVertex){
524 StatusCode sc = dumpxAODVertex();
525 if (sc.isFailure()) {
526 ATH_MSG_ERROR("The method dumpxAODVertex() failed");
527 }
528 }
529
530 if (m_doDumpAll || m_doDumpxAODTrigMinBias){
531 StatusCode sc = dumpxAODTrigMinBias();
532 if (sc.isFailure()) {
533 ATH_MSG_ERROR("The method dumpxAODTrigMinBias() failed");
534 }
535 }
536
537 if (m_doDumpTrigPassBits){
538 StatusCode sc = dumpTrigPassBits();
539 if (sc.isFailure()) {
540 ATH_MSG_ERROR("The method dumpTrigPassBits() failed");
541 }
542 }
543
544 if (m_doDumpAll || m_doDumpStoreGate) {
545 ATH_MSG_DEBUG(evtStore()->dump());
546 }
547
548 if (m_doDumpAll || m_doDumpNavigation) {
549 StatusCode sc = dumpNavigation(ctx);
550 if ( sc.isFailure() ) {
551 ATH_MSG_ERROR("The method dumpNavigation() failed");
552 }
553 }
554
555 if (m_doDumpAll || m_doTDTCheck) {
556 ATH_CHECK(dumpTDT());
557 }
558
559 if (m_doDumpAll || m_doDumpAllTrigComposite || m_dumpTrigCompositeContainers.size() > 0) {
560 ATH_CHECK( dumpTrigComposite() );
561 }
562
563 if (m_doDumpAll || m_doDumpTrigCompsiteNavigation) {
564 std::string trigCompositeSteering;
565 bool pass;
566 ATH_CHECK(TrigCompositeNavigationToDot(trigCompositeSteering, pass));
567 const std::string evtNumber = std::to_string(ctx.eventID().event_number());
568 const std::string passStr = (pass ? "Pass" : "Fail");
569 std::ofstream ofile(std::string("NavGraph_" + m_dumpNavForChain + "_Ev" + evtNumber + "_" + passStr + ".dot").c_str());
570 ofile << trigCompositeSteering;
571 }
572
573
574
575 ATH_MSG_INFO( " ==========END of event===========" );
576 return StatusCode::SUCCESS;
577
578}
579
582 const std::string name="HLT_xAOD__TrigPassBitsContainer_passbits";
583 const xAOD::TrigPassBitsContainer *xbitscont=nullptr;
584 StatusCode sc = evtStore()->retrieve(xbitscont,name);
585 if (sc.isFailure() ){
586 ATH_MSG_INFO("Cannot retrieve TrigPassBits");
587 }
588 else {
589 ATH_MSG_INFO("Size of PassBits container : " << xbitscont->size());
590 for(const auto bits:*xbitscont){
591 if(bits==nullptr){
592 ATH_MSG_INFO("TrigPassBits point nullptr ");
593 continue;
594 }
595 ATH_MSG_DEBUG("Analyzing bits for " << bits->containerClid() << " of size " << bits->size() << " with bit size " << bits->passBits().size());
596 }
597
598 for(const xAOD::TrigPassBits* bits : *xbitscont){
599 if(bits==nullptr){
600 ATH_MSG_INFO("TrigPassBits point nullptr ");
601 continue;
602 }
603 ATH_MSG_DEBUG("Analyzing bits for " << bits->containerClid() << " of size " << bits->size() << " with bit size " << bits->passBits().size());
604 }
605 }
606 return StatusCode::SUCCESS;
607}
608
610{
611 ATH_MSG_INFO("MinBias in dumpTrigSpacePointCounts()");
612
613 std::string METTag="HLT_xAOD__TrigSpacePointCountsContainer_spacepoints";
614
615 const xAOD::TrigSpacePointCountsContainer* SpacePointCountsCont=0;
616 StatusCode sc = evtStore()->retrieve(SpacePointCountsCont,METTag);
617
618 if (sc.isFailure())
619 ATH_MSG_INFO("failed to retrieve " << METTag);
620 else {
621 ATH_MSG_INFO("Accessing " << METTag << " with " << SpacePointCountsCont->size() << " elements");
622
623 std::string s; char buff[128];
624 std::vector<float> getVec;
625 float sum;
626
627 // Loop over container content
628 for(uint i = 0; i < SpacePointCountsCont->size(); i++) {
629 getVec = SpacePointCountsCont->at(i)->contentsPixelClusEndcapC();
630 sum = 0.;
631 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
632 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusEndcapC() = %10.2f ", s.c_str(), sum );
633 ATH_MSG_INFO(buff);
634
635 getVec = SpacePointCountsCont->at(i)->contentsPixelClusBarrel();
636 sum = 0.;
637 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
638 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusBarrel() = %10.2f ", s.c_str(), sum );
639 ATH_MSG_INFO(buff);
640
641 getVec = SpacePointCountsCont->at(i)->contentsPixelClusEndcapA();
642 sum = 0.;
643 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
644 snprintf(buff, sizeof(buff), "REGTEST %s SUM of contentsPixelClusEndcapA() = %10.2f ", s.c_str(), sum );
645 ATH_MSG_INFO(buff);
646
647 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotBins() = %u ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotBins() );
648 ATH_MSG_INFO(buff);
649
650 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotMin() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotMin() );
651 ATH_MSG_INFO(buff);
652
653 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusTotMax() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusTotMax() );
654 ATH_MSG_INFO(buff);
655
656 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeBins() = %u ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeBins() );
657 ATH_MSG_INFO(buff);
658
659 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeMin() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeMin() );
660 ATH_MSG_INFO(buff);
661
662 snprintf(buff, sizeof(buff), "REGTEST %s pixelClusSizeMax() = %10.2f ", s.c_str(), SpacePointCountsCont->at(i)->pixelClusSizeMax() );
663 ATH_MSG_INFO(buff);
664
665 snprintf(buff, sizeof(buff), "REGTEST %s sctSpEndcapC() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpEndcapC() );
666 ATH_MSG_INFO(buff);
667
668 snprintf(buff, sizeof(buff), "REGTEST %s sctSpBarrel() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpBarrel() );
669 ATH_MSG_INFO(buff);
670
671 snprintf(buff, sizeof(buff), "REGTEST %s sctSpEndcapA() = %u ", s.c_str(), SpacePointCountsCont->at(i)->sctSpEndcapA() );
672 ATH_MSG_INFO(buff);
673 }
674 }
675}
676
678 ATH_MSG_INFO("MinBias in dumpTrigT2MBTSBits()");
679
680 std::string METTag="HLT_xAOD__TrigT2MbtsBitsContainer_T2Mbts";
681
682 const xAOD::TrigT2MbtsBitsContainer* T2MbtsBitsCont=0;
683 StatusCode sc = evtStore()->retrieve(T2MbtsBitsCont,METTag);
684
685 if (sc.isFailure())
686 ATH_MSG_INFO("failed to retrieve " << METTag);
687 else {
688 ATH_MSG_INFO("Accessing " << METTag << " with " << T2MbtsBitsCont->size() << " elements");
689
690 std::string s; char buff[380];
691 std::vector<float> getVec;
692 float sum;
693
694 // Loop over container content
695 for(uint i = 0; i < T2MbtsBitsCont->size(); i++) {
696 getVec = T2MbtsBitsCont->at(i)->triggerEnergies();
697 sum = 0.;
698 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
699 snprintf(buff, sizeof(buff), "REGTEST %s SUM of triggerEnergies() = %10.2f ", s.c_str(), sum );
700 ATH_MSG_INFO(buff);
701
702 getVec = T2MbtsBitsCont->at(i)->triggerTimes();
703 sum = 0.;
704 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
705 snprintf(buff, sizeof(buff), "REGTEST %s SUM of triggerTimes() = %10.2f ", s.c_str(), sum );
706 ATH_MSG_INFO(buff);
707 }
708 }
709}
710
712 ATH_MSG_INFO("MinBias in dumpTrigVertexCounts()");
713
714 std::string METTag="HLT_xAOD__TrigVertexCountsContainer_vertexcounts";
715
716 const xAOD::TrigVertexCountsContainer* T2VertexCountsCont=0;
717 StatusCode sc = evtStore()->retrieve(T2VertexCountsCont,METTag);
718
719 if (sc.isFailure())
720 ATH_MSG_INFO("failed to retrieve " << METTag);
721 else {
722 ATH_MSG_INFO("Accessing " << METTag << " with " << T2VertexCountsCont->size() << " elements");
723
724 std::string s; char buff[380];
725 std::vector<float> fgetVec;
726 float fsum(0.);
727 std::vector<unsigned int> ugetVec;
728 unsigned int usum(0);
729
730 // Loop over container content
731 for(uint i = 0; i < T2VertexCountsCont->size(); i++) {
732 ugetVec = T2VertexCountsCont->at(i)->vtxNtrks();
733 for (uint j = 0; j < ugetVec.size(); ++j) usum += ugetVec[j];
734 snprintf(buff, sizeof(buff), "REGTEST %s SUM of vtxNtrks() = %u ", s.c_str(), usum );
735 ATH_MSG_INFO(buff);
736
737 fgetVec = T2VertexCountsCont->at(i)->vtxTrkPtSqSum();
738 for (uint j = 0; j < fgetVec.size(); ++j) fsum += fgetVec[j];
739 snprintf(buff, sizeof(buff), "REGTEST %s SUM of vtxTrkPtSqSum() = %10.2f ", s.c_str(), fsum );
740 ATH_MSG_INFO(buff);
741 }
742 }
743}
744
746 ATH_MSG_INFO("MinBias in dumpTrigTrackCounts()");
747
748 std::string METTag="HLT_xAOD__TrigTrackCountsContainer_trackcounts";
749
750 const xAOD::TrigTrackCountsContainer* T2TrackCountsCont=0;
751 StatusCode sc = evtStore()->retrieve(T2TrackCountsCont,METTag);
752
753 if (sc.isFailure())
754 ATH_MSG_INFO("failed to retrieve " << METTag);
755 else {
756 ATH_MSG_INFO("Accessing " << METTag << " with " << T2TrackCountsCont->size() << " elements");
757
758 std::string s; char buff[380];
759 std::vector<float> getVec;
760 float sum;
761
762 // Loop over container content
763 for(uint i = 0; i < T2TrackCountsCont->size(); i++) {
764 getVec = T2TrackCountsCont->at(i)->z0_pt();
765 sum = 0.;
766 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
767 snprintf(buff, sizeof(buff), "REGTEST %s SUM of z0_pt = %10.2f ", s.c_str(), sum );
768 ATH_MSG_INFO(buff);
769
770 getVec = T2TrackCountsCont->at(i)->eta_phi();
771 sum = 0.;
772 for (uint j = 0; j < getVec.size(); ++j) sum += getVec[j];
773 snprintf(buff, sizeof(buff), "REGTEST %s SUM of eta_phi() = %10.2f ", s.c_str(), sum );
774 ATH_MSG_INFO(buff);
775
776 snprintf(buff, sizeof(buff), "REGTEST %s z0Bins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->z0Bins() );
777 ATH_MSG_INFO(buff);
778
779 snprintf(buff, sizeof(buff), "REGTEST %s z0Min() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->z0Min() );
780 ATH_MSG_INFO(buff);
781
782 snprintf(buff, sizeof(buff), "REGTEST %s z0Max() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->z0Max() );
783 ATH_MSG_INFO(buff);
784
785 snprintf(buff, sizeof(buff), "REGTEST %s ptBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->ptBins() );
786 ATH_MSG_INFO(buff);
787
788 snprintf(buff, sizeof(buff), "REGTEST %s ptMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->ptMin() );
789 ATH_MSG_INFO(buff);
790
791 snprintf(buff, sizeof(buff), "REGTEST %s ptMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->ptMax() );
792 ATH_MSG_INFO(buff);
793
794 snprintf(buff, sizeof(buff), "REGTEST %s etaBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->etaBins() );
795 ATH_MSG_INFO(buff);
796
797 snprintf(buff, sizeof(buff), "REGTEST %s etaMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->etaMin() );
798 ATH_MSG_INFO(buff);
799
800 snprintf(buff, sizeof(buff), "REGTEST %s etaMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->etaMax() );
801 ATH_MSG_INFO(buff);
802
803 snprintf(buff, sizeof(buff), "REGTEST %s phiBins() = %u ", s.c_str(), T2TrackCountsCont->at(i)->phiBins() );
804 ATH_MSG_INFO(buff);
805
806 snprintf(buff, sizeof(buff), "REGTEST %s phiMin() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->phiMin() );
807 ATH_MSG_INFO(buff);
808
809 snprintf(buff, sizeof(buff), "REGTEST %s phiMax() = %10.2f ", s.c_str(), T2TrackCountsCont->at(i)->phiMax() );
810 ATH_MSG_INFO(buff);
811 }
812 }
813}
814
816
821
822 return StatusCode::SUCCESS;
823}
824
826
827
828
830
831 ATH_MSG_INFO("dumpxAODTrigMissingET()");
832
833 int ntag=4;
834 std::string METTags[]={"HLT_xAOD__TrigMissingETContainer_EFJetEtSum","HLT_xAOD__TrigMissingETContainer_TrigEFMissingET", "HLT_xAOD__TrigMissingETContainer_TrigL2MissingET_FEB","HLT_xAOD__TrigMissingETContainer_TrigEFMissingET_topocl"};
835
836 for(int itag=0; itag <ntag; itag++) {
837
838 const xAOD::TrigMissingETContainer* MissingETCont=0;
839 StatusCode sc = evtStore()->retrieve(MissingETCont,METTags[itag]);
840 if (sc.isFailure())
841 ATH_MSG_INFO("failed to retrieve " << METTags[itag]);
842 else {
843 ATH_MSG_INFO("Accessing " << METTags[itag] << " with " << MissingETCont->size() << " elements");
844
845 // Loop over container content
846 for(uint i = 0; i < MissingETCont->size(); i++) {
847
848 std::string s; char buff[3000];
849
850 snprintf(buff, sizeof(buff), "REGTEST %s Ex = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ex() );
851 ATH_MSG_INFO(buff);
852 snprintf(buff, sizeof(buff), "REGTEST %s Ey = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ey() );
853 ATH_MSG_INFO(buff);
854 snprintf(buff, sizeof(buff), "REGTEST %s Ez = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->ez() );
855 ATH_MSG_INFO(buff);
856 snprintf(buff, sizeof(buff), "REGTEST %s SumET = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->sumEt() );
857 ATH_MSG_INFO(buff);
858 snprintf(buff, sizeof(buff), "REGTEST %s SumE = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->at(i)->sumE() );
859 ATH_MSG_INFO(buff);
860 snprintf(buff, sizeof(buff), "REGTEST %s Flag = %d", s.c_str(), MissingETCont->at(i)->flag() );
861 ATH_MSG_INFO(buff);
862 snprintf(buff, sizeof(buff), "REGTEST %s Flag = %d", s.c_str(), MissingETCont->at(i)->roiWord() );
863 ATH_MSG_INFO(buff);
864
865 unsigned int Nc = MissingETCont->at(i)->getNumberOfComponents();
866 if (Nc > 0) {
867 s="REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
868 s+="/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
869 ATH_MSG_INFO(s);
870 }
871
872 for(uint j = 0; j < Nc; j++) {
873
874 std::string name = MissingETCont->at(i)->nameOfComponent(j);
875 const short status = MissingETCont->at(i)->statusComponent(j);
876 const unsigned short usedChan = MissingETCont->at(i)->usedChannelsComponent(j);
877 const short sumOfSigns = MissingETCont->at(i)->sumOfSignsComponent(j);
878 const float calib0 = MissingETCont->at(i)->calib0Component(j);
879 const float calib1 = MissingETCont->at(i)->calib1Component(j);
880 const float ex = MissingETCont->at(i)->exComponent(j);
881 const float ey = MissingETCont->at(i)->eyComponent(j);
882 const float ez = MissingETCont->at(i)->ezComponent(j);
883 const float sumE = MissingETCont->at(i)->sumEComponent(j);
884 const float sumEt = MissingETCont->at(i)->sumEtComponent(j);
885
886 snprintf(buff, sizeof(buff),
887 "REGTEST %s %6d %12d %10d %6.2f %6.3f %10.2f %10.2f %10.2f %10.2f %10.2f",
888 name.c_str(), status, usedChan, sumOfSigns, calib1, calib0,
889 ex, ey, ez, sumE, sumEt);
890 ATH_MSG_INFO(buff);
891 }
892 }
893 }
894 }
895
896 return StatusCode::SUCCESS;
897}
898
900
901
902
903StatusCode TrigEDMChecker::dumpTrigMissingET ATLAS_NOT_THREAD_SAFE() {
904
905 ATH_MSG_DEBUG("in dumpTrigMissingET()");
906
907 int ntag=3;
908 std::string METTags[]={"HLT_TrigMissingETContainer_TrigEFMissingET", "HLT_TrigMissingETContainer_TrigEFMissingET_FEB", "HLT_TrigMissingETContainer_TrigEFMissingET_topocl"};
909
911 for (int itag=0; itag < ntag; itag++) { // loop over L2, EF
912 const TrigMissingETContainer* trigMETcont;
913 StatusCode sc=evtStore()->retrieve(trigMETcont , METTags[itag]);
914 if( sc.isFailure() ){
915 ATH_MSG_INFO("Failed to retrieve TrigMissingETContainer with key " << METTags[itag]);
916 continue;
917 }
918
919 ATH_MSG_INFO("Got TrigMissingETContainer with key \"" << METTags[itag]<< "\"");
920
921 for (const TrigMissingET* met : *trigMETcont) {
922
923 ATH_MSG_INFO("REGTEST ==========START of TrigMissingET DUMP===========");
924
925 std::string s;
926 char buff[128];
927
928 snprintf(buff, sizeof(buff), "REGTEST %s Ex = %10.2f CLHEP::MeV", s.c_str(), met->ex() );
929 ATH_MSG_INFO(buff);
930 snprintf(buff, sizeof(buff), "REGTEST %s Ey = %10.2f CLHEP::MeV", s.c_str(), met->ey() );
931 ATH_MSG_INFO(buff);
932 snprintf(buff, sizeof(buff), "REGTEST %s Ez = %10.2f CLHEP::MeV", s.c_str(), met->ez() );
933 ATH_MSG_INFO(buff);
934 snprintf(buff, sizeof(buff), "REGTEST %s Et = %10.2f CLHEP::MeV", s.c_str(), met->et() );
935 ATH_MSG_INFO(buff);
936 snprintf(buff, sizeof(buff), "REGTEST %s SumEt = %10.2f CLHEP::MeV", s.c_str(), met->sumEt() );
937 ATH_MSG_INFO(buff);
938 snprintf(buff, sizeof(buff), "REGTEST %s SumE = %10.2f CLHEP::MeV", s.c_str(), met->sumE() );
939 ATH_MSG_INFO(buff);
940 snprintf(buff, sizeof(buff), "REGTEST %s E = %10.2f CLHEP::MeV", s.c_str(), met->e() );
941 ATH_MSG_INFO(buff);
942 snprintf(buff, sizeof(buff), "REGTEST %s flag = %10d", s.c_str(), met->getFlag() );
943 ATH_MSG_INFO(buff);
944 snprintf(buff, sizeof(buff), "REGTEST %s RoIword = %10ld", s.c_str(), met->RoIword() );
945 ATH_MSG_INFO(buff);
946
947 unsigned int Nc = met->getNumOfComponents();
948 if (Nc > 0) {
949 s="REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
950 s+="/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
951 ATH_MSG_INFO(s);
952
953 for (unsigned int i=0; i<Nc; ++i) { // loop over components
954 std::string name = met->getNameOfComponent(i);
955 const short status = met->getStatus(i);
956 const unsigned short usedChan = met->getUsedChannels(i);
957 const short sumOfSigns = met->getSumOfSigns(i);
958 const float calib0 = met->getComponentCalib0(i);
959 const float calib1 = met->getComponentCalib1(i);
960 const float ex = met->getExComponent(i);
961 const float ey = met->getEyComponent(i);
962 const float ez = met->getEzComponent(i);
963 const float sumE = met->getSumEComponent(i);
964 const float sumEt = met->getSumEtComponent(i);
965
966 snprintf(buff, sizeof(buff),
967 "REGTEST %s %6d %12d %10d %6.2f %6.3f %10.2f %10.2f %10.2f %10.2f %10.2f",
968 name.c_str(), status, usedChan, sumOfSigns, calib1, calib0,
969 ex, ey, ez, sumE, sumEt);
970 ATH_MSG_INFO(buff);
971 } // loop over components
972 }
973 } // loop over TrigMissingET objects
974 } // loop over TrigMissingETContainers
975
976 // if( sc.isSuccess() ) return sc; // Commented out by FB (12.07.14)
977
979 ATH_MSG_INFO("Trying to fetch TrigMissingET objects from older releases");
980
981 SG::ConstIterator<TrigMissingET> trigMETfirst ,trigMETlast;
982 StatusCode sc=evtStore()->retrieve(trigMETfirst ,trigMETlast);
983 if( sc.isFailure() ){
984 ATH_MSG_INFO("Failed to retrieve TrigMissingET (rel. <= 14.2.0)");
985 }
986
987 for( ; trigMETfirst != trigMETlast ; ++trigMETfirst ){ // loop over TrigMissingET objects
988 const std::string& name(trigMETfirst.key());
989 ATH_MSG_INFO("Got TrigMissingET object with key \"" << name << "\"");
990
991 std::string s;
992 char buff[3000];
993
994 if( name.find("TrigEFMissingET") != std::string::npos ) {
995 s="REGTEST EF: ";
996 } else if( name.find("T2MissingET") != std::string::npos ){
997 s="REGTEST L2: ";
998 } else {
999 ATH_MSG_WARNING(" This is UNKNOWN! " << name);
1000 s="REGTEST ??? ";
1001 }
1002
1003 snprintf(buff, sizeof(buff), "%s Ex = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ex() );
1004 ATH_MSG_INFO(buff);
1005 snprintf(buff, sizeof(buff), "%s Ey = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ey() );
1006 ATH_MSG_INFO(buff);
1007 snprintf(buff, sizeof(buff), "%s Ez = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ez() );
1008 ATH_MSG_INFO(buff);
1009 snprintf(buff, sizeof(buff), "%s Et = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->et() );
1010 ATH_MSG_INFO(buff);
1011 snprintf(buff, sizeof(buff), "%s SumE = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->sumE() );
1012 ATH_MSG_INFO(buff);
1013 snprintf(buff, sizeof(buff), "%s SumEt = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->sumEt() );
1014 ATH_MSG_INFO(buff);
1015 snprintf(buff, sizeof(buff), "%s E = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->e() );
1016 ATH_MSG_INFO(buff);
1017 snprintf(buff, sizeof(buff), "%s flag = %10d", s.c_str(), trigMETfirst->getFlag() );
1018 ATH_MSG_INFO(buff);
1019 snprintf(buff, sizeof(buff), "%s RoIword = %10ld", s.c_str(), trigMETfirst->RoIword() );
1020 ATH_MSG_INFO(buff);
1021
1022 unsigned int Nc = trigMETfirst->getNumOfComponents();
1023 if (Nc > 0) {
1024 s="REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
1025 s+="/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
1026 ATH_MSG_INFO(s);
1027
1028 for (unsigned int i=0; i<Nc; ++i) { // loop over components
1029 std::string name = trigMETfirst->getNameOfComponent(i);
1030 const short status = trigMETfirst->getStatus(i);
1031 const unsigned short usedChan = trigMETfirst->getUsedChannels(i);
1032 const short sumOfSigns = trigMETfirst->getSumOfSigns(i);
1033 const float calib0 = trigMETfirst->getComponentCalib0(i);
1034 const float calib1 = trigMETfirst->getComponentCalib1(i);
1035 const float ex = trigMETfirst->getExComponent(i);
1036 const float ey = trigMETfirst->getEyComponent(i);
1037 const float ez = trigMETfirst->getEzComponent(i);
1038 const float sumE = trigMETfirst->getSumEComponent(i);
1039 const float sumEt = trigMETfirst->getSumEtComponent(i);
1040
1041 snprintf(buff, sizeof(buff),
1042 "REGTEST %s %6d %12d %10d %6.2f %6.3f %10.2f %10.2f %10.2f %10.2f %10.2f",
1043 name.c_str(), status, usedChan, sumOfSigns, calib1, calib0,
1044 ex, ey, ez, sumE, sumEt);
1045 ATH_MSG_INFO(buff);
1046 } // loop over components
1047 }
1048 } // loop over TrigMissingET objects
1049
1050 ATH_MSG_INFO("REGTEST ==========END of TrigMissingET DUMP===========");
1051
1052 return StatusCode::SUCCESS;
1053}
1054
1056
1058
1059 ATH_MSG_DEBUG("in dumpTrackParticleContainer()");
1060
1061 ATH_MSG_INFO("REGTEST ==========START of TrackParticleContainer DUMP===========");
1062
1063 std::string trackPtags[]={"HLT_InDetTrigParticleCreation_Bjet_EFID",
1064 "HLT_InDetTrigParticleCreation_Bphysics_EFID",
1065 "HLT_InDetTrigParticleCreation_Electron_EFID",
1066 "HLT_InDetTrigParticleCreation_FullScan_EFID",
1067 "HLT_InDetTrigParticleCreation_Muon_EFID",
1068 "HLT_InDetTrigParticleCreation_Photon_EFID",
1069 "HLT_InDetTrigParticleCreation_Tau_EFID"};
1070
1071 int ntag=7;
1072
1073 StatusCode returnsc=StatusCode::SUCCESS;
1074
1075 for (int itag=0; itag<ntag; itag++){
1076 const Rec::TrackParticleContainer* pTrackParticleC = nullptr;
1077 StatusCode sc = evtStore()->retrieve(pTrackParticleC, trackPtags[itag]);
1078 if (sc.isFailure()) {
1079 ATH_MSG_INFO("REGTEST No TrackParticleContainer found with tag " << trackPtags[itag]);
1080 continue;
1081 }
1082 ATH_MSG_INFO("TrackParticleContainer found with tag " << trackPtags[itag]
1083 << " and size " << pTrackParticleC->size());
1084
1085 Rec::TrackParticleContainer::const_iterator trackItr = pTrackParticleC->begin();
1086 Rec::TrackParticleContainer::const_iterator trackItrE = pTrackParticleC->end();
1087 for (int ind=1; trackItr != trackItrE; ++trackItr, ind++) {
1088 const Rec::TrackParticle * trackParticle = (*trackItr);
1089 ATH_MSG_INFO(" TrackParticle " << ind << " charge "
1090 << trackParticle->charge() << " p "
1091 << trackParticle->p()<< " eta " << trackParticle->eta()
1092 << " phi " << trackParticle->phi());
1093
1095 const Trk::Track * track = trackParticle->originalTrack();
1096 if ( track ) {
1097 ATH_MSG_INFO(" Got attached track");
1098 const Trk::TrackParameters* perigee = track->perigeeParameters();
1099 if (perigee) {
1100 const auto& parameterVector = perigee->parameters();
1101 ATH_MSG_INFO(" q/P " << parameterVector[Trk::qOverP] <<
1102 " theta " << parameterVector[Trk::theta] <<
1103 " phi " <<parameterVector[Trk::phi]);
1104 } else {
1105 ATH_MSG_INFO(" No perigee attached to track");
1106 }
1107
1108 } else {
1110 ATH_MSG_DEBUG(" No attached track");
1112 ATH_MSG_WARNING(" Max attached track warning reached, no further warnings given");
1113 }
1115 }
1116 }
1117
1119 const Trk::VxCandidate * vertex = trackParticle->reconstructedVertex();
1120 if ( vertex ) {
1121 const Trk::RecVertex& vtx = vertex->recVertex();
1122 const Amg::Vector3D& position = vtx.position();
1123 ATH_MSG_INFO(" vertex position (" << position[0] << ", " <<
1124 position[1] << ", " << position[2] << ") ");
1125 } else {
1127 ATH_MSG_DEBUG(" No attached vertex");
1129 ATH_MSG_WARNING(" Max attached vertex warning reached, no further warnings given");
1130 }
1132 }
1133 }
1134
1135 const Trk::Perigee* perigee = trackParticle->measuredPerigee();
1136 if (perigee) {
1137 const auto& parameters = perigee->parameters();
1138 ATH_MSG_INFO("Trk::Perigee parameters:");
1139 ATH_MSG_INFO(" * d_0 : "<< parameters[Trk::d0] );
1140 ATH_MSG_INFO(" * z_0 : "<< parameters[Trk::z0] );
1141 ATH_MSG_INFO(" * phi : "<< parameters[Trk::phi] );
1142 ATH_MSG_INFO(" * Theta : "<< parameters[Trk::theta] );
1143 ATH_MSG_INFO(" * q/p : "<< parameters[Trk::qOverP] );
1144 } else {
1145 ATH_MSG_WARNING(" No attached perigee");
1146 }
1148 const Trk::TrackSummary* summary = trackParticle->trackSummary();
1149 if (summary) {
1150 ATH_MSG_DEBUG("Track summary information:");
1151 ATH_MSG_DEBUG(" * Number of B layer hits : "<<summary->get(Trk::numberOfBLayerHits));
1152 ATH_MSG_DEBUG(" * Number of pixel hits : "<<summary->get(Trk::numberOfPixelHits));
1153 ATH_MSG_DEBUG(" * Number of SCT hits : "<<summary->get(Trk::numberOfSCTHits));
1154 ATH_MSG_DEBUG(" * Number of TRT hits : "<<summary->get(Trk::numberOfTRTHits));
1155 }
1156 }
1157 }
1158 return returnsc;
1159}
1160
1161
1163
1165
1166 ATH_MSG_DEBUG("in dumpLVL1_ROI()");
1167
1168 ATH_MSG_INFO("REGTEST ==========START of LVL1_ROI DUMP===========");
1169
1170 const LVL1_ROI * lvl1ROI;
1171 StatusCode sc = evtStore()->retrieve(lvl1ROI);
1172 if (sc.isFailure() ) {
1173 ATH_MSG_INFO("REGTEST No LVL1_ROI found");
1174 return StatusCode::SUCCESS;
1175 }
1176
1177 ATH_MSG_INFO("REGTEST LVL1_ROI retrieved");
1178
1179 LVL1_ROI::emtaus_type::const_iterator itEMTau =
1180 (lvl1ROI->getEmTauROIs()).begin();
1181 LVL1_ROI::emtaus_type::const_iterator itEMTau_e =
1182 (lvl1ROI->getEmTauROIs()).end();
1183 int j = 0;
1184 for( ; itEMTau != itEMTau_e; ++itEMTau, ++j) {
1185 ATH_MSG_INFO("REGTEST Looking at LVL1_ROI " << j);
1186 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Eta is " << itEMTau->getEta());
1187 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Phi is " << itEMTau->getPhi());
1188 ATH_MSG_INFO("REGTEST LVL1 EmTauROI EMClus is " << itEMTau->getEMClus());
1189 ATH_MSG_INFO("REGTEST LVL1 EmTauROI TauClus is " << itEMTau->getTauClus());
1190 ATH_MSG_INFO("REGTEST LVL1 EmTauROI EMIsol is " << itEMTau->getEMIsol());
1191 ATH_MSG_INFO("REGTEST LVL1 EmTauROI HadIsol is " << itEMTau->getHadIsol());
1192 ATH_MSG_INFO("REGTEST LVL1 EmTauROI Core is " << itEMTau->getCore());
1193 ATH_MSG_INFO("REGTEST LVL1 EmTauROI HadCore is " << itEMTau->getHadCore());
1194 ATH_MSG_INFO("REGTEST LVL1 EmTauROI roiWord is " << itEMTau->getROIWord());
1195 }
1196
1197 ATH_MSG_INFO("REGTEST ==========END of LVL1_ROI DUMP===========");
1198 ATH_MSG_DEBUG("dumpLVL1_ROI() succeeded");
1199 return StatusCode::SUCCESS;
1200}
1201
1202
1204
1205StatusCode TrigEDMChecker::dumpTrigPhotonContainer ATLAS_NOT_THREAD_SAFE() {
1206
1207 ATH_MSG_DEBUG("in dumpTrigPhotonContainer()");
1208
1209 ATH_MSG_INFO("REGTEST ==========START of TrigPhotonContainer DUMP===========");
1210
1213
1214 StatusCode sc = evtStore()->retrieve(trigPhoton,lastTrigPhoton);
1215 if (sc.isFailure()) {
1216 ATH_MSG_INFO("REGTEST No TrigPhotonContainer found");
1217 return StatusCode::SUCCESS;
1218 }
1219 ATH_MSG_INFO("REGTEST TrigPhotonContainers retrieved");
1220
1221
1222 for (int i=0; trigPhoton != lastTrigPhoton; ++trigPhoton, ++i) {
1223
1224 ATH_MSG_INFO("REGTEST Looking at TrigPhotonContainer " << i);
1225
1226 TrigPhotonContainer::const_iterator PhotonItr = trigPhoton->begin();
1227 TrigPhotonContainer::const_iterator PhotonItrE = trigPhoton->end();
1228
1229 for (int j=0; PhotonItr != PhotonItrE; ++PhotonItr, ++j ) {
1230
1231 ATH_MSG_INFO("REGTEST Looking at TrigPhoton " << j);
1232
1233 ATH_MSG_INFO("REGTEST TrigPhoton->dPhi() returns " << (*PhotonItr)->dPhi());
1234 ATH_MSG_INFO("REGTEST TrigPhoton->dEta() returns " << (*PhotonItr)->dEta());
1235 ATH_MSG_INFO("REGTEST TrigPhoton->rCore() returns " << (*PhotonItr)->rCore());
1236 ATH_MSG_INFO("REGTEST TrigPhoton->isValid() returns " << (*PhotonItr)->isValid());
1237 ATH_MSG_INFO("REGTEST TrigPhoton->Et() returns " << (*PhotonItr)->Et());
1238
1239 if ( (*PhotonItr)->cluster() != NULL ) {
1240 ATH_MSG_INFO("REGTEST Cluster info: ");
1241 ATH_MSG_INFO("REGTEST cluster->e() returns " << (*PhotonItr)->cluster()->e());
1242 ATH_MSG_INFO("REGTEST cluster->e237() returns " << (*PhotonItr)->cluster()->e237());
1243 ATH_MSG_INFO("REGTEST cluster->e277() returns " << (*PhotonItr)->cluster()->e277());
1244 ATH_MSG_INFO("REGTEST cluster->fracs1() returns " << (*PhotonItr)->cluster()->fracs1());
1245 ATH_MSG_INFO("REGTEST cluster->weta2() returns " << (*PhotonItr)->cluster()->weta2());
1246 ATH_MSG_INFO("REGTEST cluster->ehad() returns " << (*PhotonItr)->cluster()->ehad1());
1247 ATH_MSG_INFO("REGTEST cluster->emaxs1() returns " << (*PhotonItr)->cluster()->emaxs1());
1248
1249 ATH_MSG_INFO("REGTEST Looking at P4PtEtaPhiM " << j);
1250
1251 ATH_MSG_INFO("REGTEST P4PtEtaPhiM->Pt() returns " << (*PhotonItr)->pt());
1252 ATH_MSG_INFO("REGTEST P4PtEtaPhiM->Eta() returns " << (*PhotonItr)->eta());
1253 ATH_MSG_INFO("REGTEST P4PtEtaPhiM->Phi() returns " << (*PhotonItr)->phi());
1254 ATH_MSG_INFO("REGTEST P4PtEtaPhiM->m() returns " << (*PhotonItr)->m());
1255 }
1256
1257 // printout variables using the new << operator
1258 ATH_MSG_INFO("TrigPhoton printout:");
1259 ATH_MSG_INFO("REGTEST " << (**PhotonItr));
1260
1261 // do second loop to compare TrigPhotons using comparison operators
1262 TrigPhotonContainer::const_iterator PhotonItr2 = PhotonItr;
1263 TrigPhotonContainer::const_iterator PhotonItr2E = trigPhoton->end();
1264
1265 for (int k=0; PhotonItr2 != PhotonItr2E; ++PhotonItr2, ++k ) {
1266 // find if TrigPhotons are the same (i.e. have same cluster and track
1267 if ( (**PhotonItr) == (**PhotonItr2) ) {
1268 ATH_MSG_INFO("REGTEST TrigPhoton nr. " << j << " is the same as TrigPhoton nr. " << k);
1269 } else {
1270 // TrigPhotons are different, print out differences
1271 std::map<std::string, double> v_diff;
1272 diff(*(*PhotonItr),*(*PhotonItr2), v_diff);
1273 ATH_MSG_INFO("TrigPhoton " << k << " different form TrigPhoton " << j << " :");
1274 for (const auto& p : v_diff) {
1275 ATH_MSG_INFO("TrigPhoton Delta_" << p.first << " = " << p.second);
1276 }
1277 }
1278 }
1279 }
1280 }
1281
1282 ATH_MSG_INFO("REGTEST ==========END of TrigPhotonContainer DUMP===========");
1283 ATH_MSG_DEBUG("dumpTrigPhotonContainer() succeeded");
1284
1285 return StatusCode::SUCCESS;
1286}
1287
1288
1290
1291StatusCode TrigEDMChecker::dumpTrigMuonEFContainer ATLAS_NOT_THREAD_SAFE() {
1292
1293 ATH_MSG_DEBUG("in dumpTrigMuonEFContainer()");
1294
1295 ATH_MSG_INFO("REGTEST ==========START of TrigMuonEFContainer DUMP===========");
1296
1299
1300 StatusCode sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1301 if (sc.isFailure()) {
1302 ATH_MSG_INFO("REGTEST No TrigMuonEFContainer found");
1303 return StatusCode::SUCCESS;
1304 }
1305 ATH_MSG_INFO("REGTEST TrigMuonEFContainers retrieved");
1306
1307 for (int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++i) {
1308
1309 ATH_MSG_INFO("REGTEST Looking at TrigMuonEFContainer " << i);
1310
1311 TrigMuonEFContainer::const_iterator MuonItr = trigMuon->begin();
1312 TrigMuonEFContainer::const_iterator MuonItrE = trigMuon->end();
1313
1314 for (int j=0; MuonItr != MuonItrE; ++MuonItr, ++j ) {
1315
1316 ATH_MSG_INFO("REGTEST Looking at TrigMuonEF " << j);
1317
1318 ATH_MSG_INFO("REGTEST TrigMuonEF->muonCode() returns " << (*MuonItr)->MuonCode());
1319 ATH_MSG_INFO("REGTEST TrigMuonEF->roi() returns " << (*MuonItr)->RoINum());
1320 ATH_MSG_INFO("REGTEST TrigMuonEF->charge() returns " << (*MuonItr)->Charge());
1321
1322 ATH_MSG_INFO("REGTEST Looking at P4IPtCotThPhiM " << j);
1323
1324 ATH_MSG_INFO("REGTEST P4IPtCotThPhiM->iPt() returns " << (*MuonItr)->iPt());
1325 ATH_MSG_INFO("REGTEST P4IPtCotThPhiM->CotTh() returns " << (*MuonItr)->cotTh());
1326 ATH_MSG_INFO("REGTEST P4IPtCotThPhiM->Phi() returns " << (*MuonItr)->phi());
1327 ATH_MSG_INFO("REGTEST P4IPtCotThPhiM->m() returns " << (*MuonItr)->m());
1328 }
1329 }
1330
1331 ATH_MSG_INFO("REGTEST ==========END of TrigMuonEFContainer DUMP===========");
1332 ATH_MSG_DEBUG("dumpTrigMuonEFContainer() succeeded");
1333
1334 return StatusCode::SUCCESS;
1335}
1336
1338
1339 ATH_MSG_DEBUG("In dumpxAODMuonContainer");
1340
1341 ATH_MSG_INFO( "REGTEST ==========START of xAOD::MuonContainer DUMP===========" );
1342
1343 const xAOD::MuonContainer* muonCont=0;
1344 StatusCode sc = evtStore()->retrieve(muonCont,"HLT_xAOD__MuonContainer_MuonEFInfo");
1345 if (sc.isFailure()) {
1346 ATH_MSG_INFO("REGTEST No muon container HLT_xAOD__MuonContainer_MuonEFInfo");
1347 return StatusCode::SUCCESS;
1348 }
1349
1350 std::string output = m_muonPrinter->print( *muonCont );
1351 msg(MSG::INFO) << output << endmsg;
1352
1353 ATH_MSG_INFO( "REGTEST ==========END of xAOD::MuonContainer DUMP===========" );
1354
1355 return StatusCode::SUCCESS;
1356
1357}
1358
1360
1361StatusCode TrigEDMChecker::dumpTrigMuonEFInfoContainer ATLAS_NOT_THREAD_SAFE() {
1362
1363 ATH_MSG_DEBUG("in dumpTrigMuonEFInfoContainer()");
1364
1365 ATH_MSG_INFO("REGTEST ==========START of TrigMuonEFInfoContainer DUMP===========");
1366
1369
1370 StatusCode sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1371 if (sc.isFailure()) {
1372 ATH_MSG_INFO("REGTEST No TrigMuonEFInfoContainer found");
1373 return StatusCode::SUCCESS;
1374 }
1375 ATH_MSG_INFO("REGTEST TrigMuonEFInfoContainers retrieved");
1376
1377
1378 for (int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++i) {
1379
1380 ATH_MSG_INFO("REGTEST -+-+-+-+ Looking at TrigMuonEFInfoContainer " << i);
1381
1382 TrigMuonEFInfoContainer::const_iterator MuonItr = trigMuon->begin();
1383 TrigMuonEFInfoContainer::const_iterator MuonItrE = trigMuon->end();
1384
1385 for (int j=0; MuonItr != MuonItrE; ++MuonItr, ++j ) {
1386
1387 ATH_MSG_INFO("REGTEST Looking at TrigMuonEFInfo " << j);
1388
1389 const TrigMuonEFInfo* muonInfo = (*MuonItr);
1390
1391 ATH_MSG_INFO("REGTEST Test self equality ");
1392 if (*muonInfo == *muonInfo) {
1393 ATH_MSG_INFO("REGTEST passed ");
1394 }
1395 else {
1396 ATH_MSG_INFO("REGTEST failed ");
1397 }
1398
1399
1400 if (muonInfo->hasTrack()) {
1401 ATH_MSG_INFO("REGTEST Test new version ");
1402
1403 ATH_MSG_INFO("REGTEST hasTracks()=true ");
1404 const TrigMuonEFInfoTrackContainer *tc = muonInfo->TrackContainer();
1405 ATH_MSG_INFO("REGTEST TrackContainer size: " << tc->size());
1406
1407 for (TrigMuonEFInfoTrackContainer::const_iterator TrackItr = tc->begin() ; TrackItr!=tc->end(); ++TrackItr) {
1408
1409 const TrigMuonEFInfoTrack* muonInfo = (*TrackItr);
1410 ATH_MSG_INFO("REGTEST MuonType(): ");
1411
1412 const TrigMuonEFTrack* muonTrack = muonInfo->SpectrometerTrack();
1413 if (muonTrack) {
1414 printMuonTrk(muonTrack);
1415 } else {
1416 ATH_MSG_INFO("REGTEST no SpectrometerTrack track found");
1417 }
1418
1419 ATH_MSG_INFO("REGTEST Looking at TrigMuonEFTrack ExtrapolatedTrack()");
1420 muonTrack = muonInfo->ExtrapolatedTrack();
1421 if (muonTrack) {
1422 printMuonTrk(muonTrack);
1423 } else {
1424 ATH_MSG_INFO("REGTEST no ExtrapolatedTrack track found");
1425 }
1426
1427 ATH_MSG_INFO("REGTEST Looking at TrigMuonEFTrack CombinedTrack()");
1428 const TrigMuonEFCbTrack* muonCbTrack = muonInfo->CombinedTrack();
1429 if (muonCbTrack) {
1430 printMuonTrk(muonTrack);
1431 } else {
1432 ATH_MSG_INFO("REGTEST no CombinedTrack track found");
1433 }
1434 }
1435
1436 }
1437
1438 if (!muonInfo) {
1439 ATH_MSG_INFO("REGTEST no TrigMuonEFInfo found");
1440 return StatusCode::SUCCESS;
1441 }
1442 ATH_MSG_INFO("REGTEST TrigMuonEFInfo->RoINum() returns " << muonInfo->RoINum());
1443 }
1444 }
1445
1446 ATH_MSG_INFO("REGTEST ==========END of TrigMuonEFInfoContainer DUMP===========");
1447 ATH_MSG_DEBUG("dumpTrigMuonEFInfoContainer() succeeded");
1448
1449 return StatusCode::SUCCESS;
1450}
1451
1453
1454StatusCode TrigEDMChecker::dumpTrigMuonEFIsolationContainer ATLAS_NOT_THREAD_SAFE() {
1455
1456 ATH_MSG_DEBUG("in dumpTrigMuonEFIsolationContainer()");
1457
1458 ATH_MSG_INFO("REGTEST ==========START of TrigMuonEFIsolationContainer DUMP===========");
1459
1462
1463 StatusCode sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1464 if (sc.isFailure()) {
1465 ATH_MSG_INFO("REGTEST No TrigMuonEFIsolationContainer found");
1466 return StatusCode::SUCCESS;
1467 }
1468 ATH_MSG_INFO("REGTEST TrigMuonEFIsolationContainers retrieved");
1469
1470
1471 for (int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++i) {
1472
1473 ATH_MSG_INFO("REGTEST -+-+-+-+ Looking at TrigMuonEFIsolationContainer " << i);
1474
1475 TrigMuonEFIsolationContainer::const_iterator MuonItr = trigMuon->begin();
1476 TrigMuonEFIsolationContainer::const_iterator MuonItrE = trigMuon->end();
1477
1478 for (int j=0; MuonItr != MuonItrE; ++MuonItr, ++j ) {
1479
1480 ATH_MSG_INFO("REGTEST Looking at TrigMuonEFIsolation " << j);
1481
1482 const TrigMuonEFIsolation* muonIsolation = (*MuonItr);
1483
1484 ATH_MSG_INFO("REGTEST Test self equality ");
1485 if (*muonIsolation == *muonIsolation) {
1486 ATH_MSG_INFO("REGTEST passed ");
1487 }
1488 else {
1489 ATH_MSG_INFO("REGTEST failed ");
1490 }
1491
1492 ATH_MSG_INFO("REGTEST sumTrkPtCone02(): " << muonIsolation->sumTrkPtCone02());
1493 ATH_MSG_INFO("REGTEST sumTrkPtCone03(): " << muonIsolation->sumTrkPtCone03());
1494 ATH_MSG_INFO("REGTEST sumEtCone01() : " << muonIsolation->sumEtCone01());
1495 ATH_MSG_INFO("REGTEST sumEtCone02() : " << muonIsolation->sumEtCone02());
1496 ATH_MSG_INFO("REGTEST sumEtCone03() : " << muonIsolation->sumEtCone03());
1497 ATH_MSG_INFO("REGTEST sumEtCone04() : " << muonIsolation->sumEtCone04());
1498 ATH_MSG_INFO("REGTEST trackPosition() : " << muonIsolation->trackPosition() );
1499 // access MuonInfo* - only works for >=2012 data
1500 if(muonIsolation->getMuonInfo()) {
1501 ATH_MSG_INFO("REGTEST Link MuonEFInfo found: " << muonIsolation->getMuonInfo());
1502 if(!muonIsolation->getEFMuonInfoTrack()) {
1503 ATH_MSG_WARNING("REGTEST No InfoTrack attached to this EFIsolation object");
1504 }
1505 else {
1506 const TrigMuonEFInfoTrack* trk = muonIsolation->getEFMuonInfoTrack();
1507 ATH_MSG_INFO("REGTEST Linke EFInfoTrack has MuonType : " << trk->MuonType());
1508 if(trk->hasCombinedTrack()) ATH_MSG_INFO("REGTEST Linked EFInfoTrack combined pt : " << trk->CombinedTrack()->pt());
1509 if(trk->hasExtrapolatedTrack()) ATH_MSG_INFO("REGTEST Linked EFInfoTrack extrapolated pt : " << trk->ExtrapolatedTrack()->pt());
1510 if(trk->hasSpectrometerTrack()) ATH_MSG_INFO("REGTEST Linked EFInfoTrack MS pt : " << trk->SpectrometerTrack()->pt());
1511 if(trk->hasCombinedTrack()) {
1512 if(trk->CombinedTrack()->getIDTrackParticle())
1513 ATH_MSG_INFO("REGTEST Linked EFInfoTrack ID track pt : " << trk->CombinedTrack()->getIDTrackParticle()->pt());
1514 }
1515
1516 }
1517 }else {
1518 ATH_MSG_INFO("REGTEST No Linked MuonEFInfo, expected for pre 2012 data");
1519 }
1520
1521 }//TrigMuonEFIsolation loop
1522 }//TrigMuonEFIsolationContainer loop
1523
1524 ATH_MSG_INFO("REGTEST ==========END of TrigMuonEFIsolationContainer DUMP===========");
1525 ATH_MSG_DEBUG("dumpTrigMuonEFIsolationContainer() succeeded");
1526
1527 return StatusCode::SUCCESS;
1528
1529}//dumpTrigMuonEFIsolationContainer
1530
1531
1533 ATH_MSG_INFO("POINTER TrigMuonEFTrack: " << muonTrack);
1534 //if(muonTrack) mLog << MSG::INFO << "REGTEST TrigMuonEFTrack: " << *muonTrack << endmsg;
1535
1536// mLog <<MSG::INFO << "REGTEST TrigMuonEFTrack->charge() returns " << muonTrack->Charge() << endmsg;
1537// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->iPt() returns " << muonTrack->iPt() << endmsg;
1538// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->CotTh() returns " << muonTrack->cotTh() << endmsg;
1539// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->Phi() returns " << muonTrack->phi() << endmsg;
1540// mLog <<MSG::INFO << "REGTEST P4IPtCotThPhiM->m() returns " << muonTrack->m() << endmsg;
1541// mLog <<MSG::INFO << "REGTEST chi2() returns " << muonTrack->chi2() << endmsg;
1542// mLog <<MSG::INFO << "REGTEST chi2prob() returns " << muonTrack->chi2prob() << endmsg;
1543// mLog <<MSG::INFO << "REGTEST posX() returns " << muonTrack->posX() << endmsg;
1544// mLog <<MSG::INFO << "REGTEST posY() returns " << muonTrack->posY() << endmsg;
1545// mLog <<MSG::INFO << "REGTEST posZ() returns " << muonTrack->posZ() << endmsg;
1546// mLog <<MSG::INFO << "REGTEST NCscHitsEta() returns " << muonTrack->NCscHitsEta() << endmsg;
1547// mLog <<MSG::INFO << "REGTEST NCscHitsPhi() returns " << muonTrack->NCscHitsPhi() << endmsg;
1548// mLog <<MSG::INFO << "REGTEST NTgcHitsEta() returns " << muonTrack->NTgcHitsEta() << endmsg;
1549// mLog <<MSG::INFO << "REGTEST NTgcHitsPhi() returns " << muonTrack->NTgcHitsPhi() << endmsg;
1550// mLog <<MSG::INFO << "REGTEST NMdtHitsEta() returns " << muonTrack->NMdtHitsEta() << endmsg;
1551// mLog <<MSG::INFO << "REGTEST NMdtHitsPhi() returns " << muonTrack->NMdtHitsPhi() << endmsg;
1552// mLog <<MSG::INFO << "REGTEST NRpcHitsEta() returns " << muonTrack->NRpcHitsEta() << endmsg;
1553// mLog <<MSG::INFO << "REGTEST NRpcHitsPhi() returns " << muonTrack->NRpcHitsPhi() << endmsg;
1554// mLog <<MSG::INFO << "REGTEST d0() returns " << muonTrack->d0() << endmsg;
1555// mLog <<MSG::INFO << "REGTEST z0() returns " << muonTrack->z0() << endmsg;
1556}
1557
1559 ATH_MSG_INFO(" POINTER TrigMuonEFCbTrack: " << muonTrack);
1560 //if(muonTrack) mLog << MSG::INFO << "REGTEST TrigMuonEFCbTrack: " << *muonTrack << endmsg;
1561
1562// printMuonTrk(mLog,(TrigMuonEFTrack*)muonTrack);
1563// mLog <<MSG::INFO << "REGTEST TrigMuonEFCbTrack " << muonTrack << endmsg;
1564// mLog <<MSG::INFO << "REGTEST NIdPixelHits() returns " << muonTrack->NIdPixelHits() << endmsg;
1565// mLog <<MSG::INFO << "REGTEST NIdSctHits() returns " << muonTrack->NIdSctHits() << endmsg;
1566// mLog <<MSG::INFO << "REGTEST NTrtHits() returns " << muonTrack->NTrtHits() << endmsg;
1567// mLog <<MSG::INFO << "REGTEST matchChi2() returns " << muonTrack->matchChi2() << endmsg;
1568}
1569
1571
1572StatusCode TrigEDMChecker::dumpTrigElectronContainer ATLAS_NOT_THREAD_SAFE() {
1573
1574 ATH_MSG_DEBUG("in dumpTrigElectronContainer()");
1575
1576 ATH_MSG_INFO("REGTEST ==========START of TrigElectronContainer DUMP===========");
1577
1580
1581 StatusCode sc = evtStore()->retrieve(trigElec,lastTrigElec);
1582 if (sc.isFailure()) {
1583 ATH_MSG_INFO("REGTEST No TrigelectronContainer found");
1584 return StatusCode::SUCCESS;
1585 }
1586 ATH_MSG_INFO("REGTEST TrigElectronContainers retrieved");
1587
1588 // declare pointer to the last trigElectron to test comparison operators
1590
1591 for (int i=0; trigElec != lastTrigElec; ++trigElec, ++i) {
1592
1593 ATH_MSG_INFO("REGTEST Looking at TrigElectronContainer " << i);
1594
1595 TrigElectronContainer::const_iterator elecItr = trigElec->begin();
1596 TrigElectronContainer::const_iterator elecItrE = trigElec->end();
1597
1598 for (int j=0; elecItr != elecItrE; ++elecItr, ++j ) {
1599
1600 ATH_MSG_INFO("REGTEST Looking at TrigElectron " << j);
1601 // mLog <<MSG::INFO << "REGTEST TrigElectron->isValid() returns " << (*elecItr)->isValid() << endmsg;
1602 // mLog <<MSG::INFO << "REGTEST TrigElectron->pt() returns " << (*elecItr)->pt() << endmsg;
1603 // mLog <<MSG::INFO << "REGTEST TrigElectron->eta() returns " << (*elecItr)->eta() << endmsg;
1604 // mLog <<MSG::INFO << "REGTEST TrigElectron->phi() returns " << (*elecItr)->phi() << endmsg;
1605 // mLog <<MSG::INFO << "REGTEST TrigElectron->Zvtx() returns " << (*elecItr)->Zvtx() << endmsg;
1606
1607 // mLog <<MSG::INFO << "REGTEST TrigElectron->charge() returns " << (*elecItr)->charge() << endmsg;
1608 // mLog <<MSG::INFO << "REGTEST TrigElectron->trackIndx() returns " << (*elecItr)->trackIndx() << endmsg;
1609 // mLog <<MSG::INFO << "REGTEST TrigElectron->trkClusDphi() returns " << (*elecItr)->trkClusDphi() << endmsg;
1610 // mLog <<MSG::INFO << "REGTEST TrigElectron->trkClusDeta() returns " << (*elecItr)->trkClusDeta() << endmsg;
1611 // mLog <<MSG::INFO << "REGTEST TrigElectron->Pt() (track) returns " << (*elecItr)->Pt() << endmsg;
1612 // mLog <<MSG::INFO << "REGTEST TrigElectron->err_Pt() returns " << (*elecItr)->err_Pt() << endmsg;
1613 // mLog <<MSG::INFO << "REGTEST TrigElectron->err_eta() returns " << (*elecItr)->err_eta() << endmsg;
1614 // mLog <<MSG::INFO << "REGTEST TrigElectron->err_phi() returns " << (*elecItr)->err_phi() << endmsg;
1615 // mLog <<MSG::INFO << "REGTEST TrigElectron->err_Zvtx() returns " << (*elecItr)->err_Zvtx() << endmsg;
1616
1617 // mLog <<MSG::INFO << "REGTEST New methods: " << endmsg;
1618 // mLog <<MSG::INFO << "REGTEST TrigElectron->roiWord() returns " << (*elecItr)->roiWord() << endmsg;
1619 // mLog <<MSG::INFO << "REGTEST TrigElectron->trkEtaAtCalo() returns " << (*elecItr)->trkEtaAtCalo() << endmsg;
1620 // mLog <<MSG::INFO << "REGTEST TrigElectron->trkPhiAtCalo() returns " << (*elecItr)->trkPhiAtCalo() << endmsg;
1621 // mLog <<MSG::INFO << "REGTEST TrigElectron->caloEta() returns " << (*elecItr)->caloEta() << endmsg;
1622 // mLog <<MSG::INFO << "REGTEST TrigElectron->caloPhi() returns " << (*elecItr)->caloPhi() << endmsg;
1623 // mLog <<MSG::INFO << "REGTEST TrigElectron->Rcore() returns " << (*elecItr)->Rcore() << endmsg;
1624 // mLog <<MSG::INFO << "REGTEST TrigElectron->Eratio() returns " << (*elecItr)->Eratio() << endmsg;
1625 // mLog <<MSG::INFO << "REGTEST TrigElectron->EThad() returns " << (*elecItr)->EThad() << endmsg;
1626
1627 // printout variables using the new << operator
1628 ATH_MSG_INFO("TrigElectron printout:");
1629 ATH_MSG_INFO("REGTEST " << (**elecItr));
1630
1631 // do second loop to compare TrigElectrons using comparison operators
1632 TrigElectronContainer::const_iterator elecItr2 = elecItr; //trigElec->begin();
1633 TrigElectronContainer::const_iterator elecItr2E = trigElec->end();
1634
1635 for (int k=0; elecItr2 != elecItr2E; ++elecItr2, ++k ) {
1636 // find if TrigElectrons are the same (i.e. have same cluster and track
1637 if ( (**elecItr) == (**elecItr2) ) {
1638 ATH_MSG_INFO("REGTEST TrigElectron nr. " << j << " is the same as TrigElectron nr. " << k);
1639 } else {
1640 // TrigElectrons are different, print out differences
1641 std::map<std::string, double> v_diff;
1642 diff(*(*elecItr),*(*elecItr2), v_diff);
1643 ATH_MSG_INFO("TrigElectron " << k << " different form TrigElectron " << j << " :");
1644 for (const auto& p : v_diff) {
1645 ATH_MSG_INFO("TrigElectron Delta_" << p.first << " = " << p.second);
1646 }
1647 }
1648 }
1649 }
1650 }
1651
1652 ATH_MSG_INFO("REGTEST ==========END of TrigElectronContainer DUMP===========");
1653 ATH_MSG_DEBUG("dumpTrigElectronContainer() succeeded");
1654
1655 return StatusCode::SUCCESS;
1656}
1657
1660
1661 ATH_MSG_DEBUG("In dumpxAODElectronContainer");
1662
1663 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigElectronContainer DUMP===========" );
1664
1665 const xAOD::TrigElectronContainer* elCont=0;
1666 StatusCode sc = evtStore()->retrieve(elCont,"HLT_xAOD__TrigElectronContainer_L2ElectronFex");
1667 if (sc.isFailure()) {
1668 ATH_MSG_INFO("REGTEST No TrigElectron container HLT_xAOD__TrigElectronContainer_L2ElectronFex");
1669 return StatusCode::SUCCESS;
1670 }
1671
1672 for (const auto eg : *elCont){
1673 ATH_MSG_INFO("REGTEST TrigElectron->Phi() returns " << eg->phi());
1674 ATH_MSG_INFO("REGTEST TrigElectron->Eta() returns " << eg->eta());
1675 ATH_MSG_INFO("REGTEST TrigElectron->rEta returns " << eg->rcore());
1676 ATH_MSG_INFO("REGTEST TrigElectron->eratio() returns " << eg->eratio());
1677 ATH_MSG_INFO("REGTEST TrigElectron->pt() returns " << eg->pt());
1678 ATH_MSG_INFO("REGTEST TrigElectron->etHad() returns " << eg->etHad());
1679 ATH_MSG_INFO("REGTEST TrigElectron->f1() returns " << eg->f1());
1680 ATH_MSG_INFO("REGTEST TrigElectron caloEta = " << eg->caloEta());
1681 ATH_MSG_INFO("REGTEST TrigElectron dPhiCalo" << eg->trkClusDphi());
1682 ATH_MSG_INFO("REGTEST TrigElectron dEtaCalo" << eg->trkClusDeta());
1683 ATH_MSG_INFO("REGTEST TrigElectron pTcalo" << eg->pt());
1684 ATH_MSG_INFO("REGTEST TrigElectron eTOverPt" << eg->etOverPt());
1685 ATH_MSG_INFO("REGTEST TrigElectron nTRTHits" << eg->nTRTHits());
1686 ATH_MSG_INFO("REGTEST TrigElectron nStrawHits" << eg->nTRTHiThresholdHits());
1687 ATH_MSG_INFO("REGTEST TrigElectron Check EMCluster");
1688 if(eg->emCluster()){
1689 ATH_MSG_INFO("REGTEST TrigElectron EMCluster retrieved");
1690 ATH_MSG_INFO("REGTEST TrigElectron emCluster->energy() returns " << eg->emCluster()->energy());
1691 ATH_MSG_INFO("REGTEST TrigElectron emCluster->phi() returns " << eg->emCluster()->phi());
1692 ATH_MSG_INFO("REGTEST TrigElectron emCluster->eta() returns " << eg->emCluster()->eta());
1693 ATH_MSG_INFO("REGTEST TrigElectron emCluster check Element Link");
1694 ATH_MSG_INFO("REGTEST TrigElectron emCluster energy = " << eg->emCluster()->energy());
1695 ATH_MSG_INFO("REGTEST TrigElectron ElementLink emCluster energy = " << (*eg->emClusterLink())->energy());
1696 }
1697 else ATH_MSG_INFO("REGTEST TrigElectron No EMCluster retrieved!");
1698 ATH_MSG_INFO("REGTEST TrigElectron Check TrackParticle");
1699 if(eg->trackParticle()){
1700 ATH_MSG_INFO("REGTEST TrigElectron TrackParticle retrieved");
1701 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->pt() returns " << eg->trackParticle()->pt());
1702 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->phi() returns " << eg->trackParticle()->phi());
1703 ATH_MSG_INFO("REGTEST TrigElectron trackParticle->eta() returns " << eg->trackParticle()->eta());
1704 ATH_MSG_INFO("REGTEST TrigElectron check TrackParticle Element Link");
1705 ATH_MSG_INFO("REGTEST TrigElectron TrackParticle pt = " << eg->trackParticle()->pt());
1706 ATH_MSG_INFO("REGTEST TrigElectron ElementLink TrackParticle pt = " << (*eg->trackParticleLink())->pt());
1707 }
1708 else ATH_MSG_INFO("REGTEST TrigElectron No TrackParticle retrieved!");
1709 }
1710 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigElectronContainer DUMP===========" );
1711
1712 return StatusCode::SUCCESS;
1713
1714}
1715
1718
1719 ATH_MSG_DEBUG("In dumpxAODTrigPhotonContainer");
1720
1721 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigPhotonContainer DUMP===========" );
1722
1723 const xAOD::TrigPhotonContainer* phCont=0;
1724 StatusCode sc = evtStore()->retrieve(phCont,"HLT_xAOD__TrigPhotonContainer_L2PhotonFex");
1725 if (sc.isFailure()) {
1726 ATH_MSG_INFO("REGTEST No TrigPhoton container HLT_xAOD__TrigPhotonContainer_L2PhotonFex");
1727 return StatusCode::SUCCESS;
1728 }
1729
1730 for (const auto eg : *phCont){
1731
1732 ATH_MSG_INFO("REGTEST TrigPhoton->Phi() returns " << eg->phi());
1733 ATH_MSG_INFO("REGTEST TrigPhoton->Eta() returns " << eg->eta());
1734 ATH_MSG_INFO("REGTEST TrigPhoton->dPhi() returns " << eg->dPhi());
1735 ATH_MSG_INFO("REGTEST TrigPhoton->dEta() returns " << eg->dEta());
1736 ATH_MSG_INFO("REGTEST TrigPhoton->rEta returns " << eg->rcore());
1737 ATH_MSG_INFO("REGTEST TrigPhoton->eratio() returns " << eg->eratio());
1738 ATH_MSG_INFO("REGTEST TrigPhoton->pt() returns " << eg->pt());
1739 ATH_MSG_INFO("REGTEST TrigPhoton->etHad() returns " << eg->etHad());
1740 ATH_MSG_INFO("REGTEST TrigPhoton->f1() returns " << eg->f1());
1741 ATH_MSG_INFO("REGTEST TrigPhoton Check EMCluster");
1742 if(eg->emCluster()){
1743 ATH_MSG_INFO("REGTEST TrigPhoton EMCluster retrieved");
1744 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->energy() returns " << eg->emCluster()->energy());
1745 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->phi() returns " << eg->emCluster()->phi());
1746 ATH_MSG_INFO("REGTEST TrigPhoton emCluster->eta() returns " << eg->emCluster()->eta());
1747 ATH_MSG_INFO("REGTEST TrigPhoton emCluster check Element Link");
1748 ATH_MSG_INFO("REGTEST TrigPhoton emCluster energy = " << eg->emCluster()->energy());
1749 ATH_MSG_INFO("REGTEST TrigPhoton ElementLink emCluster energy = " << (*eg->emClusterLink())->energy());
1750 }
1751 else ATH_MSG_INFO("REGTEST TrigPhoton No EMCluster retrieved!");
1752 }
1753 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigPhotonContainer DUMP===========" );
1754
1755 return StatusCode::SUCCESS;
1756
1757}
1758
1761
1762 ATH_MSG_DEBUG("In dumpxAODElectronContainer");
1763
1764 ATH_MSG_INFO( "REGTEST ==========START of xAOD::ElectronContainer DUMP===========" );
1765
1766 const xAOD::ElectronContainer* elCont=0;
1767 StatusCode sc = evtStore()->retrieve(elCont,"HLT_xAOD__ElectronContainer_egamma_Electrons");
1768 if (sc.isFailure()) {
1769 ATH_MSG_INFO("REGTEST No Electron container HLT_xAOD__ElectronContainer_egamma_Electrons");
1770 return StatusCode::SUCCESS;
1771 }
1772 float val_float=-99;
1773 unsigned int isEMbit=0;
1774 bool pid=false;
1775 //DEBUG output for Egamma container
1776 ATH_MSG_INFO(" REGTEST: xAOD Reconstruction variables: ");
1777 // //Cluster and ShowerShape info
1778 //
1779 static const SG::AuxElement::Accessor< float > accLH("LHValue");
1780 static const SG::AuxElement::Accessor< float > accLHCalo("LHCaloValue");
1781 for (const auto eg : *elCont){
1782 //REGTEST printout
1783 if (eg) {
1784 ATH_MSG_INFO(" REGTEST: egamma energy: " << eg->e() );
1785 ATH_MSG_INFO(" REGTEST: egamma eta: " << eg->eta() );
1786 ATH_MSG_INFO(" REGTEST: egamma phi: " << eg->phi() );
1787 if(eg->selectionisEM(isEMbit,"isEMVLoose"))
1788 ATH_MSG_INFO(" REGTEST: isEMVLoose " << std::hex << isEMbit << std::dec);
1789 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1790 if(eg->selectionisEM(isEMbit,"isEMLoose"))
1791 ATH_MSG_INFO(" REGTEST: isEMLoose " << std::hex << isEMbit << std::dec);
1792 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1793 if(eg->selectionisEM(isEMbit,"isEMMedium"))
1794 ATH_MSG_INFO(" REGTEST: isEMMedium " << std::hex << isEMbit << std::dec);
1795 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1796 if(eg->selectionisEM(isEMbit,"isEMTight"))
1797 ATH_MSG_INFO(" REGTEST: isEMTight " << std::hex << isEMbit << std::dec);
1798 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1799 if(eg->selectionisEM(isEMbit,"isEMLHVLoose"))
1800 ATH_MSG_INFO(" REGTEST: isEMLHVLoose " << std::hex << isEMbit << std::dec);
1801 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1802 if(eg->selectionisEM(isEMbit,"isEMLHLoose"))
1803 ATH_MSG_INFO(" REGTEST: isEMLHLoose " << std::hex << isEMbit << std::dec);
1804 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1805 if(eg->selectionisEM(isEMbit,"isEMLHMedium"))
1806 ATH_MSG_INFO(" REGTEST: isEMLHMedium " << std::hex << isEMbit << std::dec);
1807 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1808 if(eg->selectionisEM(isEMbit,"isEMLHTight"))
1809 ATH_MSG_INFO(" REGTEST: isEMLHTight " << std::hex << isEMbit << std::dec);
1810 else ATH_MSG_WARNING(" REGTEST: Missing Aux info");
1811 if(accLH.isAvailable(*eg))
1812 ATH_MSG_INFO(" REGTEST: LHValue " << accLH(*eg));
1813 else
1814 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1815 if(accLHCalo.isAvailable(*eg))
1816 ATH_MSG_INFO(" REGTEST: LHValue " << accLHCalo(*eg));
1817 else
1818 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1819 if(eg->passSelection(pid,"LHVLoose"))
1820 ATH_MSG_INFO(" REGTEST: LHVLoose " << pid);
1821 else
1822 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1823 if(eg->passSelection(pid,"LHLoose"))
1824 ATH_MSG_INFO(" REGTEST: LHLoose " << pid);
1825 else
1826 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1827 if(eg->passSelection(pid,"LHMedium"))
1828 ATH_MSG_INFO(" REGTEST: LHMedium " << pid);
1829 else
1830 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1831 if(eg->passSelection(pid,"LHTight"))
1832 ATH_MSG_INFO(" REGTEST: LHTight " << pid);
1833 else
1834 ATH_MSG_WARNING(" REGTEST: Missing Aux info ");
1835 } else{
1836 ATH_MSG_INFO(" REGTEST: problems with egamma pointer" );
1837 return StatusCode::SUCCESS;
1838 }
1839 ATH_MSG_INFO(" REGTEST: caloCluster variables ");
1840 if (eg->caloCluster()) {
1841 ATH_MSG_INFO(" REGTEST: egamma cluster transverse energy: " << eg->caloCluster()->et() );
1842 ATH_MSG_INFO(" REGTEST: egamma cluster eta: " << eg->caloCluster()->eta() );
1843 ATH_MSG_INFO(" REGTEST: egamma cluster phi: " << eg->caloCluster()->phi() );
1844 double tmpeta = -999.;
1845 double tmpphi = -999.;
1846 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::ETACALOFRAME,tmpeta);
1847 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::PHICALOFRAME,tmpphi);
1848 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1849 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1850 } else{
1851 ATH_MSG_INFO(" REGTEST: problems with egamma cluster pointer" );
1852 }
1853 ATH_MSG_INFO("REGTEST: Check the original (uncalibrated)");
1854 static const SG::AuxElement::Accessor<ElementLink<xAOD::CaloClusterContainer> > orig ("originalCaloCluster");
1855 if (!orig.isAvailable(*eg->caloCluster()) || !orig(*eg->caloCluster()).isValid()){
1856 ATH_MSG_INFO("Problem with original cluster link");
1857 }
1858 else {
1859 const xAOD::CaloCluster *origClus = *orig(*eg->caloCluster());
1860 ATH_MSG_INFO("REGTEST:: Compare new and old clusters");
1861 ATH_MSG_INFO("REGTEST:: Original Cluster e,eta,phi" << origClus->e() << " " << origClus->eta() << " " << origClus->phi());
1862 ATH_MSG_INFO("REGTEST:: MVA Cluster e,eta,phi" << eg->caloCluster()->e() << " " << eg->caloCluster()->eta() << " " << eg->caloCluster()->phi());
1863 }
1864 ATH_MSG_INFO(" REGTEST: trackmatch variables ");
1865 if(eg->trackParticle()){
1866 ATH_MSG_INFO(" REGTEST: pt= " << eg->trackParticle()->pt());
1867 ATH_MSG_INFO(" REGTEST: charge= " << eg->trackParticle()->charge());
1868 ATH_MSG_INFO(" REGTEST: E/p= " << eg->caloCluster()->et() / eg->trackParticle()->pt() );
1869 eg->trackCaloMatchValue(val_float,xAOD::EgammaParameters::deltaEta1);
1870 ATH_MSG_INFO(" REGTEST: Delta eta 1st sampling= " << val_float);
1871 eg->trackCaloMatchValue(val_float,xAOD::EgammaParameters::deltaPhi2);
1872 ATH_MSG_INFO(" REGTEST: Delta phi 2nd sampling= " << val_float);
1873 } else{
1874 ATH_MSG_INFO(" REGTEST: no electron eg->trackParticle() pointer");
1875 }
1876
1877 //msg() << MSG::VERBOSE << " REGTEST: cluster variables " << endmsg;
1878 //clus = eg->caloCluster();
1879 ATH_MSG_INFO(" REGTEST: EMShower variables ");
1880 eg->showerShapeValue(val_float,xAOD::EgammaParameters::ethad);
1881 ATH_MSG_INFO(" REGTEST: ethad = " << val_float);
1882 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e011);
1883 ATH_MSG_INFO(" REGTEST: e011 = " << val_float);
1884 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e132);
1885 ATH_MSG_INFO(" REGTEST: e132 = " << val_float);
1886 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e237);
1887 ATH_MSG_INFO(" REGTEST: e237 = " << val_float);
1888 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e335);
1889 ATH_MSG_INFO(" REGTEST: e335 = " << val_float);
1890 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2ts1);
1891 ATH_MSG_INFO(" REGTEST: e2ts1 = " << val_float);
1892 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2tsts1);
1893 ATH_MSG_INFO(" REGTEST: e2tsts1 = " << val_float);
1894 eg->isolationValue(val_float,xAOD::Iso::ptcone20);
1895 ATH_MSG_INFO(" REGTEST: ptcone20 = " << val_float);
1896 eg->isolationValue(val_float,xAOD::Iso::ptcone30);
1897 ATH_MSG_INFO(" REGTEST: ptcone30 = " << val_float);
1898 eg->isolationValue(val_float,xAOD::Iso::ptcone40);
1899 ATH_MSG_INFO(" REGTEST: ptcone40 = " << val_float);
1900 eg->isolationValue(val_float,xAOD::Iso::etcone20);
1901 ATH_MSG_INFO(" REGTEST: etcone20 = " << val_float);
1902 eg->isolationValue(val_float,xAOD::Iso::etcone30);
1903 ATH_MSG_INFO(" REGTEST: etcone30 = " << val_float);
1904 eg->isolationValue(val_float,xAOD::Iso::etcone40);
1905 ATH_MSG_INFO(" REGTEST: etcone40 = " << val_float);
1906 //DEBUG info for Electrons which by definition have a track match
1907
1908 }
1909 ATH_MSG_INFO( "REGTEST ==========END of xAOD::ElectronContainer DUMP===========" );
1910
1911 return StatusCode::SUCCESS;
1912
1913}
1914
1917
1918 ATH_MSG_DEBUG("In dumpxAODPhotonContainer");
1919
1920 ATH_MSG_INFO( "REGTEST ==========START of xAOD::PhotonContainer DUMP===========" );
1921
1922 const xAOD::PhotonContainer* phCont=0;
1923 StatusCode sc = evtStore()->retrieve(phCont,"HLT_xAOD__PhotonContainer_egamma_Photons");
1924 if (sc.isFailure()) {
1925 ATH_MSG_INFO("REGTEST No Photon container HLT_xAOD__PhotonContainer_egamma_Photons");
1926 return StatusCode::SUCCESS;
1927 }
1928
1929 float val_float=-99;
1930 unsigned int isEMbit=0;
1931 //DEBUG output for xAOD::PhotonContainer
1932 ATH_MSG_INFO(" REGTEST: xAOD Reconstruction variables: ");
1933 // //Cluster and ShowerShape info
1934 for (const auto eg : *phCont){
1935 //REGTEST printout
1936 if (eg) {
1937 ATH_MSG_INFO(" REGTEST: egamma energy: " << eg->e() );
1938 ATH_MSG_INFO(" REGTEST: egamma eta: " << eg->eta() );
1939 ATH_MSG_INFO(" REGTEST: egamma phi: " << eg->phi() );
1940 ATH_MSG_INFO(" REGTEST: isEMLoose " << eg->selectionisEM(isEMbit,"isEMLoose"));
1941 ATH_MSG_INFO(" REGTEST: isEMLoose bit " << std::hex << isEMbit << std::dec);
1942 ATH_MSG_INFO(" REGTEST: isEMMedium " << eg->selectionisEM(isEMbit,"isEMMedium"));
1943 ATH_MSG_INFO(" REGTEST: isEMMedium bit " << std::hex << isEMbit << std::dec);
1944 ATH_MSG_INFO(" REGTEST: isEMTight " << eg->selectionisEM(isEMbit,"isEMTight"));
1945 ATH_MSG_INFO(" REGTEST: isEMTight bit " << std::hex << isEMbit << std::dec);
1946 } else{
1947 ATH_MSG_INFO(" REGTEST: problems with egamma pointer" );
1948 return StatusCode::SUCCESS;
1949 }
1950 ATH_MSG_INFO(" REGTEST: caloCluster variables ");
1951 if (eg->caloCluster()) {
1952 ATH_MSG_INFO(" REGTEST: egamma cluster transverse energy: " << eg->caloCluster()->et() );
1953 ATH_MSG_INFO(" REGTEST: egamma cluster eta: " << eg->caloCluster()->eta() );
1954 ATH_MSG_INFO(" REGTEST: egamma cluster phi: " << eg->caloCluster()->phi() );
1955 double tmpeta = -999.;
1956 double tmpphi = -999.;
1957 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::ETACALOFRAME,tmpeta);
1958 eg->caloCluster()->retrieveMoment(xAOD::CaloCluster::PHICALOFRAME,tmpphi);
1959 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1960 ATH_MSG_INFO(" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1961 } else{
1962 ATH_MSG_INFO(" REGTEST: problems with egamma cluster pointer" );
1963 }
1964 ATH_MSG_INFO("REGTEST: Check the original (uncalibrated)");
1965 static const SG::AuxElement::Accessor<ElementLink<xAOD::CaloClusterContainer> > orig ("originalCaloCluster");
1966 if (!orig.isAvailable(*eg->caloCluster()) || !orig(*eg->caloCluster()).isValid()){
1967 ATH_MSG_INFO("Problem with original cluster link");
1968 }
1969 else {
1970 const xAOD::CaloCluster *origClus = *orig(*eg->caloCluster());
1971 ATH_MSG_INFO("REGTEST:: Compare new and old clusters");
1972 ATH_MSG_INFO("REGTEST:: Original Cluster e,eta,phi" << origClus->e() << " " << origClus->eta() << " " << origClus->phi());
1973 ATH_MSG_INFO("REGTEST:: MVA Cluster e,eta,phi" << eg->caloCluster()->e() << " " << eg->caloCluster()->eta() << " " << eg->caloCluster()->phi());
1974 }
1975 //msg() << MSG::VERBOSE << " REGTEST: cluster variables " << endmsg;
1976 //clus = eg->caloCluster();
1977 ATH_MSG_INFO(" REGTEST: EMShower variables ");
1978 eg->showerShapeValue(val_float,xAOD::EgammaParameters::ethad);
1979 ATH_MSG_INFO(" REGTEST: ethad = " << val_float);
1980 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e011);
1981 ATH_MSG_INFO(" REGTEST: e011 = " << val_float);
1982 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e132);
1983 ATH_MSG_INFO(" REGTEST: e132 = " << val_float);
1984 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e237);
1985 ATH_MSG_INFO(" REGTEST: e237 = " << val_float);
1986 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e335);
1987 ATH_MSG_INFO(" REGTEST: e335 = " << val_float);
1988 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2ts1);
1989 ATH_MSG_INFO(" REGTEST: e2ts1 = " << val_float);
1990 eg->showerShapeValue(val_float,xAOD::EgammaParameters::e2tsts1);
1991 ATH_MSG_INFO(" REGTEST: e2tsts1 = " << val_float);
1992 eg->isolationValue(val_float,xAOD::Iso::etcone20);
1993 ATH_MSG_INFO(" REGTEST: etcone20 = " << val_float);
1994 eg->isolationValue(val_float,xAOD::Iso::etcone30);
1995 ATH_MSG_INFO(" REGTEST: etcone30 = " << val_float);
1996 eg->isolationValue(val_float,xAOD::Iso::etcone40);
1997 ATH_MSG_INFO(" REGTEST: etcone40 = " << val_float);
1998 //DEBUG info for Electrons which by definition have a track match
1999
2000 }
2001 ATH_MSG_INFO( "REGTEST ==========END of xAOD::PhotonContainer DUMP===========" );
2002
2003 return StatusCode::SUCCESS;
2004
2005}
2006
2007
2008StatusCode TrigEDMChecker::dumpTrigTauContainer ATLAS_NOT_THREAD_SAFE() {
2009
2010 ATH_MSG_DEBUG("in dumpTrigTauContainer()");
2011 ATH_MSG_INFO("REGTEST ==========START of TrigTauContainer DUMP===========");
2012
2015
2016 StatusCode sc = evtStore()->retrieve(trigTau,lastTrigTau);
2017 if (sc.isFailure()) {
2018 ATH_MSG_INFO("REGTEST No TrigTauContainer found");
2019 return StatusCode::SUCCESS;
2020 }
2021 ATH_MSG_INFO("REGTEST TrigTauContainer retrieved");
2022
2023 for (int i=0; trigTau != lastTrigTau; ++trigTau, ++i) {
2024
2025 ATH_MSG_INFO("REGTEST Looking at TrigTauContainer " << i);
2026
2027 TrigTauContainer::const_iterator TrigTauItr = trigTau->begin();
2028 TrigTauContainer::const_iterator TrigTauItrE = trigTau->end();
2029
2030 for (int j=0; TrigTauItr != TrigTauItrE; ++TrigTauItr, ++j ) {
2031
2032 ATH_MSG_INFO("REGTEST Looking at TrigTau " << j);
2033
2034 ATH_MSG_INFO("REGTEST TrigTau->pt() returns " << (*TrigTauItr)->pt());
2035 ATH_MSG_INFO("REGTEST TrigTau->eta() returns " << (*TrigTauItr)->eta());
2036 ATH_MSG_INFO("REGTEST TrigTau->phi() returns " << (*TrigTauItr)->phi());
2037
2038 ATH_MSG_INFO("REGTEST TrigTau->nMatchedTracks() returns " << (*TrigTauItr)->nMatchedTracks());
2039 ATH_MSG_INFO("REGTEST TrigTau->simpleEtFlow() returns " << (*TrigTauItr)->simpleEtFlow());
2040 ATH_MSG_INFO("REGTEST TrigTau->m() returns " << (*TrigTauItr)->m());
2041 }
2042 }
2043
2044 ATH_MSG_INFO("REGTEST ==========END of TrigTau DUMP===========");
2045 ATH_MSG_DEBUG("dumpTrigTauContainer() succeeded");
2046
2047 return StatusCode::SUCCESS;
2048}
2049
2051StatusCode TrigEDMChecker::dumpTrigTauTracksInfo ATLAS_NOT_THREAD_SAFE() {
2052
2053 ATH_MSG_DEBUG("in dumpTrigTauTracksInfo()");
2054 ATH_MSG_INFO("REGTEST ==========START of TrigTauTracksInfo DUMP===========");
2055
2058
2059 StatusCode sc = evtStore()->retrieve(trigTau,lastTrigTau);
2060 if (sc.isFailure()) {
2061 ATH_MSG_INFO("REGTEST No TrigTauTracksInfo found");
2062 return StatusCode::SUCCESS;
2063 }
2064 ATH_MSG_INFO("REGTEST TrigTauTracksInfos retrieved");
2065
2066 for (int i=0; trigTau != lastTrigTau; ++trigTau, ++i) {
2067
2068 const TrigTauTracksInfo* thisTrigTau = &(*trigTau);
2069
2070 ATH_MSG_INFO("REGTEST Looking at TrigTauTracksInfo " << i);
2071
2072 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->pt() returns " << thisTrigTau->pt());
2073 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->eta() returns " << thisTrigTau->eta());
2074 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->phi() returns " << thisTrigTau->phi());
2075
2076 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->nCoreTracks() returns " << thisTrigTau->nCoreTracks());
2077 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->nSlowTracks() returns " << thisTrigTau->nSlowTracks());
2078 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->nIsoTracks() returns " << thisTrigTau->nIsoTracks());
2079
2080 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->charge() returns " << thisTrigTau->charge());
2081 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->leadingTrackPt() returns " <<
2082 thisTrigTau->leadingTrackPt());
2083 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->scalarPtSumCore() returns " <<
2084 thisTrigTau->scalarPtSumCore());
2085 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->scalarPtSumIso() returns " <<
2086 thisTrigTau->scalarPtSumIso());
2087 ATH_MSG_INFO("REGTEST TrigTauTracksInfo->threeFastestTracks().pt() returns " <<
2088 thisTrigTau->threeFastestTracks().pt());
2089 }
2090
2091 ATH_MSG_INFO("REGTEST ==========END of TrigTauTracksInfo DUMP===========");
2092 ATH_MSG_DEBUG("dumpTrigTauTracksInfo() succeeded");
2093
2094 return StatusCode::SUCCESS;
2095}
2096
2098
2100
2101 ATH_MSG_DEBUG("in dumpHLTResult()");
2102
2103 ATH_MSG_INFO("REGTEST ==========START of HLTResult DUMP===========");
2104
2105 const HLT::HLTResult* hltResult = 0;
2106 StatusCode sc=evtStore()->retrieve( hltResult, "HLTResult_L2");
2107 if( sc.isFailure() || !hltResult ) {
2108 ATH_MSG_INFO("No HLTResult_L2 found in TDS");
2109 return StatusCode::SUCCESS;
2110 }
2111 ATH_MSG_INFO("REGTEST HLTResult_L2 Successfully Retrieved");
2112
2113 ATH_MSG_INFO("REGTEST HLTResult_L2->isEmpty() returns " << hltResult->isEmpty());
2114 ATH_MSG_INFO("REGTEST HLTResult_L2->size() returns " << hltResult->size());
2115 ATH_MSG_INFO("REGTEST HLTResult_L2->isPassThrough() returns " << hltResult->isPassThrough());
2116 ATH_MSG_INFO("REGTEST HLTResult_L2->isAccepted() returns " << hltResult->isAccepted());
2117
2118 ATH_MSG_INFO("REGTEST ==========END of HLTResult DUMP===========");
2119
2120 ATH_MSG_DEBUG("dumpHLTResult() succeeded");
2121
2122 return StatusCode::SUCCESS;
2123}
2124
2125
2126
2127
2129
2131
2132 std::string TrigInDetTrackTags[]={ "HLT_TrigIDSCAN_Jet",
2133 "HLT_TrigIDSCAN_Tau",
2134 "HLT_TrigIDSCAN_eGamma",
2135 "HLT_TrigIDSCAN_Muon",
2136 "HLT_TrigIDSCAN_muonIso",
2137 "HLT_TrigIDSCAN_Bphysics",
2138 "HLT_TrigIDSCAN_FullScan",
2139 "HLT_TrigIDSCAN_Cosmics",
2140 "HLT_TrigIDSCAN_eGamma_Brem",
2141 "HLT_TrigIDSCAN_Tile",
2142 "HLT_TrigSiTrack_eGamma",
2143 "HLT_TrigSiTrack_Muon",
2144 "HLT_TrigSiTrack_muonIso",
2145 "HLT_TrigSiTrack_Tau",
2146 "HLT_TrigSiTrack_Jet",
2147 "HLT_TrigSiTrack_Bphysics",
2148 "HLT_TrigSiTrack_FullScan",
2149 "HLT_TrigSiTrack_Cosmics",
2150 "HLT_TRTSegmentFinder",
2151 "HLT_TRTxK"};
2152 int ntag=20;
2153
2154 ATH_MSG_DEBUG("in dumpTrigInDetTrackCollection()");
2155
2156 const TrigInDetTrackTruthMap* pTruthMap(nullptr);
2157 bool gotTruthMap = false;
2158
2159 if (evtStore()->contains<TrigInDetTrackTruthMap>("TrigInDetTrackTruthMap")) {
2160 StatusCode sc=evtStore()->retrieve(pTruthMap,"TrigInDetTrackTruthMap");
2161 if (sc.isFailure())
2162 {
2163 ATH_MSG_WARNING(" could not retrieve TrackTruthMap with key TrigInDetTruthMap");
2164 } else {
2165 gotTruthMap=true;
2166 // pTruthMap->print();
2167 }
2168 }
2169 else ATH_MSG_DEBUG(" didn't find any TrackTruthMap objects with key TrigInDetTruthMap");
2170
2171 ATH_MSG_INFO("REGTEST ==========START of TrigInDetTrackCollection DUMP===========");
2172
2173 for (int iTag=0; iTag < ntag; iTag++) {
2174 const TrigInDetTrackCollection* trigInDetTrackCollection = nullptr;
2175 StatusCode sc = evtStore()->retrieve(trigInDetTrackCollection,TrigInDetTrackTags[iTag] );
2176 if (sc.isFailure()) {
2177 ATH_MSG_DEBUG("REGTEST No TrigInDetTrackCollection found with key " << TrigInDetTrackTags[iTag]);
2178 continue;
2179 }
2180 ATH_MSG_INFO("REGTEST TrigInDetTrackCollections retrieved with key "
2181 << TrigInDetTrackTags[iTag]);
2182
2183 ATH_MSG_INFO("REGTEST TrigInDetTrackCollection->size() returns " << trigInDetTrackCollection->size());
2184
2185 TrigInDetTrackCollection::const_iterator trkItr = trigInDetTrackCollection->begin();
2186 TrigInDetTrackCollection::const_iterator trkItrE = trigInDetTrackCollection->end();
2187
2188 for (int j=0; trkItr != trkItrE; ++trkItr, ++j ) {
2189
2190 ATH_MSG_INFO("REGTEST Looking at TrigInDetTrack " << j);
2191
2192 ATH_MSG_INFO("REGTEST TrigInDetTrack->algorithmId() returns " << (*trkItr)->algorithmId());
2193 ATH_MSG_INFO("REGTEST TrigInDetTrack->chi2() returns " << (*trkItr)->chi2());
2194 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStrawHits() returns " << (*trkItr)->NStrawHits());
2195
2196 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStraw() returns " << (*trkItr)->NStraw());
2197 ATH_MSG_INFO("REGTEST TrigInDetTrack->NStrawTime() returns " << (*trkItr)->NStrawTime());
2198 ATH_MSG_INFO("REGTEST TrigInDetTrack->NTRHits() returns " << (*trkItr)->NTRHits());
2199
2200 ATH_MSG_INFO("REGTEST Looking at TrigInDetFitTrack->param()");
2201 const TrigInDetTrackFitPar* my_param = (*trkItr)->param();
2202
2203 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->a0() returns " << my_param->a0());
2204 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->z0() returns " << my_param->z0());
2205 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->phi0() returns " << my_param->phi0());
2206 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->eta() returns " << my_param->eta());
2207 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->pT() returns " << my_param->pT());
2208 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ea0() returns " << my_param->ea0());
2209 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ez0() returns " << my_param->ez0());
2210 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->ephi0() returns " << my_param->ephi0());
2211 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->eeta() returns " << my_param->eeta());
2212 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->epT() returns " << my_param->epT());
2213 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->surfaceType() returns " << my_param->surfaceType());
2214 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->surfaceCoordinate() returns " << my_param->surfaceCoordinate());
2215 ATH_MSG_INFO("REGTEST Looking at covarience matrix: ");
2216
2217 const std::vector<double>* const my_cov = my_param->cov();
2218 if (!my_cov) {
2219 ATH_MSG_INFO("REGTEST covarience matrix NULL (not stored)");
2220 } else {
2221 std::vector<double> tempcov = *my_cov;
2222 std::vector<double>::iterator iter;
2223 int k;
2224 for(iter = tempcov.begin(), k=0; iter != tempcov.end(); ++iter, ++k){
2225 ATH_MSG_INFO("REGTEST TrigInDetTrackFitPar->cov() element " << k << " is " << (*iter));
2226 }
2227 }
2228 if (gotTruthMap) {
2229 if (!(pTruthMap->hasTruth((*trkItr)))) {
2230 ATH_MSG_DEBUG(" REGTEST Track has no truth info ");
2231 } else {
2232 ATH_MSG_DEBUG(" Track has truth info: ");
2233 const TrigInDetTrackTruth* pTRTtruth = pTruthMap->truth((*trkItr));
2234 int nMatches = pTRTtruth->nrMatches() ;
2235 if (nMatches==0) {
2236 ATH_MSG_INFO(" REGTEST Track has no truth matches");
2237 } else {
2238 ATH_MSG_INFO("REGTEST number of matched truth hits: Si: " << pTruthMap->bestMatchSiHits((*trkItr))
2239 << " TRT: " << pTruthMap->bestMatchTRTHits((*trkItr)));
2240 if (pTruthMap->bestMatchSiHits((*trkItr)) > 0) {
2241
2242 const HepMcParticleLink* pSiTruth = pTruthMap->bestMatchSi((*trkItr));
2243
2244 ATH_MSG_INFO("REGTEST Si match to kine ref " << pSiTruth->barcode());
2245 if (pSiTruth->cptr() != 0) {
2246 ATH_MSG_INFO("REGTEST Si PDG id " << pSiTruth->cptr()->pdg_id());
2247 }
2248 }
2249
2250 if (pTruthMap->bestMatchTRTHits((*trkItr)) > 0) {
2251 const HepMcParticleLink* pTRTtruth = pTruthMap->bestMatchTRT((*trkItr));
2252
2253 ATH_MSG_INFO("REGTEST TRT match to kine ref " << pTRTtruth->barcode());
2254 if (pTRTtruth->cptr() != 0) {
2255 ATH_MSG_INFO("REGTEST TRT PDG id " << pTRTtruth->cptr()->pdg_id());
2256 }
2257 }
2258 }
2259 }
2260 } // if (gotTruthMap)
2261 }
2262 }
2263
2264 ATH_MSG_INFO("REGTEST ==========END of TrigInDetTrackCollection DUMP===========");
2265 ATH_MSG_DEBUG("dumpTrigInDetTrackCollection() succeeded");
2266
2267 return StatusCode::SUCCESS;
2268}
2269
2270
2272
2273StatusCode TrigEDMChecker::dumpTrigVertexCollection ATLAS_NOT_THREAD_SAFE() {
2274
2275 ATH_MSG_DEBUG("in dumpTrigVertexCollection()");
2276 ATH_MSG_INFO("REGTEST ==========START of TrigVertexCollection DUMP===========");
2277
2280
2281 StatusCode sc = evtStore()->retrieve(trigVertex,lastTrigVertex);
2282 if (sc.isFailure()) {
2283 ATH_MSG_INFO("REGTEST No TrigVertexCollection found");
2284 return StatusCode::SUCCESS;
2285 }
2286 ATH_MSG_INFO("REGTEST TrigVertexCollection retrieved");
2287
2288
2289 for (int i=0; trigVertex != lastTrigVertex; ++trigVertex, ++i) {
2290
2291 ATH_MSG_INFO("REGTEST Looking at TrigVertexCollection " << i);
2292
2293 TrigVertexCollection::const_iterator VertexItr = trigVertex->begin();
2294 TrigVertexCollection::const_iterator VertexItrE = trigVertex->end();
2295
2296 for (int j=0; VertexItr != VertexItrE; ++VertexItr, ++j ) {
2297
2298 ATH_MSG_INFO("REGTEST Looking at TrigVertex " << j);
2299
2300 ATH_MSG_INFO("REGTEST TrigVertex->x() returns " << (*VertexItr)->x());
2301 ATH_MSG_INFO("REGTEST TrigVertex->y() returns " << (*VertexItr)->y());
2302 ATH_MSG_INFO("REGTEST TrigVertex->z() returns " << (*VertexItr)->z());
2303 ATH_MSG_INFO("REGTEST TrigVertex->energyFraction() returns " << (*VertexItr)->energyFraction());
2304 ATH_MSG_INFO("REGTEST TrigVertex->ndof() returns " << (*VertexItr)->ndof());
2305
2306 if(((*VertexItr)->tracks())!=NULL ){
2307 // mLog <<MSG::INFO << "REGTEST *** ((*VertexItr)->tracks())!=NULL *** " << endmsg;
2308 TrackInVertexList::const_iterator trkItr = (*VertexItr)->tracks()->begin();
2309 TrackInVertexList::const_iterator trkItrE = (*VertexItr)->tracks()->end();
2310
2311 for (int p=0; trkItr != trkItrE; ++trkItr, ++p ) {
2312
2313 ATH_MSG_INFO("REGTEST Looking at track " << p);
2314
2315 ATH_MSG_INFO("REGTEST Tracks info: ");
2316 ATH_MSG_INFO("REGTEST tracks->NStrawHits() returns " << (*trkItr)->NStrawHits());
2317 ATH_MSG_INFO("REGTEST tracks->NStrawTime() returns " << (*trkItr)->NStrawTime());
2318 ATH_MSG_INFO("REGTEST tracks->NTRHits() returns " << (*trkItr)->NTRHits());
2319 }
2320 }
2321 }
2322 }
2323
2324 ATH_MSG_INFO("REGTEST ==========END of TrigVertexCollection DUMP===========");
2325 ATH_MSG_DEBUG("dumpTrigVertexCollection() succeeded");
2326
2327 return StatusCode::SUCCESS;
2328}
2329
2330
2332
2333
2335
2336 ATH_MSG_DEBUG("in dumpTrigEFBphysContainer()");
2337
2338 ATH_MSG_INFO("REGTEST ==========START of TrigEFBphysContainer DUMP===========");
2339
2340 std::string EFBphysTags[]={"HLT_xAOD__TrigBphysContainer_EFBMuMuFex",
2341 "HLT_xAOD__TrigBphysContainer_EFBMuMuXFex",
2342 "HLT_xAOD__TrigBphysContainer_EFDsPhiPiFex",
2343 "HLT_xAOD__TrigBphysContainer_EFMuPairs",
2344 "HLT_xAOD__TrigBphysContainer_EFMultiMuFex",
2345 "HLT_xAOD__TrigBphysContainer_EFTrackMass"
2346 };
2347
2348 int ntag= (int) sizeof(EFBphysTags) / sizeof(EFBphysTags[0]);
2349
2350
2351 for (int itag=0; itag<ntag; itag++){
2352 const xAOD::TrigBphysContainer* trigEFBphys;
2353 StatusCode sc = evtStore()->retrieve(trigEFBphys, EFBphysTags[itag]);
2354 if (sc.isFailure()) {
2355 ATH_MSG_INFO("REGTEST No TrigEFBphysContainer found with tag " << EFBphysTags[itag]);
2356 continue;
2357 }
2358
2359 ATH_MSG_INFO("REGTEST TrigEFBphysContainer found with tag " << EFBphysTags[itag]
2360 << " and size " << trigEFBphys->size());
2361
2362 // for (int i=0; trigEFBphys != lastTrigEFBphys; ++trigEFBphys, ++i) {
2363
2364 //mLog << MSG::INFO << "REGTEST Looking at TrigEFBphysContainer " << i << endmsg;
2365
2366 xAOD::TrigBphysContainer::const_iterator EFBphysItr = trigEFBphys->begin();
2367 xAOD::TrigBphysContainer::const_iterator EFBphysItrE = trigEFBphys->end();
2368
2369 for (int j=0; EFBphysItr != EFBphysItrE; ++EFBphysItr, ++j ) {
2370
2371 ATH_MSG_INFO("REGTEST Looking at TrigEFBphys " << j);
2372
2373 ATH_MSG_INFO("REGTEST TrigEFBphys->eta() returns " << (*EFBphysItr)->eta());
2374 ATH_MSG_INFO("REGTEST TrigEFBphys->phi() returns " << (*EFBphysItr)->phi());
2375 ATH_MSG_INFO("REGTEST TrigEFBphys->mass() returns " << (*EFBphysItr)->mass());
2376 ATH_MSG_INFO("REGTEST TrigEFBphys->fitmass() returns " << (*EFBphysItr)->fitmass());
2377 // ATH_MSG_INFO("REGTEST TrigEFBphys->isValid() returns " << (*EFBphysItr)->isValid());
2378 ATH_MSG_INFO("REGTEST TrigEFBphys->roiId() returns " << (*EFBphysItr)->roiId());
2379 ATH_MSG_INFO("REGTEST TrigEFBphys->particleType() returns " << (*EFBphysItr)->particleType());
2380
2381 if( (*EFBphysItr)->secondaryDecay() != NULL){
2382 const xAOD::TrigBphys * psecond =(*EFBphysItr)->secondaryDecay();
2383 ATH_MSG_INFO("REGTEST Secondary decay info: ");
2384 ATH_MSG_INFO("REGTEST pSecondDecay->eta() returns " << psecond->eta());
2385 ATH_MSG_INFO("REGTEST pSecondDecay->phi() returns " << psecond->phi());
2386 ATH_MSG_INFO("REGTEST pSecondDecay->mass() returns " << psecond->mass());
2387 ATH_MSG_INFO("REGTEST pSecondDecay->fitmass() returns " << psecond->fitmass());
2388 // ATH_MSG_INFO("REGTEST pSecondDecay->isValid() returns " << (*EFBphysItr)->secondaryDecayLink()->isValid());
2389 ATH_MSG_INFO("REGTEST pSecondDecay->roiId() returns " << psecond->roiId());
2390 ATH_MSG_INFO("REGTEST pSecondDecay->particleType() returns " << psecond->particleType());
2391
2392 } // end if secondary exists
2393
2394
2395
2396 const std::vector<ElementLink<xAOD::TrackParticleContainer> > trackVector = (*EFBphysItr)->trackParticleLinks();
2397 if (trackVector.size() != 0) {
2398 ATH_MSG_INFO(" REGTEST got track vector size: " << trackVector.size());
2399 } else {
2400 ATH_MSG_INFO(" REGTEST no track vector!!! " );
2401 }
2402 std::vector<ElementLink<xAOD::TrackParticleContainer> >::const_iterator trkIt=trackVector.begin();
2403 for (int itrk=0 ; trkIt!= trackVector.end(); ++itrk, ++trkIt) {
2404 if (!(trkIt->isValid())) {
2405 ATH_MSG_WARNING("TrackParticleContainer::Invalid ElementLink to track ");
2406 continue;
2407 }
2408 //const Trk::Perigee* trackPerigee=(*(*trkIt))->measuredPerigee();
2409 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2410
2411 // msg() << MSG::VERBOSE << "track, iterator, pointer " << itrk << " " << *trkIt << " " << *(*trkIt) << endmsg;
2412 double phi = trackPerigee->parameters()[Trk::phi];
2413 double theta = trackPerigee->parameters()[Trk::theta];
2414 double px = trackPerigee->momentum()[Trk::px];
2415 double py = trackPerigee->momentum()[Trk::py];
2416 double pt = sqrt(px*px + py*py);
2417 double eta = -std::log(tan(theta/2));
2418
2419 ATH_MSG_INFO("track " << itrk << " pt phi eta " << pt << " " <<
2420 phi << " " << eta);
2421 }
2422
2423 }
2424 }
2425 ATH_MSG_INFO("REGTEST ==========END of TrigEFBphysContainer DUMP===========");
2426 ATH_MSG_DEBUG("dumpTrigEFBphysContainer() succeeded");
2427
2428 return StatusCode::SUCCESS;
2429}
2430
2433
2434 ATH_MSG_DEBUG("in dumpTrigL2BphysContainer()");
2435 ATH_MSG_INFO("REGTEST ==========START of TrigL2BphysContainer DUMP===========");
2436
2437 std::string L2BphysTags[]={"HLT_xAOD__TrigBphysContainer_L2BMuMuFex",
2438 "HLT_xAOD__TrigBphysContainer_L2BMuMuXFex",
2439 "HLT_xAOD__TrigBphysContainer_L2DsPhiPiFexDs",
2440 "HLT_xAOD__TrigBphysContainer_L2DsPhiPiFexPhi",
2441 "HLT_xAOD__TrigBphysContainer_L2JpsieeFex",
2442 "HLT_xAOD__TrigBphysContainer_L2MultiMuFex",
2443 "HLT_xAOD__TrigBphysContainer_L2TrackMass",
2444 };
2445 const int ntag = (int) sizeof(L2BphysTags) / sizeof(L2BphysTags[0]);
2446
2447
2448 for (int itag=0; itag<ntag; itag++){
2449 const xAOD::TrigBphysContainer* trigL2Bphys;
2450 StatusCode sc = evtStore()->retrieve(trigL2Bphys, L2BphysTags[itag]);
2451 if (sc.isFailure()) {
2452 ATH_MSG_INFO("REGTEST No TrigL2BphysContainer found with tag " << L2BphysTags[itag]);
2453 continue;
2454 }
2455
2456 ATH_MSG_INFO("REGTEST TrigL2BphysContainer found with tag " << L2BphysTags[itag]
2457 << " and size " << trigL2Bphys->size());
2458
2459 // for (int i=0; trigL2Bphys != lastTrigL2Bphys; ++trigL2Bphys, ++i) {
2460
2461 // mLog << MSG::INFO << "REGTEST Looking at TrigL2BphysContainer " << i << endmsg;
2462
2463 xAOD::TrigBphysContainer::const_iterator L2BphysItr = trigL2Bphys->begin();
2464 xAOD::TrigBphysContainer::const_iterator L2BphysItrE = trigL2Bphys->end();
2465
2466 for (int j=0; L2BphysItr != L2BphysItrE; ++L2BphysItr, ++j ) {
2467
2468 ATH_MSG_INFO("REGTEST Looking at TrigL2Bphys " << j);
2469
2470 ATH_MSG_INFO("REGTEST TrigL2Bphys->eta() returns " << (*L2BphysItr)->eta());
2471 ATH_MSG_INFO("REGTEST TrigL2Bphys->phi() returns " << (*L2BphysItr)->phi());
2472 ATH_MSG_INFO("REGTEST TrigL2Bphys->mass() returns " << (*L2BphysItr)->mass());
2473 ATH_MSG_INFO("REGTEST TrigL2Bphys->fitmass() returns " << (*L2BphysItr)->fitmass());
2474 // ATH_MSG_INFO("REGTEST TrigL2Bphys->isValid() returns " << (*L2BphysItr)->isValid());
2475 ATH_MSG_INFO("REGTEST TrigL2Bphys->roiId() returns " << (*L2BphysItr)->roiId());
2476 ATH_MSG_INFO("REGTEST TrigL2Bphys->particleType() returns " << (*L2BphysItr)->particleType());
2477
2478 if( (*L2BphysItr)->secondaryDecay() != NULL){
2479 const xAOD::TrigBphys * psecond =(*L2BphysItr)->secondaryDecay();
2480 ATH_MSG_INFO("REGTEST Secondary decay info: ");
2481 ATH_MSG_INFO("REGTEST pSecondDecay->eta() returns " << psecond->eta());
2482 ATH_MSG_INFO("REGTEST pSecondDecay->phi() returns " << psecond->phi());
2483 ATH_MSG_INFO("REGTEST pSecondDecay->mass() returns " << psecond->mass());
2484 ATH_MSG_INFO("REGTEST pSecondDecay->fitmass() returns " << psecond->fitmass());
2485 // ATH_MSG_INFO("REGTEST pSecondDecay->isValid() returns " << (*L2BphysItr)->secondaryDecayLink()->isValid());
2486 ATH_MSG_INFO("REGTEST pSecondDecay->roiId() returns " << psecond->roiId());
2487 ATH_MSG_INFO("REGTEST pSecondDecay->particleType() returns " << psecond->particleType());
2488 } // end if secondary exists
2489
2490 const std::vector<ElementLink<xAOD::TrackParticleContainer> > trackVector = (*L2BphysItr)->trackParticleLinks();
2491 if (trackVector.size() != 0) {
2492 ATH_MSG_INFO(" REGTEST got track vector size: " << trackVector.size());
2493 } else {
2494 ATH_MSG_INFO(" REGTEST no track vector!!! " );
2495 }
2496 std::vector<ElementLink<xAOD::TrackParticleContainer> >::const_iterator trkIt=trackVector.begin();
2497 for (int itrk=0 ; trkIt!= trackVector.end(); ++itrk, ++trkIt) {
2498 if (!(trkIt->isValid())) {
2499 ATH_MSG_WARNING("TrackParticleContainer::Invalid ElementLink to track ");
2500 continue;
2501 }
2502 //const Trk::Perigee* trackPerigee=(*(*trkIt))->measuredPerigee();
2503 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2504
2505 // msg() << MSG::VERBOSE << "track, iterator, pointer " << itrk << " " << *trkIt << " " << *(*trkIt) << endmsg;
2506 double phi = trackPerigee->parameters()[Trk::phi];
2507 double theta = trackPerigee->parameters()[Trk::theta];
2508 double px = trackPerigee->momentum()[Trk::px];
2509 double py = trackPerigee->momentum()[Trk::py];
2510 double pt = sqrt(px*px + py*py);
2511 double eta = -std::log(tan(theta/2));
2512
2513 ATH_MSG_INFO("track " << itrk << " pt phi eta " << pt << " " <<
2514 phi << " " << eta);
2515 }
2516 }
2517 }
2518
2519 ATH_MSG_INFO("REGTEST ==========END of TrigL2BphysContainer DUMP===========");
2520 ATH_MSG_DEBUG("dumpTrigL2BphysContainer() succeeded");
2521
2522 return StatusCode::SUCCESS;
2523}
2524
2525
2526
2528
2530
2531 ATH_MSG_DEBUG("in dumpxAODJetContainer()");
2532
2533 ATH_MSG_INFO("REGTEST ==========START of xAOD::JetContainer DUMP===========");
2534
2535 std::string containerName[30] = {"HLT_xAOD__JetContainer_a4tcemjesFS",
2536 "HLT_xAOD__JetContainer_a4tcemsubFS",
2537 "HLT_xAOD__JetContainer_a4tcemsubjesFS",
2538 "HLT_xAOD__JetContainer_a4tcemnojcalibFS",
2539 "HLT_xAOD__JetContainer_a4tcemjesPS",
2540 "HLT_xAOD__JetContainer_a4tcemnojcalibPS",
2541 "HLT_xAOD__JetContainer_a4tclcwjesFS",
2542 "HLT_xAOD__JetContainer_a4tclcwsubFS",
2543 "HLT_xAOD__JetContainer_a4tclcwsubjesFS",
2544 "HLT_xAOD__JetContainer_a4tclcwnojcalibFS",
2545 "HLT_xAOD__JetContainer_a4tclcwjesPS",
2546 "HLT_xAOD__JetContainer_a4tclcwnojcalibPS",
2547 "HLT_xAOD__JetContainer_a4TTemnojcalibFS",
2548 "HLT_xAOD__JetContainer_a4TThadnojcalibFS",
2549 "HLT_xAOD__JetContainer_a10tcemjesFS",
2550 "HLT_xAOD__JetContainer_a10tcemsubFS",
2551 "HLT_xAOD__JetContainer_a10tcemsubjesFS",
2552 "HLT_xAOD__JetContainer_a10tcemnojcalibFS",
2553 "HLT_xAOD__JetContainer_a10tcemjesPS",
2554 "HLT_xAOD__JetContainer_a10tcemnojcalibPS",
2555 "HLT_xAOD__JetContainer_a10tclcwjesFS",
2556 "HLT_xAOD__JetContainer_a10tclcwsubFS",
2557 "HLT_xAOD__JetContainer_a10tclcwsubjesFS",
2558 "HLT_xAOD__JetContainer_a10tclcwnojcalibFS",
2559 "HLT_xAOD__JetContainer_a10tclcwjesPS",
2560 "HLT_xAOD__JetContainer_a10tclcwnojcalibPS",
2561 "HLT_xAOD__JetContainer_a10TTemnojcalibFS",
2562 "HLT_xAOD__JetContainer_a10TThadnojcalibFS",
2563 "HLT_xAOD__JetContainer_a10r_tcemsubjesFS",
2564 "HLT_xAOD__JetContainer_TrigHLTJetDSSelectorCollection"};
2565 float containerSizeParameter[30] = {0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4, 0.4,
2566 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.4};
2567 int containerInputType[30] = {1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 2, 2,
2568 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 2, 2, 1, 1};
2569 int containerSignalState[30] = {0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1,
2570 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1, 0, 1, 0, 0};
2571 bool onefilled = false;
2572
2573 for (int icont=0; icont<30; ++icont) {
2574 //retrieve jet collection
2575 const xAOD::JetContainer* jetCont = 0;
2576 StatusCode sc = evtStore()->retrieve(jetCont, containerName[icont]) ;
2577
2578 if (sc.isFailure()) {
2579 ATH_MSG_WARNING("REGTEST Cannot retrieve jet container");
2580 continue;
2581 }
2582
2583 int jetContsize = jetCont->size();
2584 ATH_MSG_INFO("REGTEST Got jet container " << containerName[icont] << ", size: " << jetContsize);
2585 if (jetContsize != 0) {
2586 onefilled = true;
2587 int i = 0;
2588 for(const auto thisjet : *jetCont) {
2589 ++i;
2590 ATH_MSG_INFO( "REGTEST Looking at jet " << i);
2591 if (thisjet) {
2592 //checks jet variables
2593 ATH_MSG_DEBUG("REGTEST Checking jet variables");
2594 ATH_MSG_INFO( "REGTEST pt: " << thisjet->pt() );
2595 ATH_MSG_INFO( "REGTEST eta: " << thisjet->eta() );
2596 ATH_MSG_INFO( "REGTEST phi: " << thisjet->phi() );
2597 ATH_MSG_INFO( "REGTEST m: " << thisjet->m() );
2598 ATH_MSG_INFO( "REGTEST e: " << thisjet->e() );
2599 ATH_MSG_INFO( "REGTEST rapidity: " << thisjet->rapidity() );
2600 ATH_MSG_INFO( "REGTEST px: " << thisjet->px() );
2601 ATH_MSG_INFO( "REGTEST py: " << thisjet->py() );
2602 ATH_MSG_INFO( "REGTEST pz: " << thisjet->pz() );
2603 ATH_MSG_INFO( "REGTEST type: " << thisjet->type() );
2604 ATH_MSG_INFO( "REGTEST algorithm (kt: 0, cam: 1, antikt: 2, ...): " << thisjet->getAlgorithmType() << "; should be 2");
2605 if(thisjet->getAlgorithmType() != 2) ATH_MSG_WARNING("Jet algorithm different from container");
2606 ATH_MSG_INFO( "REGTEST size parameter: " << thisjet->getSizeParameter() << "; should be " << containerSizeParameter[icont]);
2607 if(thisjet->getSizeParameter() != containerSizeParameter[icont]) ATH_MSG_WARNING("Jet size different from container");
2608 ATH_MSG_INFO( "REGTEST input (LCTopo: 0, EMTopo: 1, TopoTower: 2, ...): " << thisjet->getInputType() << "; should be " << containerInputType[icont]);
2609 if(thisjet->getInputType() != containerInputType[icont]) ATH_MSG_WARNING("Jet input different from container");
2610 ATH_MSG_INFO( "REGTEST constituents signal state (uncalibrated: 0, calibrated: 1): " << thisjet->getConstituentsSignalState() << "; should be " << containerSignalState[icont]);
2611 if(thisjet->getConstituentsSignalState() != containerSignalState[icont]) ATH_MSG_WARNING("Jet constituents' signal state different from container");
2612 ATH_MSG_INFO( "REGTEST number of constituents: " << thisjet->numConstituents() );
2613
2614
2615 //checks the constituents
2616 ATH_MSG_DEBUG("REGTEST Checking jet constituents");
2617
2618 xAOD::JetConstituentVector constitCont = thisjet->getConstituents();
2619 unsigned int constitContsize = constitCont.size();
2620 ATH_MSG_INFO("REGTEST Got constituent vector, size: " << constitContsize << "; should be " << thisjet->numConstituents());
2621 if(constitContsize != thisjet->numConstituents()) ATH_MSG_WARNING("Constituents container size different from number of constituents");
2622
2623 if (constitContsize != 0) {
2624// int j = 0;
2625 // for (const auto thisconstit : constitCont) {
2626 // ++j;
2627 // ATH_MSG_INFO( "REGTEST Looking at constituent " << j);
2628 // if(thisconstit){
2629 // ATH_MSG_INFO( "REGTEST constituent pt: " << thisconstit->pt() );
2630 // ATH_MSG_INFO( "REGTEST constituent eta: " << thisconstit->eta() );
2631 // ATH_MSG_INFO( "REGTEST constituent phi: " << thisconstit->phi() );
2632 // ATH_MSG_INFO( "REGTEST constituent m: " << thisconstit->m() );
2633 // ATH_MSG_INFO( "REGTEST constituent e: " << thisconstit->e() );
2634 // ATH_MSG_INFO( "REGTEST constituent type (CaloCluster: 1, Jet: 2, ...): " << thisconstit->type() );
2635 // }
2636 // else{
2637 // ATH_MSG_WARNING("REGTEST Problem with constituent pointer");
2638 // return StatusCode::SUCCESS;
2639 // }
2640 // }
2641 // ATH_MSG_INFO("REGTEST size of constituent vector == number of displayed constituents: "<< (constitContsize == j) );
2642 // if (constitContsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2643 }
2644 // else ATH_MSG_WARNING("REGTEST This jet has 0 constituents!");
2645
2646 //checks int attributes
2647 ATH_MSG_DEBUG("REGTEST Checking int attributes");
2648 int valueint;
2649 if( thisjet->getAttribute(xAOD::JetAttribute::GhostMuonSegmentCount, valueint)) ATH_MSG_INFO("REGTEST GhostMuonSegmentCount: " << valueint);
2650 if( thisjet->getAttribute(xAOD::JetAttribute::GhostTrackCount, valueint)) ATH_MSG_INFO("REGTEST GhostTrackCount: " << valueint);
2651 if( thisjet->getAttribute(xAOD::JetAttribute::GhostTruthParticleCount, valueint)) ATH_MSG_INFO("REGTEST GhostTruthParticleCount: " << valueint);
2652 if( thisjet->getAttribute(xAOD::JetAttribute::FracSamplingMaxIndex, valueint)) ATH_MSG_INFO( "REGTEST FracSamplingMaxIndex: " << valueint);
2653
2654
2655 //checks float attributes
2656 ATH_MSG_DEBUG("REGTEST Checking float attributes");
2657 float value;
2658 if( thisjet->getAttribute(xAOD::JetAttribute::ActiveArea, value)) ATH_MSG_INFO( "REGTEST ActiveArea: " << value );
2659 // Four-vector type if( thisjet->getAttribute(xAOD::JetAttribute::ActiveArea4vec, value)) ATH_MSG_INFO( "REGTEST ActiveArea4vec: " << value );
2660 if( thisjet->getAttribute(xAOD::JetAttribute::AverageLArQF, value)) ATH_MSG_INFO( "REGTEST AverageLArQF: " << value );
2661 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrCell, value)) ATH_MSG_INFO( "REGTEST BchCorrCell: " << value );
2662 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrDotx, value)) ATH_MSG_INFO( "REGTEST BchCorrDotx: " << value );
2663 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrJet, value)) ATH_MSG_INFO( "REGTEST BchCorrJet: " << value );
2664 if( thisjet->getAttribute(xAOD::JetAttribute::BchCorrJetForCell, value)) ATH_MSG_INFO( "REGTEST BchCorrJetForCell: " << value );
2665 if( thisjet->getAttribute(xAOD::JetAttribute::CentroidR, value)) ATH_MSG_INFO( "REGTEST CentroidR: " << value );
2666 if( thisjet->getAttribute(xAOD::JetAttribute::HECQuality, value)) ATH_MSG_INFO( "REGTEST HECQuality: " << value );
2667 if( thisjet->getAttribute(xAOD::JetAttribute::IsoKR20Par, value)) ATH_MSG_INFO( "REGTEST IsoKR20Par: " << value );
2668 if( thisjet->getAttribute(xAOD::JetAttribute::IsoKR20Perp, value)) ATH_MSG_INFO( "REGTEST IsoKR20Perp: " << value );
2669 // ElementLink<DataVector<xAOD::Vertex> > type if( thisjet->getAttribute(xAOD::JetAttribute::HighestJVFVtx, value)) ATH_MSG_INFO( "REGTEST HighestJVFVtx: " << value );
2670 // ??? type if( thisjet->getAttribute(xAOD::JetAttribute::JetLabel, value)) ATH_MSG_INFO( "REGTEST JetLabel: " << value );
2671 if( thisjet->getAttribute(xAOD::JetAttribute::KtDR, value)) ATH_MSG_INFO( "REGTEST KtDR: " << value );
2672 if( thisjet->getAttribute(xAOD::JetAttribute::LArBadHVEnergy, value)) ATH_MSG_INFO( "REGTEST LArBadHVEnergy: " << value );
2673 if( thisjet->getAttribute(xAOD::JetAttribute::LArBadHVRatio, value)) ATH_MSG_INFO( "REGTEST LArBadHVRatio: " << value );
2674 if( thisjet->getAttribute(xAOD::JetAttribute::LArQuality, value)) ATH_MSG_INFO( "REGTEST LArQuality: " << value );
2675 if( thisjet->getAttribute(xAOD::JetAttribute::NegativeE, value)) ATH_MSG_INFO( "REGTEST NegativeE: " << value );
2676 // no tools available yet if( thisjet->getAttribute(xAOD::JetAttribute::NumTowers, value)) ATH_MSG_INFO( "REGTEST NumTowers: " << value );
2677 if( thisjet->getAttribute(xAOD::JetAttribute::SamplingMax, value)) ATH_MSG_INFO( "REGTEST SamplingMax: " << value );
2678 if( thisjet->getAttribute(xAOD::JetAttribute::Timing, value)) ATH_MSG_INFO( "REGTEST Timing: " << value );
2679 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiArea, value)) ATH_MSG_INFO( "REGTEST VoronoiArea: " << value );
2680 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaE, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaE: " << value );
2681 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPx, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPx: " << value );
2682 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPy, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPy: " << value );
2683 if( thisjet->getAttribute(xAOD::JetAttribute::VoronoiAreaPz, value)) ATH_MSG_INFO( "REGTEST VoronoiAreaPz: " << value );
2684 if( thisjet->getAttribute(xAOD::JetAttribute::Width, value)) ATH_MSG_INFO( "REGTEST WIDTH: " << value );
2685 if( thisjet->getAttribute(xAOD::JetAttribute::FracSamplingMax, value)) ATH_MSG_INFO( "REGTEST FracSamplingMax: " << value );
2686 if( thisjet->getAttribute(xAOD::JetAttribute::EMFrac, value)) ATH_MSG_INFO( "REGTEST EMFrac: " << value );
2687 if( thisjet->getAttribute(xAOD::JetAttribute::HECFrac, value)) ATH_MSG_INFO( "REGTEST HECFrac: " << value );
2688 if( thisjet->getAttribute(xAOD::JetAttribute::isBadLoose, value)) ATH_MSG_INFO( "REGTEST isBadLoose: " << value );
2689 if( thisjet->getAttribute(xAOD::JetAttribute::isBadMedium, value)) ATH_MSG_INFO( "REGTEST isBadMedium: " << value );
2690 if( thisjet->getAttribute(xAOD::JetAttribute::isBadTight, value)) ATH_MSG_INFO( "REGTEST isBadTight: " << value );
2691 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::isUgly, value)) ATH_MSG_INFO( "REGTEST isUgly: " << value );
2692 if( thisjet->getAttribute(xAOD::JetAttribute::N90Constituents, value)) ATH_MSG_INFO( "REGTEST N90Constituents: " << value );
2693 if( thisjet->getAttribute(xAOD::JetAttribute::N90Cells, value)) ATH_MSG_INFO( "REGTEST N90Cells: " << value );
2694 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracClusters10, value)) ATH_MSG_INFO( "REGTEST OotFracClusters10: " << value );
2695 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracClusters5, value)) ATH_MSG_INFO( "REGTEST OotFracClusters5: " << value );
2696 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracCells5, value)) ATH_MSG_INFO( "REGTEST OotFracCells5: " << value );
2697 if( thisjet->getAttribute(xAOD::JetAttribute::OotFracCells10, value)) ATH_MSG_INFO( "REGTEST OotFracCells10: " << value );
2698 if( thisjet->getAttribute(xAOD::JetAttribute::PtTruth, value)) ATH_MSG_INFO( "REGTEST PtTruth: " << value );
2699 if( thisjet->getAttribute(xAOD::JetAttribute::Tau1, value)) ATH_MSG_INFO( "REGTEST Tau1: " << value );
2700 if( thisjet->getAttribute(xAOD::JetAttribute::Tau2, value)) ATH_MSG_INFO( "REGTEST Tau2: " << value );
2701 if( thisjet->getAttribute(xAOD::JetAttribute::Tau3, value)) ATH_MSG_INFO( "REGTEST Tau3: " << value );
2702 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split12, value)) ATH_MSG_INFO( "REGTEST Split12: " << value );
2703 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split23, value)) ATH_MSG_INFO( "REGTEST Split23: " << value );
2704 // unknown attribute if( thisjet->getAttribute(xAOD::JetAttribute::Split34, value)) ATH_MSG_INFO( "REGTEST Split34: " << value );
2705 if( thisjet->getAttribute(xAOD::JetAttribute::Dip12, value)) ATH_MSG_INFO( "REGTEST Dip12: " << value );
2706 if( thisjet->getAttribute(xAOD::JetAttribute::Dip13, value)) ATH_MSG_INFO( "REGTEST Dip13: " << value );
2707 if( thisjet->getAttribute(xAOD::JetAttribute::Dip23, value)) ATH_MSG_INFO( "REGTEST Dip23: " << value );
2708 if( thisjet->getAttribute(xAOD::JetAttribute::DipExcl12, value)) ATH_MSG_INFO( "REGTEST DipExcl12: " << value );
2709 if( thisjet->getAttribute(xAOD::JetAttribute::ThrustMin, value)) ATH_MSG_INFO( "REGTEST ThrustMin: " << value );
2710 if( thisjet->getAttribute(xAOD::JetAttribute::ThrustMaj, value)) ATH_MSG_INFO( "REGTEST ThrustMaj: " << value );
2711 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram0, value)) ATH_MSG_INFO( "REGTEST FoxWolfram0: " << value );
2712 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram1, value)) ATH_MSG_INFO( "REGTEST FoxWolfram1: " << value );
2713 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram2, value)) ATH_MSG_INFO( "REGTEST FoxWolfram2: " << value );
2714 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram3, value)) ATH_MSG_INFO( "REGTEST FoxWolfram3: " << value );
2715 if( thisjet->getAttribute(xAOD::JetAttribute::FoxWolfram4, value)) ATH_MSG_INFO( "REGTEST FoxWolfram4: " << value );
2716 if( thisjet->getAttribute(xAOD::JetAttribute::Sphericity, value)) ATH_MSG_INFO( "REGTEST Sphericity: " << value );
2717 if( thisjet->getAttribute(xAOD::JetAttribute::Aplanarity, value)) ATH_MSG_INFO( "REGTEST Aplanarity: " << value );
2718
2719 //checks vector<int> attributes
2720 ATH_MSG_DEBUG("REGTEST Checking vector<int> attributes");
2721 std::vector<int> vecvalueint;
2722 if (thisjet->getAttribute(xAOD::JetAttribute::NumTrkPt1000, vecvalueint)) {
2723 int vecsize = vecvalueint.size();
2724 ATH_MSG_INFO("REGTEST Got NumTrkPt1000 vector, size: " << vecsize);
2725 if (vecsize != 0) {
2726 int j = 0;
2727 for(const auto & thisvalue : vecvalueint){
2728 ++j;
2729 ATH_MSG_INFO("REGTEST NumTrkPt1000 #" << j << ": " << thisvalue);
2730 }
2731 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2732 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2733 }
2734 }
2735 if (thisjet->getAttribute(xAOD::JetAttribute::NumTrkPt500, vecvalueint)) {
2736 int vecsize = vecvalueint.size();
2737 ATH_MSG_INFO("REGTEST Got Got NumTrkPt500 vector, size: " << vecsize);
2738 if (vecsize != 0) {
2739 int j = 0;
2740 for(const auto & thisvalue : vecvalueint){
2741 ++j;
2742 ATH_MSG_INFO("REGTEST NumTrkPt500 #" << j << ": " << thisvalue);
2743 }
2744 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2745 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2746 }
2747 }
2748
2749 //checks vector<float> attributes
2750 ATH_MSG_DEBUG("REGTEST Checking vector<float> attributes");
2751 std::vector<float> vecvalue;
2752 if (thisjet->getAttribute(xAOD::JetAttribute::JVF, vecvalue)) {
2753 int vecsize = vecvalue.size();
2754 ATH_MSG_INFO("REGTEST Got JVF vector, size: " << vecsize);
2755 if (vecsize != 0) {
2756 int j = 0;
2757 for(const auto & thisvalue : vecvalue){
2758 ++j;
2759 ATH_MSG_INFO("REGTEST JVF #" << j << ": " << thisvalue);
2760 }
2761 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2762 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2763 }
2764 }
2765 if (thisjet->getAttribute(xAOD::JetAttribute::SumPtTrkPt1000, vecvalue)) {
2766 int vecsize = vecvalue.size();
2767 ATH_MSG_INFO("REGTEST Got SumPtTrkPt1000 vector, size: " << vecsize);
2768 if (vecsize != 0) {
2769 int j = 0;
2770 for(const auto & thisvalue : vecvalue){
2771 ++j;
2772 ATH_MSG_INFO("REGTEST SumPtTrkPt1000 #" << j << ": " << thisvalue);
2773 }
2774 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2775 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2776 }
2777 }
2778 if (thisjet->getAttribute(xAOD::JetAttribute::SumPtTrkPt500, vecvalue)) {
2779 int vecsize = vecvalue.size();
2780 ATH_MSG_INFO("REGTEST Got SumPtTrkPt500 vector, size: " << vecsize);
2781 if (vecsize != 0) {
2782 int j = 0;
2783 for(const auto & thisvalue : vecvalue){
2784 ++j;
2785 ATH_MSG_INFO("REGTEST SumPtTrkPt500 #" << j << ": " << thisvalue);
2786 }
2787 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2788 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2789 }
2790 }
2791 if (thisjet->getAttribute(xAOD::JetAttribute::TrackWidthPt1000, vecvalue)) {
2792 int vecsize = vecvalue.size();
2793 ATH_MSG_INFO("REGTEST Got TrackWidthPt1000 vector, size: " << vecsize);
2794 if (vecsize != 0) {
2795 int j = 0;
2796 for(const auto & thisvalue : vecvalue){
2797 ++j;
2798 ATH_MSG_INFO("REGTEST TrackWidthPt1000 #" << j << ": " << thisvalue);
2799 }
2800 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2801 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2802 }
2803 }
2804 if (thisjet->getAttribute(xAOD::JetAttribute::TrackWidthPt500, vecvalue)) {
2805 int vecsize = vecvalue.size();
2806 ATH_MSG_INFO("REGTEST Got TrackWidthPt500 vector, size: " << vecsize);
2807 if (vecsize != 0) {
2808 int j = 0;
2809 for(const auto & thisvalue : vecvalue){
2810 ++j;
2811 ATH_MSG_INFO("REGTEST TrackWidthPt500 #" << j << ": " << thisvalue);
2812 }
2813 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2814 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2815 }
2816 }
2817 if (thisjet->getAttribute(xAOD::JetAttribute::EnergyPerSampling, vecvalue)) {
2818 int vecsize = vecvalue.size();
2819 ATH_MSG_INFO("REGTEST Got EnergyPerSampling vector, size: " << vecsize);
2820 if (vecsize != 0) {
2821 int j = 0;
2822 for(const auto & thisvalue : vecvalue){
2823 ++j;
2824 ATH_MSG_INFO("REGTEST EnergyPerSampling #" << j << ": " << thisvalue);
2825 }
2826 ATH_MSG_INFO("REGTEST size of attribute vector == number of displayed attributes: " << (vecsize == j) );
2827 if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this attribute");
2828 }
2829 }
2830
2831
2832 //checks associated objects
2833 // ATH_MSG_DEBUG("REGTEST Checking associated objects");
2834 // std::vector<const xAOD::TrackParticle*> track;
2835 // if( thisjet->getAssociatedObjects(xAOD::JetAttribute::GhostTrack, track) ){
2836 // int vecsize = track.size();
2837 // ATH_MSG_INFO("REGTEST Got GhostTrack vector, size: " << vecsize);
2838 // if (vecsize != 0) {
2839 // int j = 0;
2840 // for(const auto & thistrack : track){
2841 // ++j;
2842 // //checks only one associated variable, just making sure getting the object worked
2843 // if (thistrack) ATH_MSG_INFO("REGTEST z0 for GhostTrack #" << j << ": " << thistrack->z0());
2844 // else{
2845 // ATH_MSG_WARNING("REGTEST Problem with attribute pointer");
2846 // return StatusCode::SUCCESS;
2847 // }
2848 // }
2849 // ATH_MSG_INFO("REGTEST size of associated object vector == number of displayed attributes: " << (vecsize == j) );
2850 // if (vecsize != j) ATH_MSG_WARNING("REGTEST Problem with displaying this associated object");
2851 // }
2852 // }
2853 }
2854 else{
2855 ATH_MSG_WARNING("REGTEST Problem with jet pointer");
2856 return StatusCode::SUCCESS;
2857 }
2858 }
2859
2860 if (jetContsize == i) ATH_MSG_INFO("REGTEST size of jet container == number of displayed jets: " << (jetContsize == i) );
2861 else ATH_MSG_WARNING("REGTEST Problem with displaying jets");
2862 }
2863 }
2864
2865 if (!onefilled) ATH_MSG_DEBUG("There was no filled jet containers");
2866
2867 ATH_MSG_INFO("REGTEST ==========END of xAOD::JetContainer DUMP===========");
2868
2869 ATH_MSG_DEBUG("leaving dumpxAODJetContainer()");
2870
2871 return StatusCode::SUCCESS;
2872}
2873
2874
2876
2877StatusCode TrigEDMChecker::dumpTrigEFBjetContainer ATLAS_NOT_THREAD_SAFE() {
2878
2879 ATH_MSG_DEBUG("in dumpTrigEFBjetContainer()");
2880 ATH_MSG_INFO("REGTEST ==========START of TrigEFBjetContainer DUMP===========");
2881
2884
2885 StatusCode sc = evtStore()->retrieve(trigEFBjet,lastTrigEFBjet);
2886 if (sc.isFailure()) {
2887 ATH_MSG_INFO("REGTEST No TrigEFBjetContainer found");
2888 return StatusCode::SUCCESS;
2889 }
2890 ATH_MSG_INFO("REGTEST TrigEFBjetContainers retrieved");
2891
2892
2893 for (int i=0; trigEFBjet != lastTrigEFBjet; ++trigEFBjet, ++i) {
2894
2895 ATH_MSG_INFO("REGTEST Looking at TrigEFBjetContainer " << i);
2896
2897 TrigEFBjetContainer::const_iterator EFBjetItr = trigEFBjet->begin();
2898 TrigEFBjetContainer::const_iterator EFBjetItrE = trigEFBjet->end();
2899
2900 for (int j=0; EFBjetItr != EFBjetItrE; ++EFBjetItr, ++j ) {
2901
2902 ATH_MSG_INFO("REGTEST Looking at TrigEFBjet " << j);
2903
2904 ATH_MSG_INFO("REGTEST TrigEFBjet->prmVtx() returns " << (*EFBjetItr)->prmVtx());
2905 ATH_MSG_INFO("REGTEST TrigEFBjet->xComb() returns " << (*EFBjetItr)->xComb());
2906 // mLog <<MSG::INFO << "REGTEST TrigEFBjet->x2D() returns " << (*EFBjetItr)->x2D() << endmsg;
2907 ATH_MSG_INFO("REGTEST TrigEFBjet->xIP1D() returns " << (*EFBjetItr)->xIP1D());
2908 ATH_MSG_INFO("REGTEST TrigEFBjet->isValid() returns " << (*EFBjetItr)->isValid());
2909 ATH_MSG_INFO("REGTEST TrigEFBjet->roiId() returns " << (*EFBjetItr)->roiId());
2910 // mLog <<MSG::INFO << "REGTEST TrigEFBjet->xD0() returns " << (*EFBjetItr)->xD0() << endmsg;
2911 ATH_MSG_INFO("REGTEST TrigEFBjet->xIP2D() returns " << (*EFBjetItr)->xIP2D());
2912 // mLog <<MSG::INFO << "REGTEST TrigEFBjet->xZ0() returns " << (*EFBjetItr)->xZ0() << endmsg;
2913 ATH_MSG_INFO("REGTEST TrigEFBjet->xIP3D() returns " << (*EFBjetItr)->xIP3D());
2914 // new one:
2915 ATH_MSG_INFO("REGTEST TrigEFBjet->xCHI2() returns " << (*EFBjetItr)->xCHI2());
2916 // mLog <<MSG::INFO << "REGTEST TrigEFBjet->x3D() returns " << (*EFBjetItr)->x3D() << endmsg; // replaced by :
2917 ATH_MSG_INFO("REGTEST TrigEFBjet->xSV() returns " << (*EFBjetItr)->xSV());
2918 //
2919 ATH_MSG_INFO("REGTEST TrigEFBjet->xMVtx() returns " << (*EFBjetItr)->xMVtx());
2920 ATH_MSG_INFO("REGTEST TrigEFBjet->xEVtx() returns " << (*EFBjetItr)->xEVtx());
2921 ATH_MSG_INFO("REGTEST TrigEFBjet-> xNVtx() returns " << (*EFBjetItr)-> xNVtx());
2922 }
2923 }
2924 ATH_MSG_INFO("REGTEST ==========END of TrigEFBjetContainer DUMP===========");
2925 ATH_MSG_DEBUG("dumpTrigEFBjetContainer() succeeded");
2926
2927 return StatusCode::SUCCESS;
2928}
2929
2930
2932
2933StatusCode TrigEDMChecker::dumpTrigL2BjetContainer ATLAS_NOT_THREAD_SAFE() {
2934
2935 ATH_MSG_DEBUG("in dumpTrigL2BjetContainer()");
2936 ATH_MSG_INFO("REGTEST ==========START of TrigL2BjetContainer DUMP===========");
2937
2940
2941 StatusCode sc = evtStore()->retrieve(trigL2Bjet,lastTrigL2Bjet);
2942 if (sc.isFailure()) {
2943 ATH_MSG_INFO("REGTEST No TrigL2BjetContainer found");
2944 return StatusCode::SUCCESS;
2945 }
2946 ATH_MSG_INFO("REGTEST TrigL2BjetContainers retrieved");
2947
2948
2949 for (int i=0; trigL2Bjet != lastTrigL2Bjet; ++trigL2Bjet, ++i) {
2950
2951 ATH_MSG_INFO("REGTEST Looking at TrigL2BjetContainer " << i);
2952
2953 TrigL2BjetContainer::const_iterator L2BjetItr = trigL2Bjet->begin();
2954 TrigL2BjetContainer::const_iterator L2BjetItrE = trigL2Bjet->end();
2955
2956 for (int j=0; L2BjetItr != L2BjetItrE; ++L2BjetItr, ++j ) {
2957
2958 ATH_MSG_INFO("REGTEST Looking at TrigL2Bjet " << j);
2959 ATH_MSG_INFO("REGTEST TrigL2Bjet->prmVtx() returns " << (*L2BjetItr)->prmVtx());
2960 ATH_MSG_INFO("REGTEST TrigL2Bjet->xComb() returns " << (*L2BjetItr)->xComb());
2961 // ATH_MSG_INFO("REGTEST TrigL2Bjet->x2D() returns " << (*L2BjetItr)->x2D());
2962 ATH_MSG_INFO("REGTEST TrigL2Bjet->xIP1D() returns " << (*L2BjetItr)->xIP1D());
2963 ATH_MSG_INFO("REGTEST TrigL2Bjet->isValid() returns " << (*L2BjetItr)->isValid());
2964 ATH_MSG_INFO("REGTEST TrigL2Bjet->roiId() returns " << (*L2BjetItr)->roiId());
2965 // ATH_MSG_INFO("REGTEST TrigL2Bjet->xD0() returns " << (*L2BjetItr)->xD0());
2966 ATH_MSG_INFO("REGTEST TrigL2Bjet->xIP2D() returns " << (*L2BjetItr)->xIP2D());
2967 // ATH_MSG_INFO("REGTEST TrigL2Bjet->xZ0() returns " << (*L2BjetItr)->xZ0());
2968 ATH_MSG_INFO("REGTEST TrigL2Bjet->xIP3D() returns " << (*L2BjetItr)->xIP3D());
2969 // new one:
2970 ATH_MSG_INFO("REGTEST TrigL2Bjet->xCHI2() returns " << (*L2BjetItr)->xCHI2());
2971 // ATH_MSG_INFO("REGTEST TrigL2Bjet->x3D() returns " << (*L2BjetItr)->x3D());
2972 ATH_MSG_INFO("REGTEST TrigL2Bjet->xSV() returns " << (*L2BjetItr)->xSV());
2973 ATH_MSG_INFO("REGTEST TrigL2Bjet->xMVtx() returns " << (*L2BjetItr)->xMVtx());
2974 ATH_MSG_INFO("REGTEST TrigL2Bjet->xEVtx() returns " << (*L2BjetItr)->xEVtx());
2975 ATH_MSG_INFO("REGTEST TrigL2Bjet-> xNVtx() returns " << (*L2BjetItr)-> xNVtx());
2976 }
2977 }
2978 ATH_MSG_INFO("REGTEST ==========END of TrigL2BjetContainer DUMP===========");
2979 ATH_MSG_DEBUG("dumpTrigL2BjetContainer() succeeded");
2980
2981 return StatusCode::SUCCESS;
2982}
2983
2985
2986StatusCode TrigEDMChecker::dumpMuonFeature ATLAS_NOT_THREAD_SAFE() {
2987
2988 ATH_MSG_DEBUG("in dumpMuonFeature()");
2989
2990 ATH_MSG_INFO("REGTEST ==========START of MuonFeature DUMP===========");
2991
2994
2995 StatusCode sc = evtStore()->retrieve(MuFeature,lastMuFeature);
2996 if (sc.isFailure()) {
2997 ATH_MSG_INFO("REGTEST No MuonFeature found");
2998 return StatusCode::SUCCESS;
2999 }
3000 ATH_MSG_INFO("REGTEST MuonFeature retrieved");
3001
3002
3003 for (int i=0; MuFeature != lastMuFeature; ++MuFeature, ++i) {
3004
3005 const MuonFeature* thisMuFeature = &(*MuFeature);
3006
3007 ATH_MSG_INFO("REGTEST Looking at MuonFeature " << i);
3008 ATH_MSG_INFO("REGTEST MuonFeature->roiId() returns " << thisMuFeature->roiId());
3009 ATH_MSG_INFO("REGTEST MuonFeature->eta() returns " << thisMuFeature->eta());
3010 ATH_MSG_INFO("REGTEST MuonFeature->phi() returns " << thisMuFeature->phi());
3011 ATH_MSG_INFO("REGTEST MuonFeature->saddress() returns " << thisMuFeature->saddress());
3012 ATH_MSG_INFO("REGTEST MuonFeature->pt() returns " << thisMuFeature->pt());
3013 ATH_MSG_INFO("REGTEST MuonFeature->radius() returns " << thisMuFeature->radius());
3014 ATH_MSG_INFO("REGTEST MuonFeature->dir_phi() returns " << thisMuFeature->dir_phi());
3015 ATH_MSG_INFO("REGTEST MuonFeature->zeta() returns " << thisMuFeature->zeta());
3016 ATH_MSG_INFO("REGTEST MuonFeature->dir_zeta() returns " << thisMuFeature->dir_zeta());
3017 ATH_MSG_INFO("REGTEST MuonFeature->beta() returns " << thisMuFeature->beta());
3018 }
3019
3020 ATH_MSG_INFO("REGTEST ==========END of MuonFeature DUMP===========");
3021 ATH_MSG_DEBUG("dumpMuonFeature() succeeded");
3022
3023 return StatusCode::SUCCESS;
3024}
3025
3027
3028StatusCode TrigEDMChecker::dumpCombinedMuonFeature ATLAS_NOT_THREAD_SAFE() {
3029
3030 ATH_MSG_DEBUG("in dumpCombinedMuonFeature()");
3031
3032 ATH_MSG_INFO("REGTEST ==========START of CombinedMuonFeature DUMP===========");
3033
3036
3037 StatusCode sc = evtStore()->retrieve(CombMuon,lastCombMuon);
3038 if (sc.isFailure()) {
3039 ATH_MSG_INFO("REGTEST No CombinedMuonFeature found");
3040 return StatusCode::SUCCESS;
3041 }
3042 ATH_MSG_INFO("REGTEST CombinedMuonFeatures retrieved");
3043
3044 for (int i=0; CombMuon != lastCombMuon; ++CombMuon, ++i) {
3045
3046 const CombinedMuonFeature* thisCombMuFeature = &(*CombMuon);
3047
3048 ATH_MSG_INFO("REGTEST Looking at CombinedMuonFeature " << i);
3049 ATH_MSG_INFO("REGTEST TrigPhoton->pt() returns " << (thisCombMuFeature)->pt());
3050 ATH_MSG_INFO("REGTEST TrigPhoton->sigma_pt() returns " << (thisCombMuFeature)->sigma_pt());
3051 ATH_MSG_INFO("REGTEST MuonFeature info: ");
3052 // if ((thisCombMuFeature)->muFastTrack()) {
3053 if ((thisCombMuFeature)->muFastTrackLink().isValid() ) {
3054 ATH_MSG_INFO("REGTEST muFastTrack->eta() returns " << (thisCombMuFeature)->muFastTrack()->eta());
3055 ATH_MSG_INFO("REGTEST muFastTrack->phi() returns " << (thisCombMuFeature)->muFastTrack()->phi());
3056 ATH_MSG_INFO("REGTEST muFastTrack->radius() returns " << (thisCombMuFeature)->muFastTrack()->radius());
3057 ATH_MSG_INFO("REGTEST muFastTrack->zeta() returns " << (thisCombMuFeature)->muFastTrack()->zeta());
3058 } else {
3059 ATH_MSG_INFO("CombinedMuonFeature has no muFastTrack" );
3060 }
3061
3062 ATH_MSG_INFO("REGTEST TrigInDetTrack info: ");
3063 // if ((thisCombMuFeature)->IDTrack()) {
3064 if ((thisCombMuFeature)->IDTrackLink().isValid() ) {
3065 ATH_MSG_INFO("REGTEST IDTrack->algorithmId() returns " <<(thisCombMuFeature)->IDTrack()->algorithmId());
3066 ATH_MSG_INFO("REGTEST IDTrack->chi2() returns " << (thisCombMuFeature)->IDTrack()->chi2());
3067 ATH_MSG_INFO("REGTEST IDTrack->NStrawHits() returns " <<(thisCombMuFeature)->IDTrack()->NStrawHits());
3068 ATH_MSG_INFO("REGTEST IDTrack->NStraw() returns " << (thisCombMuFeature)->IDTrack()->NStraw());
3069 ATH_MSG_INFO("REGTEST IDTrack->NStrawTime() returns " <<(thisCombMuFeature)->IDTrack()->NStrawTime());
3070 ATH_MSG_INFO("REGTEST IDTrack->NTRHits() returns " <<(thisCombMuFeature)->IDTrack()->NTRHits());
3071 } else {
3072 ATH_MSG_INFO("CombinedMuonFeature has no IDTrack" );
3073 }
3074
3075 }
3076
3077 ATH_MSG_INFO("REGTEST ==========END of CombinedMuonFeature DUMP===========");
3078 ATH_MSG_DEBUG("dumpCombinedMuonFeature() succeeded");
3079
3080 return StatusCode::SUCCESS;
3081}
3082
3083StatusCode TrigEDMChecker::dumpCombinedMuonFeatureContainer ATLAS_NOT_THREAD_SAFE() {
3084
3085 ATH_MSG_DEBUG("in dumpCombinedMuonFeatureContainer()");
3086 ATH_MSG_INFO("REGTEST ==========START of CombinedMuonFeatureContainer DUMP===========");
3087
3090
3091 StatusCode sc = evtStore()->retrieve(CombMuon,lastCombMuon);
3092 if (sc.isFailure()) {
3093 ATH_MSG_INFO("REGTEST No CombinedMuonFeatureContainer found");
3094 return StatusCode::SUCCESS;
3095 }
3096 ATH_MSG_INFO("REGTEST CombinedMuonFeaturesContainer retrieved");
3097
3098 for (int j=0; CombMuon != lastCombMuon; ++CombMuon, ++j) {
3099 ATH_MSG_INFO("REGTEST Looking at CombinedMuonFeatureContainer " << j);
3100
3101 const CombinedMuonFeatureContainer* container = &(*CombMuon);
3103
3104 int i = 0;
3105 for ( muon = container->begin() ; muon != container->end(); ++i, ++muon ) {
3106 const CombinedMuonFeature* thisCombMuFeature = *muon;
3107 ATH_MSG_INFO("REGTEST Looking at CombinedMuonFeature " << i);
3108
3109 ATH_MSG_INFO("REGTEST CombinedMuonFeature->pt() returns " << (thisCombMuFeature)->pt());
3110 ATH_MSG_INFO("REGTEST CombinedMuonFeature->sigma_pt() returns " << (thisCombMuFeature)->sigma_pt());
3111
3112 ATH_MSG_INFO("REGTEST MuonFeature info: ");
3113 if ( thisCombMuFeature->muFastTrackLink().isValid() ) {
3114 ATH_MSG_INFO("REGTEST muFastTrack->eta() returns " << (thisCombMuFeature)->muFastTrack()->eta());
3115 ATH_MSG_INFO("REGTEST muFastTrack->phi() returns " << (thisCombMuFeature)->muFastTrack()->phi());
3116 ATH_MSG_INFO("REGTEST muFastTrack->radius() returns " << (thisCombMuFeature)->muFastTrack()->radius());
3117 ATH_MSG_INFO("REGTEST muFastTrack->zeta() returns " << (thisCombMuFeature)->muFastTrack()->zeta());
3118 } else {
3119 ATH_MSG_WARNING("MuonFeature has no muFastTrack!" );
3120 }
3121
3122 ATH_MSG_INFO("REGTEST TrigInDetTrack info: ");
3123 if ( thisCombMuFeature->IDTrackLink().isValid() ) {
3124 ATH_MSG_INFO("REGTEST IDTrack->algorithmId() returns " <<(thisCombMuFeature)->IDTrack()->algorithmId());
3125 ATH_MSG_INFO("REGTEST IDTrack->chi2() returns " << (thisCombMuFeature)->IDTrack()->chi2());
3126 ATH_MSG_INFO("REGTEST IDTrack->NStrawHits() returns " <<(thisCombMuFeature)->IDTrack()->NStrawHits());
3127
3128 ATH_MSG_INFO("REGTEST IDTrack->NStraw() returns " << (thisCombMuFeature)->IDTrack()->NStraw());
3129 ATH_MSG_INFO("REGTEST IDTrack->NStrawTime() returns " <<(thisCombMuFeature)->IDTrack()->NStrawTime());
3130 ATH_MSG_INFO("REGTEST IDTrack->NTRHits() returns " <<(thisCombMuFeature)->IDTrack()->NTRHits());
3131 } else {
3132 ATH_MSG_WARNING("MuonFeature has no IDTrack!" );
3133 }
3134
3135 }
3136 }
3137 return StatusCode::SUCCESS;
3138}
3139
3141
3142StatusCode TrigEDMChecker::dumpTrigEMCluster ATLAS_NOT_THREAD_SAFE() {
3143
3144 ATH_MSG_DEBUG("in dumpTrigEMCluster()");
3145 ATH_MSG_INFO("REGTEST ==========START of TrigEMCluster DUMP===========");
3146
3149
3150 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3151 if (sc.isFailure()) {
3152 ATH_MSG_INFO("REGTEST No TrigEMCluster found");
3153 return StatusCode::SUCCESS;
3154 }
3155 ATH_MSG_INFO("REGTEST TrigEMCluster retrieved");
3156
3157 for (int i=0; EMCluster != lastEMCluster; ++EMCluster, ++i) {
3158
3159 const TrigEMCluster* thisEMCluster = &(*EMCluster);
3160
3161 ATH_MSG_INFO("REGTEST Looking at TrigEMCluster " << i);
3162
3163 ATH_MSG_INFO("REGTEST TrigEMCluster->energy() returns " << thisEMCluster->energy());
3164 ATH_MSG_INFO("REGTEST TrigEMCluster->e() returns " << thisEMCluster->e());
3165 ATH_MSG_INFO("REGTEST TrigEMCluster->phi() returns " << thisEMCluster->phi());
3166
3167 ATH_MSG_INFO("REGTEST TrigEMCluster->eta() returns " << thisEMCluster->eta());
3168 ATH_MSG_INFO("REGTEST TrigEMCluster->e237() returns " << thisEMCluster->e237());
3169 ATH_MSG_INFO("REGTEST TrigEMCluster->e277() returns " << thisEMCluster->e277());
3170 ATH_MSG_INFO("REGTEST TrigEMCluster->fracs1() returns " << thisEMCluster->fracs1());
3171 ATH_MSG_INFO("REGTEST TrigEMCluster->weta2() returns " << thisEMCluster->weta2());
3172 ATH_MSG_INFO("REGTEST TrigEMCluster->ehad1() returns " << thisEMCluster->ehad1());
3173 ATH_MSG_INFO("REGTEST TrigEMCluster->Eta1() returns " << thisEMCluster->Eta1());
3174 }
3175
3176 ATH_MSG_INFO("REGTEST ==========END of TrigEMCluster DUMP===========");
3177 ATH_MSG_DEBUG("dumpTrigEMCluster() succeeded");
3178
3179 return StatusCode::SUCCESS;
3180}
3181
3182StatusCode TrigEDMChecker::dumpxAODTrigEMCluster ATLAS_NOT_THREAD_SAFE() {
3183
3184 ATH_MSG_DEBUG("in dumpxAODTrigEMCluster()");
3185
3186 ATH_MSG_INFO("REGTEST ==========START of TrigEMCluster DUMP===========");
3187
3190
3191 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3192 if (sc.isFailure()) {
3193 ATH_MSG_INFO("REGTEST No xAOD::TrigEMCluster found");
3194 return StatusCode::SUCCESS;
3195 }
3196 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster retrieved");
3197
3198
3199 for (int i=0; EMCluster != lastEMCluster; ++EMCluster, ++i) {
3200
3201 const xAOD::TrigEMCluster* thisEMCluster = &(*EMCluster);
3202
3203 ATH_MSG_INFO("REGTEST Looking at xAOD::TrigEMCluster " << i);
3204
3205 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->energy() returns " << thisEMCluster->energy());
3206 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->e() returns " << thisEMCluster->energy());
3207 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->phi() returns " << thisEMCluster->phi());
3208
3209 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->eta() returns " << thisEMCluster->eta());
3210 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->e237() returns " << thisEMCluster->e237());
3211 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->e277() returns " << thisEMCluster->e277());
3212 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->fracs1() returns " << thisEMCluster->fracs1());
3213 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->weta2() returns " << thisEMCluster->weta2());
3214 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->ehad1() returns " << thisEMCluster->ehad1());
3215 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->Eta1() returns " << thisEMCluster->eta1());
3216 }
3217
3218 ATH_MSG_INFO("REGTEST ==========END of xAOD::TrigEMCluster DUMP===========");
3219 ATH_MSG_DEBUG("dumpxAODTrigEMCluster() succeeded");
3220
3221 return StatusCode::SUCCESS;
3222}
3223
3225
3226StatusCode TrigEDMChecker::dumpTrigTauClusterContainer ATLAS_NOT_THREAD_SAFE() {
3227
3228 ATH_MSG_DEBUG("in dumpTrigTauClusterContainer()");
3229
3230 ATH_MSG_INFO("REGTEST ==========START of TrigTauClusterContainer/TrigTauClusterDetailsContainer DUMP===========");
3231
3234
3235 StatusCode sc = evtStore()->retrieve(TauCluster,lastTauCluster);
3236 if (sc.isFailure()) {
3237 ATH_MSG_INFO("REGTEST No TrigTauClusterContainer found");
3238 return StatusCode::SUCCESS;
3239 }
3240 ATH_MSG_INFO("REGTEST TrigTauClusterContainer retrieved");
3241
3242
3243 int nClusters = 0;
3244 for (int i=0; TauCluster != lastTauCluster; ++TauCluster, ++i) {
3245
3246 ATH_MSG_INFO("REGTEST Looking at TrigTauClusterContainer " << i);
3247
3248 TrigTauClusterContainer::const_iterator TauClusterItr = TauCluster->begin();
3249 TrigTauClusterContainer::const_iterator TauClusterItrE = TauCluster->end();
3250
3251 for (int j=0; TauClusterItr != TauClusterItrE; ++TauClusterItr, ++j ) {
3252 nClusters++;
3253 ATH_MSG_INFO("REGTEST Looking at TrigTauCluster " << j);
3254
3255 ATH_MSG_INFO("REGTEST TrigTauCluster->energy() returns " << (*TauClusterItr)->energy());
3256 ATH_MSG_INFO("REGTEST TrigTauCluster->et() returns " << (*TauClusterItr)->et());
3257 ATH_MSG_INFO("REGTEST TrigTauCluster->EMCalibEnergy() returns " << (*TauClusterItr)->EMCalibEnergy());
3258
3259 ATH_MSG_INFO("REGTEST TrigTauCluster->EMenergy() returns " << (*TauClusterItr)->EMenergy());
3260 ATH_MSG_INFO("REGTEST TrigTauCluster->HADenergy() returns " << (*TauClusterItr)->HADenergy());
3261 ATH_MSG_INFO("REGTEST TrigTauCluster->eta() returns " << (*TauClusterItr)->eta());
3262 ATH_MSG_INFO("REGTEST TrigTauCluster->phi() returns " << (*TauClusterItr)->phi());
3263 ATH_MSG_INFO("REGTEST TrigTauCluster->IsoFrac() returns " << (*TauClusterItr)->IsoFrac());
3264 ATH_MSG_INFO("REGTEST TrigTauCluster->stripWidth() returns " << (*TauClusterItr)->stripWidth());
3265 ATH_MSG_INFO("REGTEST TrigTauCluster->numStripCells() returns " << (*TauClusterItr)->numStripCells());
3266 ATH_MSG_INFO("REGTEST TrigTauCluster->CaloRadius() returns " << (*TauClusterItr)->CaloRadius());
3267 ATH_MSG_INFO("REGTEST TrigTauCluster->numTotCells() returns " << (*TauClusterItr)->numTotCells());
3268
3269
3270 if( (*TauClusterItr)->clusterDetails() == 0 )
3271 ATH_MSG_WARNING("REGTEST TrigTauCluster-> Details link is MISSING ");
3272 else{
3273 ATH_MSG_INFO("REGTEST TrigTauCluster->Energy in Narrow cone : EM[0/1/2/3]="
3274 <<(*TauClusterItr)->EMenergyNarrow(0) << " " << (*TauClusterItr)->EMenergyNarrow(1) << " "
3275 <<(*TauClusterItr)->EMenergyNarrow(2) << " ");
3276 ATH_MSG_INFO("REGTEST TrigTauCluster->Energy in Narrow cone : HAD[0/1/2]="
3277 <<(*TauClusterItr)->HADenergyNarrow(0) << " " << (*TauClusterItr)->HADenergyNarrow(1) << " "
3278 <<(*TauClusterItr)->HADenergyNarrow(2));
3279 }
3280 }
3281 }
3282
3283 int nDetails = 0;
3286 sc = evtStore()->retrieve(TauDetailsCluster,lastTauDetailsCluster);
3287 if (sc.isFailure()) {
3288 ATH_MSG_INFO("REGTEST No TrigTauDetailsClusterContainer found");
3289 return StatusCode::SUCCESS;
3290 }
3291 ATH_MSG_INFO("REGTEST TrigTauDetailsClusterContainer retrieved");
3292
3293 for (int i=0; TauDetailsCluster != lastTauDetailsCluster; ++TauDetailsCluster, ++i) {
3294
3295 ATH_MSG_INFO("REGTEST Looking at TrigTauClusterDetailsContainer " << i);
3296
3297 TrigTauClusterDetailsContainer::const_iterator TauDetailsClusterItr = TauDetailsCluster->begin();
3298 TrigTauClusterDetailsContainer::const_iterator TauDetailsClusterItrE = TauDetailsCluster->end();
3299
3300 for (int j=0; TauDetailsClusterItr != TauDetailsClusterItrE; ++TauDetailsClusterItr, ++j ) {
3301 nDetails++;
3302 ATH_MSG_INFO("REGTEST Looking at TrigTauClusterDetails " << j);
3303
3304 for(unsigned int i = 0; i<4; ++i ) {
3305 ATH_MSG_INFO("REGTEST TrigTauClusterDetails-> EM["<<i <<"] Radius/EnergyNar/EnergyMid/EnergyWid returns "
3306 << (*TauDetailsClusterItr)->EMRadius(i) << " "
3307 << (*TauDetailsClusterItr)->EMenergyNarrow(i) << " "
3308 << (*TauDetailsClusterItr)->EMenergyMedium(i) << " "
3309 << (*TauDetailsClusterItr)->EMenergyWide(i));
3310 }
3311 for(unsigned int i = 0; i<3; ++i ) {
3312 ATH_MSG_INFO("REGTEST TrigTauClusterDetails-> HAD["<<i <<"] Radius/EnergyNar/EnergyMid/EnergyWid returns "
3313 << (*TauDetailsClusterItr)->HADRadius(i) << " "
3314 << (*TauDetailsClusterItr)->HADenergyNarrow(i) << " "
3315 << (*TauDetailsClusterItr)->HADenergyMedium(i) << " "
3316 << (*TauDetailsClusterItr)->HADenergyWide(i));
3317 }
3318 }
3319 }
3320
3321 if( nDetails != nClusters)
3322 ATH_MSG_WARNING("REGTEST inconsistent number of TrigTauClusters ("<< nClusters<< ") and TrigTauClusterDetails ("
3323 << nDetails << ")");
3324
3325 ATH_MSG_INFO("REGTEST ==========END of TrigTauClusterContainer/TrigTauClusterDetailsContainer DUMP===========");
3326
3327 ATH_MSG_DEBUG("dumpTrigTauClusterContainer() succeeded");
3328
3329 return StatusCode::SUCCESS;
3330}
3331
3333
3334StatusCode TrigEDMChecker::dumpTrigEMClusterContainer ATLAS_NOT_THREAD_SAFE() {
3335
3336 ATH_MSG_DEBUG("in dumpTrigEMClusterContainer()");
3337
3338 ATH_MSG_INFO("REGTEST ==========START of TrigEMClusterContainer DUMP===========");
3339
3342
3343 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3344 if (sc.isFailure()) {
3345 ATH_MSG_INFO("REGTEST No TrigEMClusterContainer found");
3346 return StatusCode::SUCCESS;
3347 }
3348 ATH_MSG_INFO("REGTEST TrigEMClusterContainer retrieved");
3349
3350
3351 for (int i=0; EMCluster != lastEMCluster; ++EMCluster, ++i) {
3352
3353 ATH_MSG_INFO("REGTEST Looking at TrigEMClusterContainer " << i);
3354
3355 TrigEMClusterContainer::const_iterator EMClusterItr = EMCluster->begin();
3356 TrigEMClusterContainer::const_iterator EMClusterItrE = EMCluster->end();
3357
3358 for (int j=0; EMClusterItr != EMClusterItrE; ++EMClusterItr, ++j ) {
3359
3360 ATH_MSG_INFO("REGTEST Looking at TrigEMCluster " << j);
3361
3362 ATH_MSG_INFO("REGTEST TrigEMCluster->energy() returns " << (*EMClusterItr)->energy());
3363 ATH_MSG_INFO("REGTEST TrigEMCluster->et() returns " << (*EMClusterItr)->et());
3364 ATH_MSG_INFO("REGTEST TrigEMCluster->eta() returns " << (*EMClusterItr)->eta());
3365 ATH_MSG_INFO("REGTEST TrigEMCluster->phi() returns " << (*EMClusterItr)->phi());
3366 ATH_MSG_INFO("REGTEST TrigEMCluster->print() gives");
3367 int level = msg().level();
3368 // little trick to print out stuff
3369 msg().setLevel(MSG::DEBUG);
3370 (*EMClusterItr)->print(msg());
3371 msg().setLevel(level);
3372 }
3373 }
3374
3375 ATH_MSG_INFO("REGTEST ==========END of TrigEMClusterContainer DUMP===========");
3376 ATH_MSG_DEBUG("dumpTrigEMClusterContainer() succeeded");
3377
3378 return StatusCode::SUCCESS;
3379}
3380
3381StatusCode TrigEDMChecker::dumpxAODTrigEMClusterContainer ATLAS_NOT_THREAD_SAFE() {
3382
3383 ATH_MSG_DEBUG("in dumpxAODTrigEMClusterContainer()");
3384
3385 ATH_MSG_INFO("REGTEST ==========START of xAODTrigEMClusterContainer DUMP===========");
3386
3389
3390 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3391 if (sc.isFailure()) {
3392 ATH_MSG_INFO("REGTEST No xAOD::TrigEMClusterContainer found");
3393 return StatusCode::SUCCESS;
3394 }
3395 ATH_MSG_INFO("REGTEST xAOD::TrigEMClusterContainer retrieved");
3396
3397
3398 for (int i=0; EMCluster != lastEMCluster; ++EMCluster, ++i) {
3399
3400 ATH_MSG_INFO("REGTEST Looking at xAOD::TrigEMClusterContainer " << i);
3401
3402 xAOD::TrigEMClusterContainer::const_iterator EMClusterItr = EMCluster->begin();
3403 xAOD::TrigEMClusterContainer::const_iterator EMClusterItrE = EMCluster->end();
3404
3405 for (int j=0; EMClusterItr != EMClusterItrE; ++EMClusterItr, ++j ) {
3406
3407 ATH_MSG_INFO("REGTEST Looking at xAOD::TrigEMCluster " << j);
3408 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->energy() returns " << (*EMClusterItr)->energy());
3409 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->et() returns " << (*EMClusterItr)->et());
3410 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->eta() returns " << (*EMClusterItr)->eta());
3411 ATH_MSG_INFO("REGTEST xAOD::TrigEMCluster->phi() returns " << (*EMClusterItr)->phi());
3412 //msg() <<MSG::INFO << "REGTEST xAOD::TrigEMCluster->print() gives" << endmsg;
3413 //int level = msg().level();
3414 // little trick to print out stuff
3415 //msg().setLevel(MSG::DEBUG);
3416 //(*EMClusterItr)->print(msg());
3417 //msg().setLevel(level);
3418 }
3419 }
3420
3421 ATH_MSG_INFO("REGTEST ==========END of TrigEMClusterContainer DUMP===========");
3422 ATH_MSG_DEBUG("dumpTrigEMClusterContainer() succeeded");
3423
3424 return StatusCode::SUCCESS;
3425}
3426
3428
3429StatusCode TrigEDMChecker::dumpTileMuFeatureContainer ATLAS_NOT_THREAD_SAFE() {
3430
3431 ATH_MSG_DEBUG("in dumpTileMuFeatureContainer()");
3432 ATH_MSG_INFO("REGTEST ==========START of TileMuFeatureContainer DUMP===========");
3433
3436
3437 StatusCode sc = evtStore()->retrieve(TileMu, lastTileMu);
3438 if (sc.isFailure()) {
3439 ATH_MSG_INFO("REGTEST No TileMuFeatureContainer found");
3440 return StatusCode::SUCCESS;
3441 }
3442 ATH_MSG_INFO("REGTEST TileMuFeatureContainer retrieved");
3443
3444 for (int i=0; TileMu != lastTileMu; ++TileMu, ++i) {
3445 ATH_MSG_INFO("REGTEST Looking at TileMuFeatureContainer " << i);
3448
3449 for(int j=0; TileMuItr != TileMuItrE; ++TileMuItr, ++j) {
3450 ATH_MSG_INFO("REGTEST Looking at TileMuFeature " << j);
3451 ATH_MSG_INFO("REGTEST TileMuFeature->eta() returns " << (*TileMuItr)->eta());
3452 ATH_MSG_INFO("REGTEST TileMuFeature->phi() returns " << (*TileMuItr)->phi());
3453 ATH_MSG_INFO("REGTEST TileMuFeature->enedep().at(0) returns " << (*TileMuItr)->enedep().at(0));
3454 ATH_MSG_INFO("REGTEST TileMuFeature->enedep().at(1) returns " << (*TileMuItr)->enedep().at(1));
3455 ATH_MSG_INFO("REGTEST TileMuFeature->enedep().at(2) returns " << (*TileMuItr)->enedep().at(2));
3456 ATH_MSG_INFO("REGTEST TileMuFeature->enedep().at(3) returns " << (*TileMuItr)->enedep().at(3));
3457 ATH_MSG_INFO("REGTEST TileMuFeature->quality() returns " << (*TileMuItr)->quality());
3458
3459 }
3460 }
3461
3462 ATH_MSG_INFO("REGTEST ==========END of TileMuFeatureContainer DUMP===========");
3463 ATH_MSG_DEBUG("dumpTileMuFeatureContainer() succeeded");
3464
3465 return StatusCode::SUCCESS;
3466}
3467
3469
3470StatusCode TrigEDMChecker::dumpTileTrackMuFeatureContainer ATLAS_NOT_THREAD_SAFE() {
3471
3472 ATH_MSG_DEBUG("in dumpTileTrackMuFeatureContainer()");
3473 ATH_MSG_INFO("REGTEST ==========START of TileTrackMuFeatureContainer DUMP===========");
3474
3477
3478 StatusCode sc = evtStore()->retrieve(TileTrackMu, lastTileTrackMu);
3479 if (sc.isFailure()) {
3480 ATH_MSG_INFO("REGTEST No TileTrackMuFeatureContainer found");
3481 return StatusCode::SUCCESS;
3482 }
3483 ATH_MSG_INFO("REGTEST TileTrackMuFeatureContainer retrieved");
3484
3485 for (int i=0; TileTrackMu!=lastTileTrackMu; ++TileTrackMu, ++i) {
3486 ATH_MSG_INFO("REGTEST Looking at TileTrackMuFeatureContainer " << i);
3487
3488 TileTrackMuFeatureContainer::const_iterator TileTrackMuItr = TileTrackMu->begin();
3489 TileTrackMuFeatureContainer::const_iterator TileTrackMuItrE= TileTrackMu->end();
3490
3491 for (int j=0; TileTrackMuItr != TileTrackMuItrE; ++TileTrackMuItr, ++j) {
3492 ATH_MSG_INFO("REGTEST Looking at TileTrackMuFeature " << j);
3493 ATH_MSG_INFO("REGTEST TileTrackMuFeature->PtTR_Trk() returns " << (*TileTrackMuItr)->PtTR_Trk());
3494 ATH_MSG_INFO("REGTEST TileTrackMuFeature->EtaTR_Trk() returns " << (*TileTrackMuItr)->EtaTR_Trk());
3495 ATH_MSG_INFO("REGTEST TileTrackMuFeature->PhiTR_Trk() returns " << (*TileTrackMuItr)->PhiTR_Trk());
3496 ATH_MSG_INFO("REGTEST TileTrackMuFeature->Typ_IDTrk() returns " << (*TileTrackMuItr)->Typ_IDTrk());
3497
3498 ATH_MSG_INFO("REGTEST TileMuFeature info: ");
3499 ElementLink<TileMuFeatureContainer> TileMuEL = (*TileTrackMuItr)->TileMuLink();
3500 const TileMuFeature* TileMu;
3501 if ( !TileMuEL.isValid() ) {
3502 ATH_MSG_INFO("REGTEST No TileMuFeature (Something Wrong)");
3503 TileMu = 0;
3504 } else{
3505 TileMu = *TileMuEL;
3506 }
3507
3508 if( TileMu != 0 ){
3509 ATH_MSG_INFO("REGTEST TileMuLink->eta() returns " << TileMu->eta());
3510 ATH_MSG_INFO("REGTEST TileMuLink->phi() returns " << TileMu->phi());
3511 ATH_MSG_INFO("REGTEST TileMuLink->enedep().at(0) returns " << TileMu->enedep().at(0));
3512 ATH_MSG_INFO("REGTEST TileMuLink->enedep().at(1) returns " << TileMu->enedep().at(1));
3513 ATH_MSG_INFO("REGTEST TileMuLink->enedep().at(2) returns " << TileMu->enedep().at(2));
3514 ATH_MSG_INFO("REGTEST TileMuLink->enedep().at(3) returns " << TileMu->enedep().at(3));
3515 ATH_MSG_INFO("REGTEST TileMuLink->quality() returns " << TileMu->quality());
3516 }
3517
3518 ATH_MSG_INFO("REGTEST TrigInDetTrack info: ");
3519 ElementLink<TrigInDetTrackCollection> IDScanEL = (*TileTrackMuItr)->IDScanLink();
3520 const TrigInDetTrack* Track;
3521 if ( !IDScanEL.isValid() ) {
3522 ATH_MSG_INFO("REGTEST No valid IDtracks");
3523 Track = 0;
3524 } else{
3525 Track = *IDScanEL;
3526 }
3527
3528 if (Track != 0) {
3529 ATH_MSG_INFO("REGTEST IDScanLink->algorithmId() returns " << Track->algorithmId());
3530 ATH_MSG_INFO("REGTEST IDScanLink->chi2() returns " << Track->chi2());
3531 ATH_MSG_INFO("REGTEST IDScanLink->NStrawHits() returns ");
3532 ATH_MSG_INFO("REGTEST IDScanLink->NStraw() returns " << Track->NStraw());
3533 ATH_MSG_INFO("REGTEST IDScanLink->NStrawTime() returns " << Track->NStrawTime());
3534 ATH_MSG_INFO("REGTEST IDScanLink->NTRHits() returns " << Track->NTRHits());
3535 ATH_MSG_INFO("REGTEST IDScanLink->param()->phi0() returns " << Track->param()->phi0());
3536 ATH_MSG_INFO("REGTEST IDScanLink->param()->eta() returns " << Track->param()->eta());
3537 ATH_MSG_INFO("REGTEST IDScanLink->param()->pT() returns " << Track->param()->pT());
3538 }
3539 }
3540 }
3541
3542 ATH_MSG_INFO("REGTEST ==========END of TileTrackMuFeatureContainer DUMP===========");
3543 ATH_MSG_DEBUG("dumpTileTrackMuFeatureContainer() succeeded");
3544 return StatusCode::SUCCESS;
3545}
3546
3548StatusCode TrigEDMChecker::dumpxAODTauJetContainer ATLAS_NOT_THREAD_SAFE() {
3549
3550 ATH_MSG_DEBUG("In dumpxAODTauJetContainer");
3551 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TauJetContainer DUMP===========" );
3552 const xAOD::TauJetContainer * TauJetcont = 0;
3553 StatusCode sc = evtStore() -> retrieve (TauJetcont, "HLT_xAOD__TauJetContainer_TrigTauRecMerged");
3554
3555 if (sc.isFailure()) {
3556
3557 ATH_MSG_INFO("REGTEST No Tau container HLT_xAOD__TauJetContainer_TrigTauRecMerged");
3558
3559
3560 return StatusCode::SUCCESS;
3561 }
3562
3563
3564 for(xAOD::TauJetContainer::const_iterator tauIt = TauJetcont->begin(); tauIt != TauJetcont->end();++tauIt){
3565
3566 ATH_MSG_INFO( "REGTEST (*tauIt)->eta() returns " << (*tauIt)->eta() );
3567 ATH_MSG_INFO( "REGTEST (*tauIt)->phi() returns " << (*tauIt)->phi() );
3568 ATH_MSG_INFO( "REGTEST (*tauIt)->pt() returns " << (*tauIt)->pt() );
3569
3570 // for numTracks()
3571 int EFnTracks = -1;
3572 #ifndef XAODTAU_VERSIONS_TAUJET_V3_H
3573 EFnTracks = (*tauIt)->nTracks();
3574 #else
3575 (*tauIt)->detail(xAOD::TauJetParameters::nChargedTracks, EFnTracks);
3576 #endif
3577
3578 ATH_MSG_INFO( "REGTEST (*tauIt)->nTracks() returns " << EFnTracks );
3579
3580 // for nTracksIsolation()
3581 int EFWidenTrack = -1;
3582 #ifndef XAODTAU_VERSIONS_TAUJET_V3_H
3583 EFWidenTrack = (*tauIt)->nWideTracks();
3584 #else
3585 (*tauIt)->detail(xAOD::TauJetParameters::nIsolatedTracks, EFWidenTrack);
3586 #endif
3587
3588 ATH_MSG_INFO( "REGTEST (*tauIt)->nWideTracks() returns " << EFWidenTrack );
3589
3590 //bool test = false;
3591 float trkAvgDist=0;
3592 float etOvPtLead=0;
3593 float emRadius=0;
3594 float hadRadius=0;
3595 float IsoFrac=0;
3596 float centFrac=0;
3597 float ipSigLeadTrk=0;
3598 float trFlightPathSig=0;
3599 float dRmax=0;
3600 float massTrkSys=0;
3601 float PSSFraction=0;
3602 float EMPOverTrkSysP=0;
3603 float ChPiEMEOverCaloEME=0;
3604 float EtEm=0;
3605 float EtHad=0;
3606
3607 if ( (*tauIt)->detail(xAOD::TauJetParameters::trkAvgDist,trkAvgDist))
3608 ATH_MSG_INFO( "REGTEST TauDetails->trkAvgDist() returns " << trkAvgDist);
3609
3610 if ( (*tauIt)->detail(xAOD::TauJetParameters::etOverPtLeadTrk,etOvPtLead))
3611 ATH_MSG_INFO( "REGTEST TauDetails->etOverPtLeadTrk() returns " << etOvPtLead);
3612
3613 if ( (*tauIt)->detail(xAOD::TauJetParameters::EMRadius,emRadius))
3614 ATH_MSG_INFO( "REGTEST TauDetails->EMRadius() returns " << emRadius);
3615
3616 if ( (*tauIt)->detail(xAOD::TauJetParameters::hadRadius,hadRadius))
3617 ATH_MSG_INFO( "REGTEST TauDetails->hadRadius() returns " << hadRadius);
3618
3619 if ( (*tauIt)->detail(xAOD::TauJetParameters::isolFrac,IsoFrac))
3620 ATH_MSG_INFO( "REGTEST TauDetails->isolFrac() returns " << IsoFrac);
3621
3622 if ( (*tauIt)->detail(xAOD::TauJetParameters::centFrac,centFrac))
3623 ATH_MSG_INFO( "REGTEST TauDetails->centFrac() returns " << centFrac);
3624
3625 if ( (*tauIt)->detail(xAOD::TauJetParameters::ipSigLeadTrk,ipSigLeadTrk))
3626 ATH_MSG_INFO( "REGTEST TauDetails->ipSigLeadTrk() returns " << ipSigLeadTrk);
3627
3628 if ( (*tauIt)->detail(xAOD::TauJetParameters::trFlightPathSig,trFlightPathSig))
3629 ATH_MSG_INFO( "REGTEST TauDetails->trFlightPathSig() returns " << trFlightPathSig);
3630
3631 if ( (*tauIt)->detail(xAOD::TauJetParameters::dRmax,dRmax))
3632 ATH_MSG_INFO( "REGTEST TauDetails->dRmax() returns " << dRmax);
3633
3634 if ( (*tauIt)->detail(xAOD::TauJetParameters::massTrkSys,massTrkSys)){
3635 massTrkSys /=1000;
3636 ATH_MSG_INFO( "REGTEST TauDetails->massTrkSys() returns " << massTrkSys);}
3637
3638 if ( (*tauIt)->detail(xAOD::TauJetParameters::PSSFraction,PSSFraction))
3639 ATH_MSG_INFO( "REGTEST TauDetails->PSSFraction() returns " << PSSFraction);
3640
3641 if ( (*tauIt)->detail(xAOD::TauJetParameters::EMPOverTrkSysP,EMPOverTrkSysP))
3642 ATH_MSG_INFO( "REGTEST TauDetails->EMPOverTrkSysP() returns " << EMPOverTrkSysP);
3643
3644 if ( (*tauIt)->detail(xAOD::TauJetParameters::ChPiEMEOverCaloEME,ChPiEMEOverCaloEME))
3645 ATH_MSG_INFO( "REGTEST TauDetails->ChPiEMEOverCaloEME() returns " << ChPiEMEOverCaloEME);
3646
3647 if ( (*tauIt)->detail(xAOD::TauJetParameters::etEMAtEMScale,EtEm)){
3648 EtEm /=1000;
3649 ATH_MSG_INFO( "REGTEST TauDetails->etEMAtEMScale() returns " << EtEm);}
3650
3651 if ( (*tauIt)->detail(xAOD::TauJetParameters::etHadAtEMScale,EtHad)){
3652 EtHad /=1000;
3653 ATH_MSG_INFO( "REGTEST TauDetails->etHadAtEMScale() returns " << EtHad);}
3654
3655
3656 if( !(*tauIt)->jetLink().isValid() ) {
3657 ATH_MSG_WARNING("tau does not have jet seed");
3658 return StatusCode::SUCCESS;
3659 }
3660
3661 const xAOD::Jet* pJetSeed = *((*tauIt)->jetLink());
3662
3665
3666 for (int clusCount = 0; clusItr != clusItrE; ++clusItr, ++clusCount) {
3667
3668 ATH_MSG_INFO( "REGTEST Tau Cluster " << clusCount << " pt = " << (*clusItr)->pt()
3669 << " eta = " << (*clusItr)->eta()
3670 << " phi = " << (*clusItr)->phi() );
3671
3672 }
3673
3674
3675 for (unsigned int trackNum = 0; trackNum < (*tauIt)->nTracks(); ++trackNum) {
3676
3677 const xAOD::TrackParticle *linkTrack = (*tauIt)->track(trackNum)->track();
3678 if (!linkTrack) {
3679 ATH_MSG_WARNING("can't get tau linked track");
3680 return StatusCode::SUCCESS;
3681 } else {
3682 ATH_MSG_DEBUG("Got the tau linked track");
3683 }
3684
3685 ATH_MSG_INFO( "REGTEST Tau linked track " << trackNum << " pt = " << linkTrack->pt()
3686 << " eta = " << linkTrack->eta()
3687 << " phi = " << linkTrack->phi() );
3688
3689 }
3690
3691
3692 }// end for
3693
3694 return StatusCode::SUCCESS;
3695
3696}
3697
3698
3700
3701StatusCode TrigEDMChecker::dumpTauJetContainer ATLAS_NOT_THREAD_SAFE() {
3702
3703 ATH_MSG_INFO("REGTEST ==========START of TauJetContainer DUMP===========");
3704
3705 using namespace Analysis;
3706
3707 StatusCode sCode=StatusCode::FAILURE;
3708 int ntag=1;
3709 std::string TauContainerTags[]={"HLT_TrigTauRecMerged"};
3710 for (int itag=0; itag < ntag; itag++) {
3711 const TauJetContainer* TauJetcont = nullptr;
3712 sCode=evtStore()->retrieve(TauJetcont , TauContainerTags[itag]);
3713 if( sCode.isFailure() ){
3714 ATH_MSG_INFO("Failed to retrieve TauJetContainer with key " << TauContainerTags[itag]);
3715 continue;
3716 }
3717
3718 for(Analysis::TauJetContainer::const_iterator tauIt = TauJetcont->begin(); tauIt != TauJetcont->end(); ++tauIt){
3719
3720 bool IsTaurec = false;
3721 bool Is1p3p = false;
3722 if ((*tauIt)->hasAuthor( TauJetParameters::tauRec)) {
3723 ATH_MSG_INFO("Is TauRec Seeded ");
3724 IsTaurec = true;
3725 }
3726
3727 if ((*tauIt)->hasAuthor( TauJetParameters::tau1P3P)) {
3728 ATH_MSG_INFO("Is Tau1p3p Seeded ");
3729 Is1p3p = true;
3730 }
3731
3732 if ((*tauIt)->hasAuthor( TauJetParameters::unknown)) {
3733 ATH_MSG_INFO("Is unknown seeded ");
3734 }
3735
3736 const Analysis::TauCommonDetails* TauDetails = (*tauIt)->details<const Analysis::TauCommonDetails>();
3737 if (TauDetails == NULL) {
3738 ATH_MSG_INFO(" TauDetails == NULL ");
3739 continue;
3740 }
3741
3742 ATH_MSG_INFO("REGTEST (*tauIt)->eta() returns " << (*tauIt)->eta());
3743 ATH_MSG_INFO("REGTEST (*tauIt)->phi() returns " << (*tauIt)->phi());
3744 ATH_MSG_INFO("REGTEST (*tauIt)->numTrack() returns " << (*tauIt)->numTrack());
3745 ATH_MSG_INFO("REGTEST TauDetails->nLooseTrk() returns " << TauDetails->nLooseTrk());
3746 ATH_MSG_INFO("REGTEST TauDetails->leadTrkPt() returns " << TauDetails->leadTrkPt());
3747 ATH_MSG_INFO("REGTEST TauDetails->leadLooseTrkPt() returns " << TauDetails->leadLooseTrkPt());
3748 ATH_MSG_INFO("REGTEST TauDetails->ipZ0SinThetaSigLeadTrk() returns " << TauDetails->ipZ0SinThetaSigLeadTrk());
3749 ATH_MSG_INFO("REGTEST TauDetails->ipSigLeadTrk() returns "<<TauDetails->ipSigLeadTrk());
3750 ATH_MSG_INFO("REGTEST TauDetails->ipSigLeadLooseTrk() returns "<<TauDetails->ipSigLeadLooseTrk());
3751 ATH_MSG_INFO("REGTEST TauDetails->trkWidth2() returns "<<TauDetails->trkWidth2());
3752 ATH_MSG_INFO("REGTEST TauDetails->trFlightPathSig() returns "<< TauDetails->trFlightPathSig());
3753
3754 if(IsTaurec) {
3755 ATH_MSG_INFO("Calo seeded");
3756 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_etHadCalib() returns " << TauDetails->seedCalo_etHadCalib());
3757 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_etEMCalib() returns " << TauDetails->seedCalo_etEMCalib());
3758 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_EMRadius() returns " << TauDetails->seedCalo_EMRadius());
3759 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_isolFrac() returns " << TauDetails->seedCalo_isolFrac());
3760 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_centFrac() returns " << TauDetails->seedCalo_centFrac());
3761 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_stripWidth2() returns " << TauDetails->seedCalo_stripWidth2());
3762 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_nStrip() returns " << TauDetails->seedCalo_nStrip());
3763 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_etEMAtEMScale() returns " << TauDetails->seedCalo_etEMAtEMScale());
3764 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_etHADAtEMScale() returns " << TauDetails->seedCalo_etHadAtEMScale());
3765 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_hadRadius() returns " << TauDetails->seedCalo_hadRadius());
3766 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_nIsolLooseTrk() returns " << TauDetails->seedCalo_nIsolLooseTrk());
3767 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_trkAvgDist() returns " << TauDetails->seedCalo_trkAvgDist());
3768 ATH_MSG_INFO("REGTEST TauDetails->seedCalo_trkRmsDist() returns " << TauDetails->seedCalo_trkRmsDist());
3769 }
3770
3771 if(Is1p3p) {
3772 ATH_MSG_INFO("Track seeded");
3773 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_EMRadius() returns " << TauDetails->seedTrk_EMRadius());
3774 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_isolFrac() returns " << TauDetails->seedTrk_isolFrac());
3775 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etChrgHadOverSumTrkPt () returns " << TauDetails->seedTrk_etChrgHadOverSumTrkPt ());
3776 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_isolFracWide() returns " << TauDetails->seedTrk_isolFracWide());
3777 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etHadAtEMScale() returns " << TauDetails->seedTrk_etHadAtEMScale());
3778 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etEMAtEMScale() returns " << TauDetails->seedTrk_etEMAtEMScale());
3779 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etEMCL() returns " << TauDetails->seedTrk_etEMCL());
3780 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etChrgEM() returns " << TauDetails->seedTrk_etChrgEM());
3781 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etNeuEM() returns " << TauDetails->seedTrk_etNeuEM());
3782 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etResNeuEM() returns " << TauDetails->seedTrk_etResNeuEM());
3783 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_hadLeakEt() returns " << TauDetails->seedTrk_hadLeakEt());
3784 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_sumEMCellEtOverLeadTrkPt() returns " << TauDetails->seedTrk_sumEMCellEtOverLeadTrkPt());
3785 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_secMaxStripEt() returns " << TauDetails->seedTrk_secMaxStripEt());
3786 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_stripWidth2() returns " << TauDetails->seedTrk_stripWidth2());
3787 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_nStrip() returns " << TauDetails->seedTrk_nStrip());
3788 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etChrgHad() returns " << TauDetails->seedTrk_etChrgHad());
3789 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_nOtherCoreTrk() returns " << TauDetails->seedTrk_nOtherCoreTrk());
3790 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_nIsolTrk() returns " << TauDetails->seedTrk_nIsolTrk());
3791 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etIsolEM() returns " << TauDetails->seedTrk_etIsolEM());
3792 ATH_MSG_INFO("REGTEST TauDetails->seedTrk_etIsolHad() returns " << TauDetails->seedTrk_etIsolHad());
3793 }
3794
3795 const Analysis::TauJet* tj = *tauIt;
3796 if ( tj->clusterLink().isValid() ) {
3797 ATH_MSG_INFO("REGTEST CaloCluster present");
3798 } else {
3799 ATH_MSG_INFO("REGTEST CaloCluster missing");
3800 }
3801
3802 if( TauDetails->looseTrk().size() !=0 ) {
3803 ATH_MSG_INFO("REGTEST TauDetails->looseTrk() link present ");
3804 } else {
3805 ATH_MSG_INFO("REGTEST TauDetails->looseTrk() link missing ");
3806 }
3807
3808 if ( tj->cellClusterLink().isValid() ) {
3809 ATH_MSG_INFO("REGTEST CellCaloCluster present");
3810 } else {
3811 ATH_MSG_INFO("REGTEST CellCaloCluster missing");
3812 }
3813
3814 if ( tj->jetLink().isValid() ) {
3815 ATH_MSG_INFO("REGTEST Jet present");
3816 } else {
3817 ATH_MSG_INFO("REGTEST Jet missing");
3818 }
3819
3820 if ( tj->jetLink().isValid() ) {
3821 ATH_MSG_INFO("REGTEST Jet present");
3822 } else {
3823 ATH_MSG_INFO("REGTEST Jet missing");
3824 }
3825
3826 ATH_MSG_INFO("REGTEST numTrack returns " << tj->numTrack());
3827
3828 if ( tj->trackLinkVector().size() != 0 ) {
3829 ATH_MSG_INFO("REGTEST TrackLinkVector present");
3830 } else {
3831 ATH_MSG_INFO("REGTEST TrackkLinkVector missing");
3832 }
3833
3834 ATH_MSG_INFO("REGTEST author returns " << tj->author());
3835 ATH_MSG_INFO("REGTEST ROIWord returns " << tj->author());
3836 }
3837 }
3838
3841 StatusCode sc = evtStore()->retrieve(TauJet, lastTauJet);
3842 if (sc.isFailure()) {
3843 ATH_MSG_INFO("REGTEST No TauJetContainer found");
3844 return StatusCode::FAILURE;
3845 }
3846 else ATH_MSG_DEBUG("Found TauJetContainer");
3847
3848 ATH_MSG_INFO("REGTEST TauJetContainer retrieved");
3849
3850 for ( ; TauJet != lastTauJet ; ++TauJet ) {
3851 ATH_MSG_INFO("REGTEST TauJetContainer key: " << TauJet.key());
3852 }
3853
3854 return StatusCode::SUCCESS;
3855}
3856
3858
3859 ATH_MSG_DEBUG("In dumpxAODTrackParticle()");
3860
3861 ATH_MSG_INFO("REGTEST ==========START of xAOD::TrackParticle DUMP===========");
3862
3863 std::vector<std::string> SGkeys;
3864 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Bjet_EFID");
3865 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Bphysics_EFID");
3866 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Electron_EFID");
3867 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_FullScan_EFID");
3868 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Muon_EFID");
3869 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Photon_EFID");
3870 SGkeys.push_back("HLT_xAOD__TrackParticleContainer_InDetTrigTrackingxAODCnv_Tau_EFID");
3871
3872 StatusCode returnsc = StatusCode::SUCCESS;
3873
3874 for (unsigned int SGkey = 0; SGkey < SGkeys.size(); ++SGkey) {
3875 const xAOD::TrackParticleContainer* trackParticleContainer=0;
3876 StatusCode sc = evtStore()->retrieve(trackParticleContainer,SGkeys.at(SGkey));
3877 if (sc.isFailure()) {
3878 ATH_MSG_INFO("REGTEST No track particle container found with key " << SGkeys.at(SGkey));
3879 continue;
3880 }
3881 ATH_MSG_INFO("REGTEST TrackParticleContainer retrieved with key " << SGkeys.at(SGkey)
3882 << " and size " << trackParticleContainer->size());
3883
3884 xAOD::TrackParticleContainer::const_iterator trackParticleItr = trackParticleContainer->begin();
3885 xAOD::TrackParticleContainer::const_iterator trackParticleLast = trackParticleContainer->end();
3886
3887 for (int index = 0; trackParticleItr != trackParticleLast; ++trackParticleItr, ++index) {
3888 ATH_MSG_INFO("REGTEST Looking at Track Particle " << index);
3889
3890 ATH_MSG_INFO("REGTEST IParticle functions:");
3891 ATH_MSG_INFO("REGTEST pt: " << (*trackParticleItr)->pt()
3892 << "/eta: " << (*trackParticleItr)->eta()
3893 << "/phi: " << (*trackParticleItr)->phi()
3894 << "/m: " << (*trackParticleItr)->m()
3895 << "/e: " << (*trackParticleItr)->e()
3896 << "/rapidity: " << (*trackParticleItr)->rapidity());
3897
3898 ATH_MSG_INFO("REGTEST Defining parameters functions:");
3899 ATH_MSG_INFO("REGTEST charge: " << (*trackParticleItr)->charge()
3900 << "/d0: " << (*trackParticleItr)->d0()
3901 << "/z0: " << (*trackParticleItr)->z0()
3902 << "/phi0: " << (*trackParticleItr)->phi0()
3903 << "/theta: " << (*trackParticleItr)->theta()
3904 << "/qOverP: " << (*trackParticleItr)->qOverP()
3905 << "/vx: " << (*trackParticleItr)->vx()
3906 << "/vy: " << (*trackParticleItr)->vy()
3907 << "/vz: " << (*trackParticleItr)->vz());
3908
3909 // Curvilinear functions skipped
3910
3911 ATH_MSG_INFO("REGTEST Fit quality functions:");
3912 ATH_MSG_INFO("REGTEST chiSquared: " << (*trackParticleItr)->chiSquared()
3913 << "/numberDoF: " << (*trackParticleItr)->numberDoF());
3914
3915 // TrackInfo functions skipped
3916
3917 ATH_MSG_INFO("REGTEST summaryValue variables:");
3918 msg() << MSG::INFO << "REGTEST ";
3919 uint8_t numberOfBLayerHits = 0;
3920 if ( (*trackParticleItr)->summaryValue(numberOfBLayerHits, xAOD::numberOfBLayerHits) ) {
3921 msg() << "/numberOfBLayerHits: " << static_cast<int>(numberOfBLayerHits);
3922 } else {
3923 msg() << "/numberOfBLayerHits not found";
3924 }
3925
3926 uint8_t numberOfPixelHits = 0;
3927 if ( (*trackParticleItr)->summaryValue(numberOfPixelHits, xAOD::numberOfPixelHits) ) {
3928 msg() << "/numberOfPixelHits: " << static_cast<int>(numberOfPixelHits);
3929 } else {
3930 msg() << "/numberOfPixelHits not found";
3931 }
3932
3933 uint8_t numberOfPixelHoles = 0;
3934 if ( (*trackParticleItr)->summaryValue(numberOfPixelHoles, xAOD::numberOfPixelHoles) ) {
3935 msg() << "/numberOfPixelHoles: " << static_cast<int>(numberOfPixelHoles);
3936 } else {
3937 msg() << "/numberOfPixelHoles not found";
3938 }
3939
3940 uint8_t numberOfSCTHits = 0;
3941 if ( (*trackParticleItr)->summaryValue(numberOfSCTHits, xAOD::numberOfSCTHits) ) {
3942 msg() << "/numberOfSCTHits: " << static_cast<int>(numberOfSCTHits);
3943 } else {
3944 msg() << "/numberOfSCTHits not found";
3945 }
3946
3947 uint8_t numberOfSCTHoles = 0;
3948 if ( (*trackParticleItr)->summaryValue(numberOfSCTHoles, xAOD::numberOfSCTHoles) ) {
3949 msg() << "/numberOfSCTHoles: " << static_cast<int>(numberOfSCTHoles);
3950 } else {
3951 msg() << "/numberOfSCTHoles not found";
3952 }
3953
3954 uint8_t numberOfTRTHits = 0;
3955 if ( (*trackParticleItr)->summaryValue(numberOfTRTHits, xAOD::numberOfTRTHits) ) {
3956 msg() << "/numberOfTRTHits: " << static_cast<int>(numberOfTRTHits);
3957 } else {
3958 msg() << "/numberOfTRTHits not found";
3959 }
3960
3961 uint8_t numberOfTRTHoles = 0;
3962 if ( (*trackParticleItr)->summaryValue(numberOfTRTHoles, xAOD::numberOfTRTHoles) ) {
3963 msg() << "/numberOfTRTHoles: " << static_cast<int>(numberOfTRTHoles);
3964 } else {
3965 msg() << "/numberOfTRTHoles not found";
3966 }
3967 msg() << endmsg;
3968 }
3969 }
3970
3971 ATH_MSG_INFO("REGTEST ==========END of xAOD::TrackParticle DUMP===========");
3972 ATH_MSG_DEBUG("dumpxAODTrackParticles() succeeded");
3973
3974 return returnsc;
3975}
3976
3978
3979 ATH_MSG_DEBUG("In dumpxAODVertex()");
3980
3981 ATH_MSG_INFO("REGTEST ==========START of xAOD::Vertex DUMP===========");
3982
3983 const xAOD::VertexContainer* vertexContainer=0;
3984 StatusCode sc = evtStore()->retrieve(vertexContainer,"HLT_xAOD__VertexContainer_xPrimVx");
3985 if (sc.isFailure()) {
3986 ATH_MSG_INFO("REGTEST No vertex container");
3987 return StatusCode::FAILURE;
3988 }
3989 ATH_MSG_INFO("REGTEST VertexContainer retrieved");
3990
3991 xAOD::VertexContainer::const_iterator vertexItr = vertexContainer->begin();
3992 xAOD::VertexContainer::const_iterator vertexLast = vertexContainer->end();
3993
3994 for (int index = 0; vertexItr != vertexLast; ++vertexItr, ++index) {
3995 ATH_MSG_INFO("REGTEST Looking at Vertex " << index);
3996
3997 ATH_MSG_INFO("REGTEST Public Member Functions:");
3998 ATH_MSG_INFO("REGTEST x: " << (*vertexItr)->x()
3999 << "/y: " << (*vertexItr)->y()
4000 << "/z: " << (*vertexItr)->z());
4001
4002 ATH_MSG_INFO("REGTEST Public Member Functions:");
4003 ATH_MSG_INFO("REGTEST chiSquared: " << (*vertexItr)->chiSquared()
4004 << "/numberDoF: " << (*vertexItr)->numberDoF());
4005 }
4006
4007 ATH_MSG_INFO("REGTEST ==========END of xAOD::Vertex DUMP===========");
4008 ATH_MSG_DEBUG("dumpxAODVertex() succeeded");
4009
4010 return StatusCode::SUCCESS;
4011}
4012
4014 using namespace TrigCompositeUtils; // LinkInfo
4015 ATH_MSG_INFO( "REGTEST ==========START of TDT DUMP===========" );
4016 // Note: This minimal TDT dumper is for use during run-3 dev
4017 std::string chain = m_dumpNavForChain;
4018 if (chain.empty()) {
4019 chain = "HLT_.*";
4020 }
4021 std::vector<std::string> confChains = m_trigDec->getListOfTriggers(chain);
4022 for (const auto& item : confChains) {
4023 bool passed = m_trigDec->isPassed(item);
4024 ATH_MSG_INFO(" HLT Item " << item << " (numeric ID " << TrigConf::HLTUtils::string2hash(item, "Identifier") << ") passed raw? " << passed);
4025 if (m_trigDec->getNavigationFormat() == "TriggerElement") {
4026 ATH_MSG_DEBUG(" Skipping Run 2 features in this dumper");
4027 continue;
4028 }
4029 std::vector< LinkInfo<xAOD::IParticleContainer> > passFeatures = m_trigDec->features<xAOD::IParticleContainer>(item);
4030 if (passFeatures.size()) {
4031 ATH_MSG_INFO(" " << item << " Passed Final IParticle features size: " << passFeatures.size());
4032 for (const LinkInfo<xAOD::IParticleContainer>& li : passFeatures) {
4033 if (!li.isValid()) {
4034 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4035 } else {
4036 try {
4037 std::string state = "ACTIVE";
4038 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4039 else if (li.state == ActiveState::UNSET) state = "UNSET";
4040 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4041 } catch (const std::exception& e) {
4042 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4043 }
4044 }
4045 }
4046 }
4047 std::vector< LinkInfo<xAOD::IParticleContainer> > passAndFailFeatures = m_trigDec->features<xAOD::IParticleContainer>(item, TrigDefs::includeFailedDecisions);
4048 if (passAndFailFeatures.size()) {
4049 ATH_MSG_INFO(" " << item << " Passed+Failed Final IParticle features size: " << passAndFailFeatures.size());
4050 for (const LinkInfo<xAOD::IParticleContainer>& li : passAndFailFeatures) {
4051 if (!li.isValid()) {
4052 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4053 } else {
4054 try {
4055 std::string state = "ACTIVE";
4056 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4057 else if (li.state == ActiveState::UNSET) state = "UNSET";
4058 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4059 } catch (const std::exception& e) {
4060 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4061 }
4062 }
4063 }
4064 }
4065 std::vector< LinkInfo<xAOD::IParticleContainer> > allFeatures = m_trigDec->features<xAOD::IParticleContainer>(item, TrigDefs::includeFailedDecisions, "", TrigDefs::allFeaturesOfType);
4066 if (allFeatures.size()) {
4067 ATH_MSG_INFO(" " << item << " Passed+Failed ALL IParticle features size: " << allFeatures.size());
4068 for (const LinkInfo<xAOD::IParticleContainer>& li : allFeatures) {
4069 if (!li.isValid()) {
4070 ATH_MSG_WARNING(" Unable to access feature - link invalid.");
4071 } else {
4072 try {
4073 std::string state = "ACTIVE";
4074 if (li.state == ActiveState::INACTIVE) state = "INACTIVE";
4075 else if (li.state == ActiveState::UNSET) state = "UNSET";
4076 ATH_MSG_INFO(" IParticle Feature from " << li.link.dataID() << " index:" << li.link.index() << " pt:" << (*li.link)->pt() << " eta:" << (*li.link)->eta() << " phi:" << (*li.link)->phi() << " state:" << state);
4077 } catch (const std::exception& e) {
4078 ATH_MSG_WARNING(" Unable to dereference feature {" << e.what() << "}");
4079 }
4080 }
4081 }
4082 }
4083 }
4084
4085 if (m_trigDec->getNavigationFormat() == "TrigComposite") {
4086 // Check associateToEventView helper function
4087 std::vector< LinkInfo<xAOD::IParticleContainer> > muons = m_trigDec->features<xAOD::IParticleContainer>("HLT_mu24_idperf_L1MU20", TrigDefs::Physics, "HLT_MuonL2CBInfo");
4088 SG::ReadHandle<xAOD::TrackParticleContainer> muonTracksReadHandle(m_muonTracksKey, Gaudi::Hive::currentContext());
4089 for (const LinkInfo<xAOD::IParticleContainer>& mu : muons) {
4090 // Note: auto here refers to type std::pair< xAOD::TrackParticleContainer::const_iterator, xAOD::TrackParticleContainer::const_iterator>
4091 const auto roiTrackItPair = m_trigDec->associateToEventView<xAOD::TrackParticleContainer>(muonTracksReadHandle, mu, "roi");
4092 const xAOD::TrackParticleContainer::const_iterator startIt = roiTrackItPair.first;
4093 const xAOD::TrackParticleContainer::const_iterator stopIt = roiTrackItPair.second;
4094 ATH_MSG_INFO("Muon pT: " << (*mu.link)->pt() << " is from the same ROI as tracks with index "
4095 << std::distance(muonTracksReadHandle->begin(), startIt) << "-" << std::distance(muonTracksReadHandle->begin(), stopIt)
4096 << ", which is " << std::distance(startIt, stopIt) << " tracks, out of " << muonTracksReadHandle->size() << " total tracks.");
4097 for (xAOD::TrackParticleContainer::const_iterator it = startIt; it != stopIt; ++it) {
4098 ATH_MSG_VERBOSE(" -- Track " << std::distance(startIt, it) << " in this ROI, pT: " << (*it)->pt() );
4099 }
4100 }
4101 }
4102
4103 ATH_MSG_INFO( "REGTEST ==========END of TDT DUMP===========" );
4104 return StatusCode::SUCCESS;
4105}
4106
4108 ATH_MSG_INFO( "REGTEST ==========START of xAOD::TrigCompositeContainer DUMP===========" );
4109
4112 const CLID TrigCompositeCLID = static_cast<CLID>( ClassID_traits< xAOD::TrigCompositeContainer >::ID() );
4113 evtStore()->keys(TrigCompositeCLID, m_dumpTrigCompositeContainers);
4114 std::string typeNameTC;
4115 ATH_CHECK(m_clidSvc->getTypeNameOfID(TrigCompositeCLID, typeNameTC));
4116 ATH_MSG_DEBUG("dumpTrigComposite got " << m_dumpTrigCompositeContainers.size() << " keys for " << typeNameTC);
4117 } else {
4118 ATH_MSG_DEBUG("Using supplied " << m_dumpTrigCompositeContainers.size() << " keys");
4119 }
4120
4121 for ( const std::string & key: m_dumpTrigCompositeContainers ) {
4122 // get the collection
4124 ATH_MSG_WARNING("Absent TrigCompositeContainer: " << key );
4125 continue;
4126 }
4127 ATH_MSG_DEBUG( "#################### Dumping container of : " << key );
4128 const xAOD::TrigCompositeContainer* cont= nullptr;
4129 ATH_CHECK( evtStore()->retrieve( cont, key ) );
4130
4131 size_t count = 0;
4132 for ( auto tc: *cont ) {
4133 ATH_MSG_DEBUG("########## ELEMENT " << count++);
4134 ATH_MSG_DEBUG(*tc);
4135 // Get the objects we know of
4136 for (size_t i = 0; i < tc->linkColNames().size(); ++i) ATH_CHECK(checkTrigCompositeElementLink(tc, i));
4137 }
4138 }
4139 ATH_MSG_INFO( "REGTEST ==========END of xAOD::TrigCompositeContainer DUMP===========" );
4140 return StatusCode::SUCCESS;
4141}
4142
4143
4144
4146
4147 const std::string name = tc->linkColNames().at(element);
4148 const CLID clid = static_cast<CLID>(tc->linkColClids().at(element));
4149
4151
4152 const ElementLink<TrigRoiDescriptorCollection> elementLink = tc->objectLink<TrigRoiDescriptorCollection>(name);
4153 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to TrigRoiDescriptorCollection, link name:'" << name << "'");
4154 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "'' to TrigRoiDescriptor:" << *elementLink);
4155
4156 } else if (clid == ClassID_traits< DataVector< LVL1::RecEmTauRoI > >::ID()) { // There could be a few ROI types....
4157 // CLASS_DEF( DataVector< LVL1::RecEmTauRoI >, 6256, 1 )
4158
4160 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to LVL1::RecEmTauRoI, link name:'" << name << "'");
4161 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to LVL1::RecEmTauRoI:" << *elementLink);
4162
4164
4165 const ElementLink<xAOD::TrigCompositeContainer> elementLink = tc->objectLink<xAOD::TrigCompositeContainer>(name);
4166 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to TrigComposite, link name:'" << name << "'");
4167 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to TrigComposite, TC name:'" << (*elementLink)->name() << "'");
4168
4169 } else if (clid == ClassID_traits< ViewContainer >::ID()) {
4170
4171 const ElementLink<ViewContainer> elementLink = tc->objectLink<ViewContainer>(name);
4172 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to View, link name:'" << name << "'");
4173 else ATH_MSG_DEBUG(" Dereferenced link '" << name << "' to View:'" << *elementLink);
4174
4175 } else if (name == "feature") {
4176
4178
4179 const ElementLink<xAOD::TrigEMClusterContainer> elementLink = tc->objectLink<xAOD::TrigEMClusterContainer>(name);
4180 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to xAOD::TrigEMClusterContainer 'feature'");
4181 else ATH_MSG_DEBUG(" Dereferenced xAOD::TrigEMClusterContainer link 'feature', Energy:" << (*elementLink)->energy());
4182
4184
4185 const ElementLink<xAOD::TrigMissingETContainer> elementLink = tc->objectLink<xAOD::TrigMissingETContainer>(name);
4186 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to xAOD::TrigMissingETContainer 'feature'");
4187 else ATH_MSG_DEBUG(" Dereferenced xAOD::TrigMissingETContainer link 'feature', ex:" << (*elementLink)->ex() << " ey:" << (*elementLink)->ey());
4188
4189 } else {
4190
4191 try {
4192 const ElementLink<xAOD::IParticleContainer> elementLink = tc->objectLink<xAOD::IParticleContainer>(name);
4193 if (!elementLink.isValid()) ATH_MSG_WARNING(" Invalid element link to 'feature'");
4194 else ATH_MSG_DEBUG(" Dereferenced IParticle link 'feature', pt:" << (*elementLink)->pt() << " eta:" << (*elementLink)->eta() << " phi:" << (*elementLink)->phi());
4195 } catch(std::runtime_error& e) {
4196 ATH_MSG_WARNING(" Cannot dereference 'feature' as IParticle: '" << e.what() << "'");
4197 }
4198
4199 }
4200
4201 } else {
4202 ATH_MSG_DEBUG(" Ignoring link to '" << name << "' with link CLID " << clid);
4203 }
4204
4205 return StatusCode::SUCCESS;
4206
4207}
4208
4209
4210StatusCode TrigEDMChecker::TrigCompositeNavigationToDot(std::string& returnValue, bool& pass) {
4211
4212 using namespace TrigCompositeUtils;
4213
4214 // This constexpr is evaluated at compile time
4215 const CLID TrigCompositeCLID = static_cast<CLID>( ClassID_traits< xAOD::TrigCompositeContainer >::ID() );
4216 std::vector<std::string> keys;
4217 if ( m_dumpTrigCompositeContainers.size() == 0 ) {
4218 evtStore()->keys(TrigCompositeCLID, keys);
4219 }
4220 else {
4222 }
4223 std::string typeNameTC;
4224 ATH_CHECK(m_clidSvc->getTypeNameOfID(TrigCompositeCLID, typeNameTC));
4225 ATH_MSG_DEBUG("Got " << keys.size() << " keys for " << typeNameTC);
4226
4228 DecisionIDContainer chainIDs;
4229 chainIDs.insert( chainID.numeric() );
4230
4231 std::set<int> converted;
4232
4233 const Trig::ChainGroup* cg = m_trigDec->getChainGroup(m_dumpNavForChain);
4235 std::vector<std::string> chains = cg->getListOfTriggers();
4236 for (const std::string& chain : chains) {
4237 const TrigConf::HLTChain* hltChain = m_trigDec->ExperimentalAndExpertMethods().getChainConfigurationDetails(chain);
4238 const HLT::Identifier chainID_tmp( hltChain->chain_name() );
4239 chainIDs.insert( chainID_tmp.numeric() );
4240 const std::vector<size_t> legMultiplicites = hltChain->leg_multiplicities();
4241 if (legMultiplicites.size() == 0) {
4242 ATH_MSG_ERROR("chain " << chainID_tmp << " has invalid configuration, no multiplicity data.");
4243 } else if (legMultiplicites.size() > 1) {
4244 // For multi-leg chains, the DecisionIDs are handled per leg.
4245 // We don't care here exactly how many objects are required per leg, just that there are two-or-more legs
4246 for (size_t legNumeral = 0; legNumeral < legMultiplicites.size(); ++legNumeral) {
4247 const HLT::Identifier legID = TrigCompositeUtils::createLegName(chainID_tmp, legNumeral);
4248 chainIDs.insert( legID.numeric() );
4249 }
4250 }
4251 }
4252
4253 // First retrieve them all (this should not be needed in future)
4254 const DecisionContainer* container = nullptr;
4255 for (const std::string& key : keys) ATH_CHECK( evtStore()->retrieve( container, key ) );
4256
4257 std::stringstream ss;
4258 ss << "digraph {" << std::endl;
4259 ss << " node [shape=rectangle]" << std::endl;
4260 ss << " rankdir = BT" << std::endl;
4261
4262 // Now process them
4263 for (const std::string& key : keys) {
4264 if ( not m_doDumpAllTrigComposite ) {
4265 if ( not key.starts_with( "HLTNav_") ) { // Nav containers should always start with HLTNav_
4266 continue;
4267 }
4268 }
4269 ATH_CHECK( evtStore()->retrieve( container, key ) );
4270 ATH_MSG_DEBUG("Processing collection " << key << " to be added to the navigation graph");
4271 // ss << " rank=same" << std::endl; // dot cannot handle this is seems
4272 bool writtenHeader = false;
4273 for (const Decision* tc : *container ) {
4274 // Output my ID in the graph.
4275 const DecisionContainer* container = dynamic_cast<const DecisionContainer*>( tc->container() );
4276 const ElementLink<DecisionContainer> selfEL = ElementLink<DecisionContainer>(*container, tc->index());
4277 std::vector<ElementLink<DecisionContainer>> seedELs = tc->objectCollectionLinks<DecisionContainer>("seed");
4278 const bool isHypoAlgNode = tc->name() == "H";
4279 const bool isComboHypoAlgNode = tc->name() == "CH";
4280 const std::vector<DecisionID>& decisions = tc->decisions();
4281 const uint32_t selfKey = selfEL.key();
4282 const uint32_t selfIndex = selfEL.index();
4283 if (m_dumpNavForChain != "") {
4284 bool doDump = false;
4285 // Check me
4286 for (DecisionID id : decisions) {
4287 if (chainIDs.count(id) == 1) {
4288 doDump = true;
4289 break;
4290 }
4291 }
4292 // Check my seeds
4293 if (!doDump and (isHypoAlgNode or isComboHypoAlgNode) and not m_excludeFailedHypoNodes) {
4294 for (const ElementLink<DecisionContainer>& s : seedELs) {
4295 const std::vector<DecisionID>& seedDecisions = (*s)->decisions();
4296 for (DecisionID id : seedDecisions) {
4297 if (chainIDs.count(id) == 1) {
4298 doDump = true;
4299 break;
4300 }
4301 }
4302 }
4303 }
4304 if (!doDump) {
4305 continue;
4306 }
4307 }
4308 if (!writtenHeader) {
4309 writtenHeader = true;
4310 ss << " subgraph " << key << " {" << std::endl;
4311 ss << " label=\"" << key << "\"" << std::endl;
4312 }
4313 const std::string scheme = "rdpu9";
4314 std::string color = "1";
4315 if (tc->name() == "L1") { color = "1"; }
4316 else if (tc->name() == "F") { color = "2"; }
4317 else if (tc->name() == "IM") { color = "3"; }
4318 else if (tc->name() == "H") { color = "4"; }
4319 else if (tc->name() == "CH") { color = "5"; }
4320 else if (tc->name() == "SF") { color = "6"; }
4321 else if (tc->name() == "HLTPassRaw") { color = "7"; }
4322 ss << " \"" << selfKey << "_" << selfIndex << "\" [colorscheme="<<scheme<<",style=filled,fillcolor="<<color<<",label=<<B>Container</B>=" << typeNameTC;
4323 if (tc->name() != "") ss << " <B>Name</B>=" << tc->name();
4324 ss << "<BR/><B>Key</B>=" << key << "<BR/><B>Index</B>=" << selfIndex;
4325 const bool isRemapped = tc->isRemapped();
4326 if (isHypoAlgNode) ss << " <B>linksRemapped</B>=" << (isRemapped ? "Y" : "N");
4327 if (decisions.size() > 0) {
4328 ss << "<BR/><B>Pass</B>=";
4329 size_t c = 0;
4330 for (unsigned decisionID : decisions) {
4331 HLT::Identifier dID(decisionID);
4332 std::string highlight = (dID.numeric() == chainID.numeric() ? "<B>[CHAIN:" : "");
4333 if (highlight == "" and chainIDs.count(dID.numeric()) == 1 and TrigCompositeUtils::isLegId(dID)) {
4334 highlight = "<B>[LEG" + std::to_string(TrigCompositeUtils::getIndexFromLeg(dID)) + ":";
4335 }
4336 ss << std::hex << highlight << decisionID << (!highlight.empty() ? "]</B>" : "") << std::dec << ",";
4337 if (c++ == 5) {
4338 ss << "<BR/>";
4339 c = 0;
4340 }
4341 }
4342 }
4343 ss << ">]" << std::endl;
4344 // Output all the things I link to
4345 size_t seedCount = 0;
4346 for (size_t i = 0; i < tc->linkColNames().size(); ++i) {
4347 const std::string link = tc->linkColNames().at(i);
4348 if (link == "seed" || link == "seed__COLL") {
4349 ElementLink<DecisionContainer> seedEL = seedELs.at(seedCount++);
4350 const uint32_t seedKey = tc->linkColKeys().at(i);
4351 const uint32_t seedIndex = tc->linkColIndices().at(i);
4352 ATH_CHECK( seedKey == seedEL.key() );
4353 ATH_CHECK( seedIndex == seedEL.index() );
4354 if (m_dumpNavForChain != "") { // Only print "seed" link to nodes we include in our search
4355 const std::vector<DecisionID> seedDecisions = (*seedEL)->decisions();
4356 bool doSeedLink = false;
4357 for (DecisionID id : seedDecisions) {
4358 if (chainIDs.count(id) == 1) {
4359 doSeedLink = true;
4360 break;
4361 }
4362 }
4363 if (!doSeedLink) {
4364 continue;
4365 }
4366 }
4367 ss << " \"" << selfKey << "_" << selfIndex << "\" -> \"" << seedKey << "_" << seedIndex << "\" [colorscheme="<<scheme<<",color=9,fontcolor=8,label=\"seed\"]" << std::endl;
4368 } else {
4369 // Start with my class ID
4370 std::string linkColour = "12";
4371 std::string linkBackground = "11";
4372 const std::string extScheme = "paired12";
4373 if (link == "roi") { linkColour="2"; linkBackground="1"; }
4374 else if (link == "initialRoI") { linkColour="2"; linkBackground="1"; }
4375 else if (link == "initialRecRoI") { linkColour="8"; linkBackground="7"; }
4376 else if (link == "feature") { linkColour="4"; linkBackground="3"; }
4377 else if (link == "view") { linkColour="10"; linkBackground="9"; }
4378 const CLID linkCLID = static_cast<CLID>( tc->linkColClids().at(i) );
4379 // Use it to get my class name
4380 std::string tname;
4381 ATH_CHECK(m_clidSvc->getTypeNameOfID(linkCLID, tname));
4382 // Now get the sgkey I'm linking to & the index
4383 const SG::sgkey_t key = (isRemapped ? static_cast<SG::sgkey_t>( tc->linkColKeysRemap().at(i) ) : static_cast<SG::sgkey_t>( tc->linkColKeys().at(i) ));
4384 const unsigned index = (isRemapped ? tc->linkColIndicesRemap().at(i) : tc->linkColIndices().at(i));
4385 // Look it up
4386 CLID checkCLID;
4387 const std::string* keyStr = evtStore()->keyToString(key, checkCLID); // I don't own this str
4388 if (keyStr != nullptr && checkCLID != linkCLID) {
4389 std::string tnameOfCheck;
4390 m_clidSvc->getTypeNameOfID(checkCLID, tnameOfCheck).ignore(); // Might be invalid. But we don't care.
4391 ATH_MSG_ERROR("Inconsistent CLID " << checkCLID << " [" << tnameOfCheck << "] stored in storegate for key " << key
4392 << ". We were expecting " << linkCLID << " [" << tname << "]");
4393 }
4394
4395 std::string tnameEscape;
4396 for (std::string::const_iterator i = tname.begin(); i != tname.end(); ++i) {
4397 unsigned char c = *i;
4398 if (c == '<') {
4399 tnameEscape += "&lt;";
4400 } else if (c == '>') {
4401 tnameEscape += "&gt;";
4402 } else {
4403 tnameEscape += c;
4404 }
4405 }
4406
4407 // Print
4408 ss << " \"" << selfKey << "_" << selfIndex << "\" -> \"" << key << "_" << index << "\" ";
4409 ss << "[colorscheme="<<extScheme<<",color="<<linkColour<<",fontcolor="<<linkColour<<",arrowhead=empty,label=\"" << link << "\"]" << std::endl;
4410
4411 // Check if we are linking to self (e.g. a dummy-feature), don't output a new box for this
4412 const bool linkToSelf = (selfKey == key and selfIndex == index);
4413
4414 if (converted.count(key + index) == 0 and not linkToSelf) {
4415 ss << " \"" << key << "_" << index << "\" [colorscheme="<<extScheme<<",style=filled,fillcolor="<<linkBackground<<",label=<<B>Container</B>=" << tnameEscape << "<BR/><B>Key</B>=";
4416 if (keyStr != nullptr) ss << *keyStr;
4417 else ss << "[<I>KEY "<< key <<" NOT IN STORE</I>] ";
4418 ss << "<BR/><B>Index</B>=" << index << ">]";
4419 }
4420
4421 converted.insert(key + index);
4422 }
4423 }
4424 }
4425 if (writtenHeader) {
4426 ss << " }" << std::endl;
4427 }
4428 }
4429
4430 ss << "}" << std::endl;
4431
4432 returnValue.assign( ss.str() );
4433 return StatusCode::SUCCESS;
4434}
4435
4436StatusCode TrigEDMChecker::dumpNavigation(const EventContext& ctx)
4437{
4438 // Get object from store
4439 const xAOD::TrigNavigation * navigationHandle = nullptr;
4440 ATH_CHECK( evtStore()->retrieve( navigationHandle, m_navigationHandleKey.key() ) );
4441 // Proper version doesn't work - conversion issue?
4442 //SG::ReadHandle< xAOD::TrigNavigation > navigationHandle = SG::ReadHandle< xAOD::TrigNavigation >( m_navigationHandleKey );
4443 //if ( !navigationHandle.isValid() ) ATH_MSG_FATAL( "Could not retrieve navigation" );
4444
4445 // Get serialised navigation info
4446 const std::vector< unsigned int > serialisedNavigation = navigationHandle->serialized();
4447 ATH_MSG_INFO( "Serialised navigation size: " << serialisedNavigation.size() );
4448
4449 // Convert the input
4450 HLT::Navigation* testNav = m_navigationTool.get();
4451 testNav->deserialize( serialisedNavigation );
4452
4453 // Make a map of TE name hashes
4454 const xAOD::TriggerMenuContainer * testMenu = nullptr;
4455 ATH_CHECK( inputMetaStore()->retrieve( testMenu, "TriggerMenu" ) );
4456 std::map< int, std::string > hash2string;
4457 for ( auto const& sequence : testMenu->front()->sequenceInputTEs() ) {
4458 for ( auto const& name : sequence ) {
4460 hash2string[ hash ] = name;
4461 }
4462 }
4463
4464 // Map TE names to chain names
4465 unsigned int chainCounter = 0;
4466 std::map< int, std::string > hash2chain;
4467 for ( auto const& chain : testMenu->front()->chainSignatureOutputTEs() ) {
4468
4469 // Find the chain name
4470 std::string chainName = testMenu->front()->chainNames()[ chainCounter ];
4471 ++chainCounter;
4472
4473 // Find all associated TEs
4474 for ( auto const& signature : chain ) {
4475 for ( auto const& name : signature ) {
4477 hash2string[ hash ] = name; // for decoding
4478 hash2chain[ hash ] = chainName;
4479 }
4480 }
4481 }
4482
4483 // Define a map of TE features, to the TEs that use them. Needs a custom sort lambda
4484 auto cmpLambda = []( const HLT::TriggerElement::FeatureAccessHelper &lhs, const HLT::TriggerElement::FeatureAccessHelper &rhs) {
4485
4486 // Compare indices if CLID matches
4487 if ( lhs.getCLID() == rhs.getCLID() ) return ( lhs.getIndex() < rhs.getIndex() );
4488
4489 // Compare CLIDs
4490 else return ( lhs.getCLID() < rhs.getCLID() );
4491 };
4492 std::map< HLT::TriggerElement::FeatureAccessHelper, std::vector< HLT::TriggerElement* >, decltype(cmpLambda) > feature2element(cmpLambda);
4493
4494 // Retrieve all TE features and add them to the map
4495 std::vector< HLT::TriggerElement* > allTEs;
4496 testNav->getAll( allTEs, false );
4497 for ( auto element : allTEs ) {
4498
4499 // Add TE features to the big map
4500 for ( auto helper : element->getFeatureAccessHelpers() ) {
4501 feature2element[ helper ].push_back( element );
4502 }
4503 }
4504
4505 // Debug - output all TEs and their ancestors
4506 // No duplication - only print terminal nodes
4507 for ( auto element : allTEs ) {
4508 if ( testNav->isTerminalNode( element ) ) {
4509 ATH_MSG_INFO( "+++++++++++ " << hash2string[ element->getId() ] << " is terminal node" );
4510 ATH_MSG_INFO( "ptr: " << element );
4511 std::queue< HLT::TriggerElement* > allAncestors;
4512 allAncestors.push( element );
4513 while ( allAncestors.size() ) {
4514
4515 HLT::TriggerElement * thisElement = allAncestors.front();
4516 allAncestors.pop();
4517 auto theseAncestors = thisElement->getRelated( HLT::TriggerElement::Relation::seededByRelation );
4518
4519 // Dump TE
4520 ATH_MSG_INFO( "te: " << thisElement->getId() << " " << hash2string[ thisElement->getId() ] );
4521 ATH_MSG_INFO( " chain: " << hash2chain[ thisElement->getId() ] );
4522 for ( const auto& helper : thisElement->getFeatureAccessHelpers() ) {
4523 ATH_MSG_INFO( " feat: " << helper );
4524 }
4525 ATH_MSG_INFO( theseAncestors.size() << " ancestors" );
4526
4527 // Examine ancestors
4528 for ( auto ancestor : theseAncestors ) {
4529 allAncestors.push( ancestor );
4530 }
4531 }
4532 }
4533 }
4534
4535 // Make the decision container
4537 auto decisionOutput = outputNavigation.ptr();
4538
4539 // Find unique chains associated with a feature
4540 std::map< HLT::TriggerElement const*, std::vector< int > > element2decisions;
4541 for ( const auto& pair : feature2element ) {
4542
4543 // Get the feature info
4544 std::string featureName = testNav->label( pair.first.getCLID(), pair.first.getIndex().subTypeIndex() );
4545 auto sgKey = evtStore()->stringToKey( featureName, pair.first.getCLID() );
4546
4547 // Store RoIs with appropriate label ?
4548 std::string storeFeatureName = "feature";
4549/* if ( pair.first.getCLID() == ClassID_traits< TrigRoiDescriptor >::ID() ) {
4550 storeFeatureName = "roi";
4551 }*/
4552
4553 // Make a decision object for the feature
4554 auto decision = TrigCompositeUtils::newDecisionIn( decisionOutput );
4555 decision->typelessSetObjectLink( storeFeatureName, sgKey, pair.first.getCLID(), pair.first.getIndex().objectsBegin(), pair.first.getIndex().objectsEnd() );
4556
4557 // Examine associated TEs, look for chains
4558 std::set< std::string > passedChains;
4559 for ( HLT::TriggerElement const* element : pair.second ) {
4560
4561 // TODO - find out what chains actually passed!
4562 passedChains.insert( hash2chain[ element->getId() ] );
4563
4564 // Index the TE
4565 int decisionNumber = decisionOutput->size() - 1;
4566 element2decisions[ element ].push_back( decisionNumber );
4567 }
4568
4569 // Store unique chains in the decision
4570 for ( auto& chain : passedChains ) {
4572 }
4573 }
4574
4575 // Store decision ancestry (had to go through once before to ensure indices populated)
4576 unsigned int decisionCounter = 0;
4577 for ( const auto& pair : feature2element ) {
4578
4579 // Get current decision
4580 auto decision = decisionOutput->at( decisionCounter );
4581 ++decisionCounter;
4582
4583 // Find ancestor TEs
4584 for ( auto element : pair.second ) {
4585 auto theseAncestors = element->getRelated( HLT::TriggerElement::Relation::seededByRelation );
4586 for ( auto ancestor : theseAncestors ) {
4587 for ( int decisionIndex : element2decisions[ ancestor ] ) {
4588 TrigCompositeUtils::linkToPrevious( decision, m_decisionsKey.key(), decisionIndex );
4589 }
4590 }
4591 }
4592 }
4593
4594 return StatusCode::SUCCESS;
4595}
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method
Scalar theta() const
theta method
#define endmsg
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
#define ATH_MSG_INFO(x)
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
Helper functions intended to be called from the debugger.
uint32_t CLID
The Class ID type.
ElementLink< xAOD::TrackParticleContainer > linkTrack(const xAOD::TrackParticle *trk)
This file defines helper classes to deal with jet constituents.
bool passed(DecisionID id, const DecisionIDContainer &)
checks if required decision ID is in the set of IDs in the container
unsigned int uint
static Double_t ss
static Double_t tc
static Double_t sc
unsigned int DecisionID
std::set< DecisionID > DecisionIDContainer
xAOD::TrigCompositeContainer DecisionContainer
void diff(const Jet &rJet1, const Jet &rJet2, std::map< std::string, double > varDiff)
Difference between jets - Non-Class function required by trigger.
Definition Jet.cxx:631
Declaration of tau jet transient class.
size_t size() const
Number of registered mappings.
static const int maxRepWarnings
Adapted from code by A.Hamilton to check trigger EDM; R.Goncalo 21/11/07.
StatusCode TrigEDMChecker::dumpTrigMissingET ATLAS_NOT_THREAD_SAFE()
Install fatal handler with default options.
@ TauJet
DataVector< SG::View > ViewContainer
View container for recording in StoreGate.
Definition View.h:290
Define macros for attributes used to control the static checker.
#define ATLAS_THREAD_SAFE
Basic detail class containing information for track and calo seeded tau reconstruction algorithms.
Object for taus common for ESD and AOD.
const ElementLink< CaloClusterContainer > cellClusterLink() const
ElementLink to cell CaloCluster, might be invalid the ID variables are calculated from this cluster i...
unsigned int numTrack() const
number of Tracks associated to Tau candidate, CAUTION not to be confused with numberOfTracks()!
const ElementLinkVector< Rec::TrackParticleContainer > & trackLinkVector() const
Get track link vector.
const ElementLink< CaloClusterContainer > clusterLink() const
ElementLink to seed CaloCluster, DEPRECATED as of release 13
const ElementLink< JetCollection > jetLink() const
ElementLink to seed Jet, might be invalid if not seeded from a Jet
TauJetParameters::Author author() const
Author of this object (DO NOT USE! only for backward compatibility).
const ServiceHandle< StoreGateSvc > & inputMetaStore() const
Const accessor for the input metadata store.
AthAnalysisAlgorithm(const std::string &name)
Constructor taking just a name.
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
ServiceHandle< StoreGateSvc > & evtStore()
hash_t hash(const std::string &histName) const
Method to calculate a 32-bit hash from a string.
const ElementLink< MuonFeatureContainer > & muFastTrackLink(void) const
const ElementLink< TrigInDetTrackCollection > & IDTrackLink(void) const
Derived DataVector<T>.
Definition DataVector.h:795
DataModel_detail::const_iterator< DataVector > const_iterator
Definition DataVector.h:838
const T * at(size_type n) const
Access an element, as an rvalue.
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
size_type size() const noexcept
Returns the number of elements in the collection.
HLT::HLTResult is sumarising result of trigger decision evaluation (online/offline) It contains basic...
Definition HLTResult.h:49
bool isAccepted() const
gets HLT decision
Definition HLTResult.h:129
bool isPassThrough() const
forced-accepted (FA) event configuration the FA request(s) are set per chain and hlt level by the tig...
Definition HLTResult.h:144
bool isEmpty() const
true if result is empty
unsigned int size() const
TrigCompositeUtils::DecisionID numeric() const
numeric ID
bool deserialize(const std::vector< uint32_t > &input)
The Navigation class, organizes TriggerElements into the tree structure.
Definition Navigation.h:100
void getAll(std::vector< TriggerElement * > &output, const bool activeOnly=true) const
The query returning a collection of all TriggerElements.
static bool isTerminalNode(const TriggerElement *te)
queries if node is terminal (no more TriggerElement are seeded by it)
std::string label(class_id_type clid, const index_or_label_type &sti_or_label) const
the FeatureAccessHelper is a class used to keep track of features attached to this TE.
const ObjectIndex & getIndex() const
index in the external ojects array
TriggerElement is the basic ingreedient of the interface between HLT algorithms and the navigation It...
const std::vector< TriggerElement * > & getRelated(Relation rel) const
returns reference to the likns to other TriggerElements related by relation r
const std::vector< FeatureAccessHelper > & getFeatureAccessHelpers() const
returns all features which ara attached to this TE
virtual double phi() const =0
phi in [-pi,pi[
virtual double pt() const =0
transverse momentum
virtual double p() const =0
momentum magnitude
virtual double eta() const =0
pseudo rapidity
Top level AOD object storing LVL1 RoIs.
Definition LVL1_ROI.h:43
const emtaus_type & getEmTauROIs() const
Get all the em/tau RoIs in the event.
Definition LVL1_ROI.h:65
float zeta(void) const
Definition MuonFeature.h:53
int saddress(void) const
Definition MuonFeature.h:47
float pt(void) const
Definition MuonFeature.h:48
int roiId(void) const
Definition MuonFeature.h:46
float beta(void) const
Definition MuonFeature.h:55
float phi(void) const
Definition MuonFeature.h:51
float dir_zeta(void) const
Definition MuonFeature.h:54
float radius(void) const
Definition MuonFeature.h:49
float dir_phi(void) const
Definition MuonFeature.h:52
float eta(void) const
Definition MuonFeature.h:50
virtual double pt() const
transverse momentum
virtual double pt() const
get pt data member
virtual double eta() const
get eta data member
virtual double phi() const
get phi data member
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
a const_iterator facade to DataHandle.
Definition SGIterator.h:164
pointer_type ptr()
Dereference the pointer.
const std::string & key() const
Get the key string with which the current object was stored.
Class to store TileMuId quantities.
Definition TileMu.h:25
float eta() const
Eta (computed as the average of the eta values of the TileCal cells where the muon goes through).
Definition TileMu.h:43
float phi() const
Phi (average value at the TileCal radius).
Definition TileMu.h:46
float quality() const
Quality flag (0 or 1): set to 0 if the "energy deposition path" is MIP like in all three samples (tig...
Definition TileMu.h:60
const std::vector< float > & enedep() const
Energy deposition by the muons in TileCal: 1st component: energy deposited in innermost layer (A cell...
Definition TileMu.h:54
HLT chain configuration information.
const std::vector< size_t > & leg_multiplicities() const
static HLTHash string2hash(const std::string &, const std::string &category="TE")
hash function translating TE names into identifiers
SG::WriteHandleKey< TrigCompositeUtils::DecisionContainer > m_decisionsKey
StatusCode dumpTrigInDetTrackCollection()
StatusCode dumpTrigPassBits()
virtual StatusCode execute(const EventContext &ctx) override
Execute method.
StatusCode dumpTrigEFBphysContainer()
bool m_doDumpxAODTrigMissingET
StatusCode dumpxAODTrackParticle()
StatusCode dumpNavigation(const EventContext &ctx)
ToolHandle< Rec::IMuonPrintingTool > m_muonPrinter
PublicToolHandle< Trig::TrigDecisionTool > m_trigDec
StatusCode dumpHLTResult()
StatusCode dumpTrigComposite()
Dump information on TrigComposite collections.
StatusCode dumpxAODTrigMinBias()
StatusCode dumpTrigL2BphysContainer()
bool m_doDumpTrigTauContainer
bool m_doDumpTrigVertexCollection
bool m_doDumpTrigEFBphysContainer
StatusCode TrigCompositeNavigationToDot(std::string &returnValue, bool &pass)
Construct graph of HLT navigation in Run-3.
StatusCode checkTrigCompositeElementLink(const xAOD::TrigComposite *tc, size_t element)
Dump details on element links within TrigComposites.
bool m_doDumpTrigPhotonContainer
bool m_doDumpxAODTrigEMClusterContainer
bool m_doDumpTrigMuonEFContainer
SG::ReadHandleKey< xAOD::TrigNavigation > m_navigationHandleKey
bool m_doDumpxAODTrigElectronContainer
StatusCode dumpLVL1_ROI()
StatusCode dumpxAODTrigMissingET()
ToolHandle< HLT::Navigation > m_navigationTool
ServiceHandle< ::IClassIDSvc > m_clidSvc
bool m_doDumpxAODElectronContainer
bool m_doDumpTrigL2BjetContainer
StatusCode dumpTrackParticleContainer()
bool m_doDumpTrigElectronContainer
StatusCode dumpxAODElectronContainer()
StatusCode dumpxAODPhotonContainer()
bool m_doDumpTrigEMClusterContainer
bool m_doDumpxAODTauJetContainer
StatusCode dumpxAODVertex()
bool m_doDumpTrigInDetTrackCollection
bool m_doDumpTrigL2BphysContainer
bool m_doDumpAll
a handle on Store Gate for access to the Event Store
std::vector< std::string > m_dumpTrigCompositeContainers
bool m_doDumpTrigEFBjetContainer
StatusCode dumpxAODTrigPhotonContainer()
bool m_doDumpTrigMuonEFIsolationContainer
void dumpTrigSpacePointCounts()
bool m_doDumpTrigTauTracksInfo
bool m_doDumpTrackParticleContainer
bool m_doDumpTrigMuonEFInfoContainer
bool m_doDumpCombinedMuonFeature
bool m_doDumpTileTrackMuFeature
bool m_doDumpTrigCompsiteNavigation
Gaudi::Property< bool > m_excludeFailedHypoNodes
bool m_doDumpxAODTrigPhotonContainer
bool m_doDumpxAODPhotonContainer
StatusCode dumpxAODMuonContainer()
TrigEDMChecker(const std::string &name, ISvcLocator *pSvcLocator)
bool m_doDumpxAODTrackParticle
virtual ~TrigEDMChecker()
bool m_doDumpxAODJetContainer
StatusCode dumpxAODTrigElectronContainer()
bool m_doDumpTrigTauClusterContainer
SG::ReadHandleKey< xAOD::TrackParticleContainer > m_muonTracksKey
bool m_doDumpxAODTrigEMCluster
bool m_doDumpAllTrigComposite
bool m_doDumpxAODMuonContainer
StatusCode dumpTDT()
void printMuonTrk(const TrigMuonEFTrack *muonTrack)
Gaudi::Property< std::string > m_dumpNavForChain
StatusCode dumpxAODJetContainer()
virtual StatusCode initialize() override
Class with calibrated variables for egamma clustering.
float ehad1() const
get hadronic Energy (first hadronic layer)
float weta2() const
get cluster width (based on a 3x5 cluster - 2nd layer)
float e277() const
get Energy in a 7x7 cluster (no calibration) around hottest cell
float fracs1() const
get Energy in a 7 strips (around hottest strip) minus energy in 3 strips divided by energy in 3 strip...
float Eta1() const
get Eta sampling 1 (strip layer)
float e237() const
get Energy in a 3x7 cluster (no calibration) around hottest cell
encapsulates LVL2 track parameters and covariance matrix The vector of track parameters consists of
void surfaceCoordinate(double c)
Setter: surface reference coordinate for non-perigee surfaces.
void eta(const double eta)
Setter: pseudorapidity.
void z0(const double z0)
Setter: longitudinal impact parameter.
double ea0() const
variance of transverse impact parameter
void phi0(const double phi0)
Setter: azimuthal angle of the momentum.
void a0(const double a0)
Setter: transverse impact parameter.
double eeta() const
variance of pseudorapidity
void surfaceType(TrigSurfaceType s)
Setter: surface type PERIGEE=0, BARREL=1, ENDCAP=2.
double ez0() const
variance of longitudinal impact parameter
void cov(const std::vector< double > *cov)
Setter: covariance matrix of track parameters.
double ephi0() const
variance of azimuthal angle of the momentum
double epT() const
variance of transverse momentum
void pT(const double pT)
Setter: transverse momentum.
const HepMcParticleLink * bestMatchSi(const TrigInDetTrack *p_trig_trk) const
int bestMatchSiHits(const TrigInDetTrack *p_trig_trk) const
bool hasTruth(const TrigInDetTrack *p_trig_trk) const
methods to get truth-match objects
int bestMatchTRTHits(const TrigInDetTrack *p_trig_trk) const
const HepMcParticleLink * bestMatchTRT(const TrigInDetTrack *p_trig_trk) const
const TrigInDetTrackTruth * truth(const TrigInDetTrack *p_trig_trk) const
unsigned int nrMatches() const
returns number of matching particles
represents a LVL2 ID track
const Rec::TrackParticle * getIDTrackParticle() const
Get associated ID track.
TrigMuonEFCbTrack * CombinedTrack()
unsigned short int MuonType() const
TrigMuonEFTrack * ExtrapolatedTrack()
TrigMuonEFTrack * SpectrometerTrack()
const TrigMuonEFInfoTrackContainer * TrackContainer() const
bool hasTrack() const
EDM class for holding results of EF muon isolation calculation.
int trackPosition() const
Position of the muon in the TrigMuonEFInfoTrack container.
const TrigMuonEFInfoTrack * getEFMuonInfoTrack() const
Access the muon we calculated the isolation for.
const TrigMuonEFInfo * getMuonInfo() const
Access the muon info object we calculated the isolation for.
Contains basic information about trackc collection associated with Tau RoI.
float scalarPtSumCore() const
const P4PtEtaPhiM & threeFastestTracks() const
float leadingTrackPt() const
float scalarPtSumIso() const
bool isPassed(unsigned int condition=TrigDefs::Physics) const
tells if chain group passed
std::vector< std::string > getListOfTriggers() const
const Amg::Vector3D & momentum() const
Access method for the momentum.
Trk::RecVertex inherits from Trk::Vertex.
Definition RecVertex.h:44
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
const Track * originalTrack() const
Return pointer to associated track.
double charge() const
Return charge of the particle.
const VxCandidate * reconstructedVertex() const
Get a pointer to the primary vertex.
A summary of the information contained by a track.
const Amg::Vector3D & position() const
return position of vertex
Definition Vertex.cxx:63
STL class.
virtual double eta() const
The pseudorapidity ( ) of the particle.
virtual double e() const
The total energy of the particle.
virtual double phi() const
The azimuthal angle ( ) of the particle.
@ ETACALOFRAME
Eta in the calo frame (for egamma).
@ PHICALOFRAME
Phi in the calo frame (for egamma).
A vector of jet constituents at the scale used during jet finding.
iterator begin() const
iterator on the first constituent
size_t size() const
number of constituents
iterator end() const
iterator after the last constituent
JetConstituentVector getConstituents() const
Return a vector of consituents. The object behaves like vector<const IParticle*>. See JetConstituentV...
Definition Jet_v1.cxx:149
uint32_t roiId() const
accessor method: ID of L1 RoI
float eta() const
accessor method: eta
pType particleType() const
accessor method: particle Type
float phi() const
accessor method: phi
float fitmass() const
accessor method: mass from vertex fit
float mass() const
accessor method: mass
float eta() const
get Eta (calibrated)
float phi() const
get Phi (calibrated)
float e237() const
get Energy in a 3x7 cluster (no calibration) around hottest cell
float eta1() const
get Eta sampling 1 (strip layer)
float e277() const
get Energy in a 7x7 cluster (no calibration) around hottest cell
float ehad1() const
get hadronic Energy (first hadronic layer)
float weta2() const
get cluster width (based on a 3x5 cluster - 2nd layer)
float energy() const
get Energy (calibrated)
float fracs1() const
get Energy in a 7 strips (around hottest strip) minus energy in 3 strips divided by energy in 3 strip...
int flag() const
Get the status flag.
float ex() const
Get the x component of the missing energy.
float exComponent(unsigned int index) const
Get the x component fo the energy of a component.
const std::string & nameOfComponent(unsigned int index) const
Get the name of a component.
float eyComponent(unsigned int index) const
Get the y component fo the energy of a component.
uint32_t roiWord() const
Get the ROI word.
float sumE() const
Get the sum of the E of the missing energy.
float calib0Component(unsigned int index) const
Get Calib0.
float calib1Component(unsigned int index) const
Get Calib1.
unsigned int getNumberOfComponents() const
Get the number of components.
float ezComponent(unsigned int index) const
Get the z component fo the energy of a component.
float sumEt() const
Get the sum of the ET of the missing energy.
short statusComponent(unsigned int index) const
Get Status.
float ez() const
Get the z component of the missing energy.
float sumOfSignsComponent(unsigned int index) const
Get SumOfSigns.
float sumEComponent(unsigned int index) const
Get SumE.
float ey() const
Get the y component of the missing energy.
float sumEtComponent(unsigned int index) const
Get SumEt.
unsigned short usedChannelsComponent(unsigned int index) const
Get used Channels.
const std::vector< unsigned int > & serialized() const
expose the navigation information (in serialized form)
unsigned int sctSpEndcapA() const
unsigned int pixelClusTotBins() const
unsigned int sctSpBarrel() const
unsigned int pixelClusSizeBins() const
const std::vector< float > & contentsPixelClusEndcapC() const
getters
const std::vector< float > & contentsPixelClusEndcapA() const
unsigned int sctSpEndcapC() const
const std::vector< float > & contentsPixelClusBarrel() const
const std::vector< float > & triggerEnergies() const
Return the trigger energies of each counter.
const std::vector< float > & triggerTimes() const
Return the relative times of the triggers.
const std::vector< float > & eta_phi() const
unsigned int phiBins() const
unsigned int etaBins() const
const std::vector< float > & z0_pt() const
getters
unsigned int z0Bins() const
unsigned int ptBins() const
const std::vector< float > & vtxTrkPtSqSum() const
const std::vector< unsigned int > & vtxNtrks() const
getters
double chi2(TH1 *h0, TH1 *h1)
bool contains(const std::string &s, const std::string &regx)
does a string contain the substring
Definition hcg.cxx:116
int count(std::string s, const std::string &regx)
count how many occurances of a regx are in a string
Definition hcg.cxx:148
Eigen::Matrix< double, 3, 1 > Vector3D
The namespace of all packages in PhysicsAnalysis/JetTagging.
::StatusCode StatusCode
StatusCode definition for legacy code.
uint32_t sgkey_t
Type used for hashed StoreGate key+CLID pairs.
Definition sgkey_t.h:32
const SG::AuxVectorData * container() const
Return the container holding this element.
float j(const xAOD::IParticle &, const xAOD::TrackMeasurementValidation &hit, const Eigen::Matrix3d &jab_inv)
HLT::Identifier createLegName(const HLT::Identifier &chainIdentifier, size_t counter)
Generate the HLT::Identifier which corresponds to a specific leg of a given chain.
@ UNSET
Default property of state.
Definition ActiveState.h:19
@ INACTIVE
The link was inactive for all of the HLT Chains requested in the TDT.
Definition ActiveState.h:21
Decision * newDecisionIn(DecisionContainer *dc, const std::string &name)
Helper method to create a Decision object, place it in the container and return a pointer to it.
int32_t getIndexFromLeg(const HLT::Identifier &legIdentifier)
Extract the numeric index of a leg identifier.
SG::WriteHandle< DecisionContainer > createAndStore(const SG::WriteHandleKey< DecisionContainer > &key, const EventContext &ctx)
Creates and right away records the DecisionContainer with the key.
void linkToPrevious(Decision *d, const std::string &previousCollectionKey, size_t previousIndex)
Links to the previous object, location of previous 'seed' decision supplied by hand.
void addDecisionID(DecisionID id, Decision *d)
Appends the decision (given as ID) to the decision object.
bool isLegId(const HLT::Identifier &legIdentifier)
Recognise whether the chain ID is a leg ID.
static const unsigned int includeFailedDecisions
Run3 synonym of alsoDeactivateTEs.
static const unsigned int allFeaturesOfType
Run 3 "enum". Return all features along legs (still with type and container checks).
ParametersT< TrackParametersDim, Charged, PerigeeSurface > Perigee
@ theta
Definition ParamDefs.h:66
@ qOverP
perigee
Definition ParamDefs.h:67
@ phi
Definition ParamDefs.h:75
@ d0
Definition ParamDefs.h:63
@ px
Definition ParamDefs.h:59
@ z0
Definition ParamDefs.h:64
@ py
Definition ParamDefs.h:60
ParametersBase< TrackParametersDim, Charged > TrackParameters
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
-event-from-file
Definition index.py:1
@ deltaPhi2
difference between the cluster phi (second sampling) and the phi of the track extrapolated to the sec...
@ deltaEta1
difference between the cluster eta (first sampling) and the eta of the track extrapolated to the firs...
@ e237
uncalibrated energy (sum of cells) of the middle sampling in a rectangle of size 3x7
Definition EgammaEnums.h:78
@ ethad
ET leakage into hadronic calorimeter with exclusion of energy in CaloSampling::TileGap3.
Definition EgammaEnums.h:46
@ e2ts1
2nd max in strips calc by summing 3 strips
@ e335
uncalibrated energy (sum of cells) of the third sampling in a rectangle of size 3x5
Definition EgammaEnums.h:87
@ e132
uncalibrated energy (sum of cells) in strips in a 3x2 window in cells in eta X phi
Definition EgammaEnums.h:37
@ e011
uncalibrated energy (sum of cells) in presampler in a 1x1 window in cells in eta X phi
Definition EgammaEnums.h:31
@ e2tsts1
energy of the cell corresponding to second energy maximum in the first sampling
@ etcone20
Calorimeter isolation.
@ ptcone20
Track isolation.
@ hadRadius
Get hadron calorimeter radius.
Definition TauDefs.h:192
@ EMRadius
Get E_T radius.
Definition TauDefs.h:190
@ etHadAtEMScale
Get Hadronic energy at EM scale.
Definition TauDefs.h:196
@ isolFrac
Get isolation fraction.
Definition TauDefs.h:198
@ trkAvgDist
Get calibrated EM transverse energy (DEPRECATED since r19).
Definition TauDefs.h:214
@ etEMAtEMScale
Get EM energy at EM scale.
Definition TauDefs.h:194
@ centFrac
Get centrality fraction.
Definition TauDefs.h:200
@ dRmax
Get maximal dR of tracks associated to calo-seeded tau.
Definition TauDefs.h:226
Jet_v1 Jet
Definition of the current "jet version".
TrigVertexCountsContainer_v1 TrigVertexCountsContainer
PhotonContainer_v1 PhotonContainer
Definition of the current "photon container version".
TrigPassBitsContainer_v1 TrigPassBitsContainer
Define the latest version of the trig pass bits container class.
TrigMissingETContainer_v1 TrigMissingETContainer
DataVector of TrigMissingET - the current version.
TrigCompositeContainer_v1 TrigCompositeContainer
Declare the latest version of the container.
TrigElectronContainer_v1 TrigElectronContainer
Declare the latest version of the container.
ElectronContainer_v1 ElectronContainer
Definition of the current "electron container version".
TrigBphys_v1 TrigBphys
Definition TrigBphys.h:18
TriggerMenuContainer_v1 TriggerMenuContainer
Define the latest version of the trigger menu container class.
CaloCluster_v1 CaloCluster
Define the latest version of the calorimeter cluster class.
TrigComposite_v1 TrigComposite
Declare the latest version of the class.
TrigSpacePointCountsContainer_v1 TrigSpacePointCountsContainer
TrigEMClusterContainer_v1 TrigEMClusterContainer
Define the latest version of the trigger EM cluster container.
TrigTrackCountsContainer_v1 TrigTrackCountsContainer
TrigPhotonContainer_v1 TrigPhotonContainer
Declare the latest version of the container.
TrackParticle_v1 TrackParticle
Reference the current persistent version:
VertexContainer_v1 VertexContainer
Definition of the current "Vertex container version".
TrigPassBits_v1 TrigPassBits
Define the latest version of the trigger pass bits class.
TrackParticleContainer_v1 TrackParticleContainer
Definition of the current "TrackParticle container version".
TrigEMCluster_v1 TrigEMCluster
Define the latest version of the trigger EM cluster class.
TrigNavigation_v1 TrigNavigation
Define the latest version of the trigger navigation class.
JetContainer_v1 JetContainer
Definition of the current "jet container version".
TauJetContainer_v3 TauJetContainer
Definition of the current "taujet container version".
MuonContainer_v1 MuonContainer
Definition of the current "Muon container version".
TrigBphysContainer_v1 TrigBphysContainer
@ numberOfPixelHoles
number of pixel layers on track with absence of hits [unit8_t].
@ numberOfTRTHits
number of TRT hits [unit8_t].
@ numberOfTRTHoles
number of TRT holes [unit8_t].
@ numberOfBLayerHits
these are the hits in the first pixel layer, i.e.
@ numberOfSCTHits
number of hits in SCT [unit8_t].
@ numberOfPixelHits
these are the pixel hits, including the b-layer [unit8_t].
@ numberOfSCTHoles
number of SCT holes [unit8_t].
DataVector< IParticle > IParticleContainer
Simple convenience declaration of IParticleContainer.
Default, invalid implementation of ClassID_traits.
Helper to keep a Decision object, ElementLink and ActiveState (with respect to some requested ChainGr...
Definition LinkInfo.h:22
MsgStream & msg
Definition testRead.cxx:32