7#include "GaudiKernel/IToolSvc.h"
239 return StatusCode::SUCCESS;
263 if(m_doDumpTrackParticleContainer){
264 StatusCode
sc = dumpTrackParticleContainer();
265 if (
sc.isFailure()) {
266 ATH_MSG_ERROR(
"The method dumpTrackParticleContainer() failed");
270 if(m_doDumpAll || m_doDumpLVL1_ROI ){
271 StatusCode
sc = dumpLVL1_ROI();
272 if (
sc.isFailure()) {
287 if(m_doDumpAll || m_doDumpxAODTrigMissingET){
288 StatusCode
sc = dumpxAODTrigMissingET();
289 if (
sc.isFailure()) {
294 if(m_doDumpAll || m_doDumpMuonFeature){
295 StatusCode
sc = dumpMuonFeature();
296 if (
sc.isFailure()) {
301 if(m_doDumpAll || m_doDumpCombinedMuonFeature){
302 StatusCode
sc = dumpCombinedMuonFeature();
303 if (
sc.isFailure()) {
304 ATH_MSG_ERROR(
"The method dumpCombinedMuonFeature() failed");
306 sc = dumpCombinedMuonFeatureContainer();
307 if (
sc.isFailure()) {
308 ATH_MSG_ERROR(
"The method dumpCombinedMuonFeatureContainer() failed");
309 return StatusCode::SUCCESS;
313 if(m_doDumpAll || m_doDumpTileMuFeature) {
314 StatusCode
sc = dumpTileMuFeatureContainer();
315 if (
sc.isFailure()) {
316 ATH_MSG_ERROR(
"The method dumpTileMuFeatureContainer() failed");
320 if(m_doDumpAll || m_doDumpTileTrackMuFeature) {
321 StatusCode
sc = dumpTileTrackMuFeatureContainer();
322 if (
sc.isFailure()) {
323 ATH_MSG_ERROR(
"The method dumpTileTrackMuFeatureContainer() failed");
327 if(m_doDumpAll || m_doDumpTrigEMCluster){
328 StatusCode
sc = dumpTrigEMCluster();
329 if (
sc.isFailure()) {
334 if(m_doDumpAll || m_doDumpTrigEMClusterContainer){
335 StatusCode
sc = dumpTrigEMClusterContainer();
336 if (
sc.isFailure()) {
337 ATH_MSG_ERROR(
"The method dumpTrigEMClusterContainer() failed");
341 if(m_doDumpAll || m_doDumpxAODTrigEMCluster){
342 StatusCode
sc = dumpxAODTrigEMCluster();
343 if (
sc.isFailure()) {
348 if(m_doDumpAll || m_doDumpxAODTrigEMClusterContainer){
349 StatusCode
sc = dumpxAODTrigEMClusterContainer();
350 if (
sc.isFailure()) {
351 ATH_MSG_ERROR(
"The method dumpxAODTrigEMClusterContainer() failed");
355 if(m_doDumpTrigTauClusterContainer){
356 StatusCode
sc = dumpTrigTauClusterContainer();
357 if (
sc.isFailure()) {
358 ATH_MSG_ERROR(
"The method dumpTrigTauClusterContainer() failed");
362 if(m_doDumpAll || m_doDumpTrigPhotonContainer){
363 StatusCode
sc = dumpTrigPhotonContainer();
364 if (
sc.isFailure()) {
365 ATH_MSG_ERROR(
"The method dumpTrigPhotonContainer() failed");
369 if(m_doDumpAll || m_doDumpxAODJetContainer){
370 StatusCode
sc = dumpxAODJetContainer();
371 if (
sc.isFailure()) {
376 if(m_doDumpAll || m_doDumpTrigL2BphysContainer){
377 StatusCode
sc = dumpTrigL2BphysContainer();
378 if (
sc.isFailure()) {
379 ATH_MSG_ERROR(
"The method dumpTrigL2BphysContainer() failed");
383 if(m_doDumpAll || m_doDumpTrigEFBphysContainer){
384 StatusCode
sc = dumpTrigEFBphysContainer();
385 if (
sc.isFailure()) {
386 ATH_MSG_ERROR(
"The method dumpTrigEFBphysContainer() failed");
390 if(m_doDumpAll || m_doDumpTrigEFBjetContainer){
391 StatusCode
sc = dumpTrigEFBjetContainer();
392 if (
sc.isFailure()) {
393 ATH_MSG_ERROR(
"The method dumpTrigEFBjetContainer() failed");
397 if(m_doDumpAll || m_doDumpTrigL2BjetContainer){
398 StatusCode
sc = dumpTrigL2BjetContainer();
399 if (
sc.isFailure()) {
400 ATH_MSG_ERROR(
"The method dumpTrigL2BjetContainer() failed");
404 if(m_doDumpAll || m_doDumpTrigMuonEFContainer){
405 StatusCode
sc = dumpTrigMuonEFContainer();
406 if (
sc.isFailure()) {
407 ATH_MSG_ERROR(
"The method dumpTrigMuonEFContainer() failed");
411 if(m_doDumpAll || m_doDumpTrigMuonEFInfoContainer){
412 StatusCode
sc = dumpTrigMuonEFInfoContainer();
413 if (
sc.isFailure()) {
414 ATH_MSG_ERROR(
"The method dumpTrigMuonEFInfoContainer() failed");
418 if(m_doDumpAll || m_doDumpTrigMuonEFIsolationContainer) {
419 StatusCode
sc = dumpTrigMuonEFIsolationContainer();
421 ATH_MSG_ERROR(
"The method dumpTrigMuonEFIsolationContainer() failed");
425 if(m_doDumpAll || m_doDumpxAODMuonContainer) {
426 StatusCode
sc = dumpxAODMuonContainer();
432 if(m_doDumpAll || m_doDumpTrigElectronContainer){
433 StatusCode
sc = dumpTrigElectronContainer();
434 if (
sc.isFailure()) {
435 ATH_MSG_ERROR(
"The method dumpTrigElectronContainer() failed");
439 if(m_doDumpAll || m_doDumpxAODTrigElectronContainer){
440 StatusCode
sc = dumpxAODTrigElectronContainer();
441 if (
sc.isFailure()) {
442 ATH_MSG_ERROR(
"The method dumpxAODTrigElectronContainer() failed");
446 if(m_doDumpAll || m_doDumpxAODTrigPhotonContainer){
447 StatusCode
sc = dumpxAODTrigPhotonContainer();
448 if (
sc.isFailure()) {
449 ATH_MSG_ERROR(
"The method dumpxAODTrigElectronContainer() failed");
453 if(m_doDumpAll || m_doDumpxAODElectronContainer){
454 StatusCode
sc = dumpxAODElectronContainer();
455 if (
sc.isFailure()) {
456 ATH_MSG_ERROR(
"The method dumpxAODTrigElectronContainer() failed");
460 if(m_doDumpAll || m_doDumpxAODPhotonContainer){
461 StatusCode
sc = dumpxAODPhotonContainer();
462 if (
sc.isFailure()) {
463 ATH_MSG_ERROR(
"The method dumpxAODTrigElectronContainer() failed");
467 if(m_doDumpTrigTauContainer){
468 StatusCode
sc = dumpTrigTauContainer();
469 if (
sc.isFailure()) {
474 if(m_doDumpTrigTauTracksInfo){
475 StatusCode
sc = dumpTrigTauTracksInfo();
476 if (
sc.isFailure()) {
481 if(m_doDumpAll || m_doDumpHLTResult){
482 StatusCode
sc = dumpHLTResult();
483 if (
sc.isFailure()) {
488 if(m_doDumpTrigInDetTrackCollection){
489 StatusCode
sc = dumpTrigInDetTrackCollection();
490 if (
sc.isFailure()) {
491 ATH_MSG_ERROR(
"The method dumpTrigInDetTrackCollection() failed");
495 if(m_doDumpAll || m_doDumpTrigVertexCollection){
496 StatusCode
sc = dumpTrigVertexCollection();
497 if (
sc.isFailure()) {
498 ATH_MSG_ERROR(
"The method dumpTrigVertexCollection() failed");
502 if(m_doDumpAll || m_doDumpxAODTauJetContainer){
503 StatusCode
sc = dumpxAODTauJetContainer();
504 if (
sc.isFailure()) {
505 ATH_MSG_ERROR(
"The method dumpxAODTauJetContainer() failed");
509 if(m_doDumpTauJetContainer){
510 StatusCode
sc = dumpTauJetContainer();
511 if (
sc.isFailure()) {
516 if(m_doDumpAll || m_doDumpxAODTrackParticle){
517 StatusCode
sc = dumpxAODTrackParticle();
518 if (
sc.isFailure()) {
523 if(m_doDumpAll || m_doDumpxAODVertex){
524 StatusCode
sc = dumpxAODVertex();
525 if (
sc.isFailure()) {
530 if (m_doDumpAll || m_doDumpxAODTrigMinBias){
531 StatusCode
sc = dumpxAODTrigMinBias();
532 if (
sc.isFailure()) {
537 if (m_doDumpTrigPassBits){
538 StatusCode
sc = dumpTrigPassBits();
539 if (
sc.isFailure()) {
544 if (m_doDumpAll || m_doDumpStoreGate) {
548 if (m_doDumpAll || m_doDumpNavigation) {
549 StatusCode
sc = dumpNavigation(ctx);
550 if (
sc.isFailure() ) {
555 if (m_doDumpAll || m_doTDTCheck) {
559 if (m_doDumpAll || m_doDumpAllTrigComposite || m_dumpTrigCompositeContainers.size() > 0) {
563 if (m_doDumpAll || m_doDumpTrigCompsiteNavigation) {
564 std::string trigCompositeSteering;
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;
576 return StatusCode::SUCCESS;
582 const std::string name=
"HLT_xAOD__TrigPassBitsContainer_passbits";
584 StatusCode
sc =
evtStore()->retrieve(xbitscont,name);
585 if (
sc.isFailure() ){
590 for(
const auto bits:*xbitscont){
595 ATH_MSG_DEBUG(
"Analyzing bits for " << bits->containerClid() <<
" of size " << bits->size() <<
" with bit size " << bits->passBits().size());
603 ATH_MSG_DEBUG(
"Analyzing bits for " << bits->containerClid() <<
" of size " << bits->size() <<
" with bit size " << bits->passBits().size());
606 return StatusCode::SUCCESS;
613 std::string METTag=
"HLT_xAOD__TrigSpacePointCountsContainer_spacepoints";
616 StatusCode
sc =
evtStore()->retrieve(SpacePointCountsCont,METTag);
621 ATH_MSG_INFO(
"Accessing " << METTag <<
" with " << SpacePointCountsCont->
size() <<
" elements");
623 std::string s;
char buff[128];
624 std::vector<float> getVec;
628 for(
uint i = 0; i < SpacePointCountsCont->
size(); i++) {
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 );
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 );
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 );
647 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusTotBins() = %u ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusTotBins() );
650 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusTotMin() = %10.2f ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusTotMin() );
653 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusTotMax() = %10.2f ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusTotMax() );
656 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusSizeBins() = %u ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusSizeBins() );
659 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusSizeMin() = %10.2f ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusSizeMin() );
662 snprintf(buff,
sizeof(buff),
"REGTEST %s pixelClusSizeMax() = %10.2f ", s.c_str(), SpacePointCountsCont->
at(i)->
pixelClusSizeMax() );
665 snprintf(buff,
sizeof(buff),
"REGTEST %s sctSpEndcapC() = %u ", s.c_str(), SpacePointCountsCont->
at(i)->
sctSpEndcapC() );
668 snprintf(buff,
sizeof(buff),
"REGTEST %s sctSpBarrel() = %u ", s.c_str(), SpacePointCountsCont->
at(i)->
sctSpBarrel() );
671 snprintf(buff,
sizeof(buff),
"REGTEST %s sctSpEndcapA() = %u ", s.c_str(), SpacePointCountsCont->
at(i)->
sctSpEndcapA() );
680 std::string METTag=
"HLT_xAOD__TrigT2MbtsBitsContainer_T2Mbts";
683 StatusCode
sc =
evtStore()->retrieve(T2MbtsBitsCont,METTag);
688 ATH_MSG_INFO(
"Accessing " << METTag <<
" with " << T2MbtsBitsCont->
size() <<
" elements");
690 std::string s;
char buff[380];
691 std::vector<float> getVec;
695 for(
uint i = 0; i < T2MbtsBitsCont->
size(); i++) {
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 );
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 );
714 std::string METTag=
"HLT_xAOD__TrigVertexCountsContainer_vertexcounts";
717 StatusCode
sc =
evtStore()->retrieve(T2VertexCountsCont,METTag);
722 ATH_MSG_INFO(
"Accessing " << METTag <<
" with " << T2VertexCountsCont->
size() <<
" elements");
724 std::string s;
char buff[380];
725 std::vector<float> fgetVec;
727 std::vector<unsigned int> ugetVec;
728 unsigned int usum(0);
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 );
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 );
748 std::string METTag=
"HLT_xAOD__TrigTrackCountsContainer_trackcounts";
751 StatusCode
sc =
evtStore()->retrieve(T2TrackCountsCont,METTag);
756 ATH_MSG_INFO(
"Accessing " << METTag <<
" with " << T2TrackCountsCont->
size() <<
" elements");
758 std::string s;
char buff[380];
759 std::vector<float> getVec;
763 for(
uint i = 0; i < T2TrackCountsCont->
size(); i++) {
764 getVec = T2TrackCountsCont->
at(i)->
z0_pt();
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 );
770 getVec = T2TrackCountsCont->
at(i)->
eta_phi();
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 );
776 snprintf(buff,
sizeof(buff),
"REGTEST %s z0Bins() = %u ", s.c_str(), T2TrackCountsCont->
at(i)->
z0Bins() );
779 snprintf(buff,
sizeof(buff),
"REGTEST %s z0Min() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
z0Min() );
782 snprintf(buff,
sizeof(buff),
"REGTEST %s z0Max() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
z0Max() );
785 snprintf(buff,
sizeof(buff),
"REGTEST %s ptBins() = %u ", s.c_str(), T2TrackCountsCont->
at(i)->
ptBins() );
788 snprintf(buff,
sizeof(buff),
"REGTEST %s ptMin() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
ptMin() );
791 snprintf(buff,
sizeof(buff),
"REGTEST %s ptMax() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
ptMax() );
794 snprintf(buff,
sizeof(buff),
"REGTEST %s etaBins() = %u ", s.c_str(), T2TrackCountsCont->
at(i)->
etaBins() );
797 snprintf(buff,
sizeof(buff),
"REGTEST %s etaMin() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
etaMin() );
800 snprintf(buff,
sizeof(buff),
"REGTEST %s etaMax() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
etaMax() );
803 snprintf(buff,
sizeof(buff),
"REGTEST %s phiBins() = %u ", s.c_str(), T2TrackCountsCont->
at(i)->
phiBins() );
806 snprintf(buff,
sizeof(buff),
"REGTEST %s phiMin() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
phiMin() );
809 snprintf(buff,
sizeof(buff),
"REGTEST %s phiMax() = %10.2f ", s.c_str(), T2TrackCountsCont->
at(i)->
phiMax() );
822 return StatusCode::SUCCESS;
834 std::string METTags[]={
"HLT_xAOD__TrigMissingETContainer_EFJetEtSum",
"HLT_xAOD__TrigMissingETContainer_TrigEFMissingET",
"HLT_xAOD__TrigMissingETContainer_TrigL2MissingET_FEB",
"HLT_xAOD__TrigMissingETContainer_TrigEFMissingET_topocl"};
836 for(
int itag=0; itag <ntag; itag++) {
839 StatusCode
sc =
evtStore()->retrieve(MissingETCont,METTags[itag]);
843 ATH_MSG_INFO(
"Accessing " << METTags[itag] <<
" with " << MissingETCont->
size() <<
" elements");
846 for(
uint i = 0; i < MissingETCont->
size(); i++) {
848 std::string s;
char buff[3000];
850 snprintf(buff,
sizeof(buff),
"REGTEST %s Ex = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->
at(i)->
ex() );
852 snprintf(buff,
sizeof(buff),
"REGTEST %s Ey = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->
at(i)->
ey() );
854 snprintf(buff,
sizeof(buff),
"REGTEST %s Ez = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->
at(i)->
ez() );
856 snprintf(buff,
sizeof(buff),
"REGTEST %s SumET = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->
at(i)->
sumEt() );
858 snprintf(buff,
sizeof(buff),
"REGTEST %s SumE = %10.2f CLHEP::MeV", s.c_str(), MissingETCont->
at(i)->
sumE() );
860 snprintf(buff,
sizeof(buff),
"REGTEST %s Flag = %d", s.c_str(), MissingETCont->
at(i)->
flag() );
862 snprintf(buff,
sizeof(buff),
"REGTEST %s Flag = %d", s.c_str(), MissingETCont->
at(i)->
roiWord() );
867 s=
"REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
868 s+=
"/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
872 for(
uint j = 0; j < Nc; j++) {
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);
896 return StatusCode::SUCCESS;
908 std::string METTags[]={
"HLT_TrigMissingETContainer_TrigEFMissingET",
"HLT_TrigMissingETContainer_TrigEFMissingET_FEB",
"HLT_TrigMissingETContainer_TrigEFMissingET_topocl"};
911 for (
int itag=0; itag < ntag; itag++) {
913 StatusCode
sc=evtStore()->retrieve(trigMETcont , METTags[itag]);
914 if(
sc.isFailure() ){
915 ATH_MSG_INFO(
"Failed to retrieve TrigMissingETContainer with key " << METTags[itag]);
919 ATH_MSG_INFO(
"Got TrigMissingETContainer with key \"" << METTags[itag]<<
"\"");
923 ATH_MSG_INFO(
"REGTEST ==========START of TrigMissingET DUMP===========");
928 snprintf(buff,
sizeof(buff),
"REGTEST %s Ex = %10.2f CLHEP::MeV", s.c_str(),
met->ex() );
930 snprintf(buff,
sizeof(buff),
"REGTEST %s Ey = %10.2f CLHEP::MeV", s.c_str(),
met->ey() );
932 snprintf(buff,
sizeof(buff),
"REGTEST %s Ez = %10.2f CLHEP::MeV", s.c_str(),
met->ez() );
934 snprintf(buff,
sizeof(buff),
"REGTEST %s Et = %10.2f CLHEP::MeV", s.c_str(),
met->et() );
936 snprintf(buff,
sizeof(buff),
"REGTEST %s SumEt = %10.2f CLHEP::MeV", s.c_str(),
met->sumEt() );
938 snprintf(buff,
sizeof(buff),
"REGTEST %s SumE = %10.2f CLHEP::MeV", s.c_str(),
met->sumE() );
940 snprintf(buff,
sizeof(buff),
"REGTEST %s E = %10.2f CLHEP::MeV", s.c_str(),
met->e() );
942 snprintf(buff,
sizeof(buff),
"REGTEST %s flag = %10d", s.c_str(),
met->getFlag() );
944 snprintf(buff,
sizeof(buff),
"REGTEST %s RoIword = %10ld", s.c_str(),
met->RoIword() );
947 unsigned int Nc =
met->getNumOfComponents();
949 s=
"REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
950 s+=
"/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
953 for (
unsigned int i=0; i<Nc; ++i) {
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);
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);
979 ATH_MSG_INFO(
"Trying to fetch TrigMissingET objects from older releases");
982 StatusCode
sc=evtStore()->retrieve(trigMETfirst ,trigMETlast);
983 if(
sc.isFailure() ){
984 ATH_MSG_INFO(
"Failed to retrieve TrigMissingET (rel. <= 14.2.0)");
987 for( ; trigMETfirst != trigMETlast ; ++trigMETfirst ){
988 const std::string& name(trigMETfirst.
key());
989 ATH_MSG_INFO(
"Got TrigMissingET object with key \"" << name <<
"\"");
994 if( name.find(
"TrigEFMissingET") != std::string::npos ) {
996 }
else if( name.find(
"T2MissingET") != std::string::npos ){
1003 snprintf(buff,
sizeof(buff),
"%s Ex = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ex() );
1005 snprintf(buff,
sizeof(buff),
"%s Ey = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ey() );
1007 snprintf(buff,
sizeof(buff),
"%s Ez = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->ez() );
1009 snprintf(buff,
sizeof(buff),
"%s Et = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->et() );
1011 snprintf(buff,
sizeof(buff),
"%s SumE = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->sumE() );
1013 snprintf(buff,
sizeof(buff),
"%s SumEt = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->sumEt() );
1015 snprintf(buff,
sizeof(buff),
"%s E = %10.2f CLHEP::MeV", s.c_str(), trigMETfirst->e() );
1017 snprintf(buff,
sizeof(buff),
"%s flag = %10d", s.c_str(), trigMETfirst->getFlag() );
1019 snprintf(buff,
sizeof(buff),
"%s RoIword = %10ld", s.c_str(), trigMETfirst->RoIword() );
1022 unsigned int Nc = trigMETfirst->getNumOfComponents();
1024 s=
"REGTEST __name____status_usedChannels__sumOfSigns__calib1_calib0";
1025 s+=
"/MeV__ex/MeV_____ey/MeV_____ez/MeV___sumE/MeV__sumEt/CLHEP::MeV";
1028 for (
unsigned int i=0; i<Nc; ++i) {
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);
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);
1050 ATH_MSG_INFO(
"REGTEST ==========END of TrigMissingET DUMP===========");
1052 return StatusCode::SUCCESS;
1061 ATH_MSG_INFO(
"REGTEST ==========START of TrackParticleContainer DUMP===========");
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"};
1073 StatusCode returnsc=StatusCode::SUCCESS;
1075 for (
int itag=0; itag<ntag; itag++){
1077 StatusCode
sc =
evtStore()->retrieve(pTrackParticleC, trackPtags[itag]);
1078 if (
sc.isFailure()) {
1079 ATH_MSG_INFO(
"REGTEST No TrackParticleContainer found with tag " << trackPtags[itag]);
1082 ATH_MSG_INFO(
"TrackParticleContainer found with tag " << trackPtags[itag]
1083 <<
" and size " << pTrackParticleC->
size());
1087 for (
int ind=1; trackItr != trackItrE; ++trackItr, ind++) {
1090 << trackParticle->
charge() <<
" p "
1091 << trackParticle->
p()<<
" eta " << trackParticle->
eta()
1092 <<
" phi " << trackParticle->
phi());
1100 const auto& parameterVector = perigee->parameters();
1103 " phi " <<parameterVector[
Trk::phi]);
1112 ATH_MSG_WARNING(
" Max attached track warning reached, no further warnings given");
1123 ATH_MSG_INFO(
" vertex position (" << position[0] <<
", " <<
1124 position[1] <<
", " << position[2] <<
") ");
1129 ATH_MSG_WARNING(
" Max attached vertex warning reached, no further warnings given");
1137 const auto& parameters = perigee->parameters();
1168 ATH_MSG_INFO(
"REGTEST ==========START of LVL1_ROI DUMP===========");
1171 StatusCode
sc =
evtStore()->retrieve(lvl1ROI);
1172 if (
sc.isFailure() ) {
1174 return StatusCode::SUCCESS;
1179 LVL1_ROI::emtaus_type::const_iterator itEMTau =
1181 LVL1_ROI::emtaus_type::const_iterator itEMTau_e =
1184 for( ; itEMTau != itEMTau_e; ++itEMTau, ++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());
1197 ATH_MSG_INFO(
"REGTEST ==========END of LVL1_ROI DUMP===========");
1199 return StatusCode::SUCCESS;
1209 ATH_MSG_INFO(
"REGTEST ==========START of TrigPhotonContainer DUMP===========");
1214 StatusCode
sc = evtStore()->retrieve(trigPhoton,lastTrigPhoton);
1215 if (
sc.isFailure()) {
1217 return StatusCode::SUCCESS;
1219 ATH_MSG_INFO(
"REGTEST TrigPhotonContainers retrieved");
1222 for (
int i=0; trigPhoton != lastTrigPhoton; ++trigPhoton, ++
i) {
1224 ATH_MSG_INFO(
"REGTEST Looking at TrigPhotonContainer " << i);
1229 for (
int j=0; PhotonItr != PhotonItrE; ++PhotonItr, ++
j ) {
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());
1239 if ( (*PhotonItr)->cluster() != NULL ) {
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());
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());
1265 for (
int k=0; PhotonItr2 != PhotonItr2E; ++PhotonItr2, ++
k ) {
1267 if ( (**PhotonItr) == (**PhotonItr2) ) {
1268 ATH_MSG_INFO(
"REGTEST TrigPhoton nr. " << j <<
" is the same as TrigPhoton nr. " << k);
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);
1282 ATH_MSG_INFO(
"REGTEST ==========END of TrigPhotonContainer DUMP===========");
1285 return StatusCode::SUCCESS;
1295 ATH_MSG_INFO(
"REGTEST ==========START of TrigMuonEFContainer DUMP===========");
1300 StatusCode sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1301 if (
sc.isFailure()) {
1303 return StatusCode::SUCCESS;
1305 ATH_MSG_INFO(
"REGTEST TrigMuonEFContainers retrieved");
1307 for (
int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++
i) {
1309 ATH_MSG_INFO(
"REGTEST Looking at TrigMuonEFContainer " << i);
1314 for (
int j=0; MuonItr != MuonItrE; ++MuonItr, ++
j ) {
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());
1322 ATH_MSG_INFO(
"REGTEST Looking at P4IPtCotThPhiM " << j);
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());
1331 ATH_MSG_INFO(
"REGTEST ==========END of TrigMuonEFContainer DUMP===========");
1334 return StatusCode::SUCCESS;
1341 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::MuonContainer DUMP===========" );
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;
1353 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::MuonContainer DUMP===========" );
1355 return StatusCode::SUCCESS;
1365 ATH_MSG_INFO(
"REGTEST ==========START of TrigMuonEFInfoContainer DUMP===========");
1370 StatusCode
sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1371 if (
sc.isFailure()) {
1372 ATH_MSG_INFO(
"REGTEST No TrigMuonEFInfoContainer found");
1373 return StatusCode::SUCCESS;
1375 ATH_MSG_INFO(
"REGTEST TrigMuonEFInfoContainers retrieved");
1378 for (
int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++
i) {
1380 ATH_MSG_INFO(
"REGTEST -+-+-+-+ Looking at TrigMuonEFInfoContainer " << i);
1385 for (
int j=0; MuonItr != MuonItrE; ++MuonItr, ++
j ) {
1387 ATH_MSG_INFO(
"REGTEST Looking at TrigMuonEFInfo " << j);
1392 if (*muonInfo == *muonInfo) {
1414 printMuonTrk(muonTrack);
1416 ATH_MSG_INFO(
"REGTEST no SpectrometerTrack track found");
1419 ATH_MSG_INFO(
"REGTEST Looking at TrigMuonEFTrack ExtrapolatedTrack()");
1422 printMuonTrk(muonTrack);
1424 ATH_MSG_INFO(
"REGTEST no ExtrapolatedTrack track found");
1427 ATH_MSG_INFO(
"REGTEST Looking at TrigMuonEFTrack CombinedTrack()");
1430 printMuonTrk(muonTrack);
1440 return StatusCode::SUCCESS;
1442 ATH_MSG_INFO(
"REGTEST TrigMuonEFInfo->RoINum() returns " << muonInfo->RoINum());
1446 ATH_MSG_INFO(
"REGTEST ==========END of TrigMuonEFInfoContainer DUMP===========");
1449 return StatusCode::SUCCESS;
1458 ATH_MSG_INFO(
"REGTEST ==========START of TrigMuonEFIsolationContainer DUMP===========");
1463 StatusCode sc = evtStore()->retrieve(trigMuon,lastTrigMuon);
1464 if (
sc.isFailure()) {
1465 ATH_MSG_INFO(
"REGTEST No TrigMuonEFIsolationContainer found");
1466 return StatusCode::SUCCESS;
1468 ATH_MSG_INFO(
"REGTEST TrigMuonEFIsolationContainers retrieved");
1471 for (
int i=0; trigMuon != lastTrigMuon; ++trigMuon, ++
i) {
1473 ATH_MSG_INFO(
"REGTEST -+-+-+-+ Looking at TrigMuonEFIsolationContainer " << i);
1478 for (
int j=0; MuonItr != MuonItrE; ++MuonItr, ++
j ) {
1480 ATH_MSG_INFO(
"REGTEST Looking at TrigMuonEFIsolation " << j);
1485 if (*muonIsolation == *muonIsolation) {
1503 ATH_MSG_WARNING(
"REGTEST No InfoTrack attached to this EFIsolation object");
1518 ATH_MSG_INFO(
"REGTEST No Linked MuonEFInfo, expected for pre 2012 data");
1524 ATH_MSG_INFO(
"REGTEST ==========END of TrigMuonEFIsolationContainer DUMP===========");
1525 ATH_MSG_DEBUG(
"dumpTrigMuonEFIsolationContainer() succeeded");
1527 return StatusCode::SUCCESS;
1533 ATH_MSG_INFO(
"POINTER TrigMuonEFTrack: " << muonTrack);
1559 ATH_MSG_INFO(
" POINTER TrigMuonEFCbTrack: " << muonTrack);
1576 ATH_MSG_INFO(
"REGTEST ==========START of TrigElectronContainer DUMP===========");
1581 StatusCode
sc = evtStore()->retrieve(trigElec,lastTrigElec);
1582 if (
sc.isFailure()) {
1583 ATH_MSG_INFO(
"REGTEST No TrigelectronContainer found");
1584 return StatusCode::SUCCESS;
1586 ATH_MSG_INFO(
"REGTEST TrigElectronContainers retrieved");
1591 for (
int i=0; trigElec != lastTrigElec; ++trigElec, ++
i) {
1593 ATH_MSG_INFO(
"REGTEST Looking at TrigElectronContainer " << i);
1598 for (
int j=0; elecItr != elecItrE; ++elecItr, ++
j ) {
1635 for (
int k=0; elecItr2 != elecItr2E; ++elecItr2, ++
k ) {
1637 if ( (**elecItr) == (**elecItr2) ) {
1638 ATH_MSG_INFO(
"REGTEST TrigElectron nr. " << j <<
" is the same as TrigElectron nr. " << k);
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);
1652 ATH_MSG_INFO(
"REGTEST ==========END of TrigElectronContainer DUMP===========");
1655 return StatusCode::SUCCESS;
1663 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::TrigElectronContainer DUMP===========" );
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;
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());
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());
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());
1708 else ATH_MSG_INFO(
"REGTEST TrigElectron No TrackParticle retrieved!");
1710 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::TrigElectronContainer DUMP===========" );
1712 return StatusCode::SUCCESS;
1721 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::TrigPhotonContainer DUMP===========" );
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;
1730 for (
const auto eg : *phCont){
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());
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());
1751 else ATH_MSG_INFO(
"REGTEST TrigPhoton No EMCluster retrieved!");
1753 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::TrigPhotonContainer DUMP===========" );
1755 return StatusCode::SUCCESS;
1764 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::ElectronContainer DUMP===========" );
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;
1772 float val_float=-99;
1773 unsigned int isEMbit=0;
1776 ATH_MSG_INFO(
" REGTEST: xAOD Reconstruction variables: ");
1779 static const SG::AuxElement::Accessor< float > accLH(
"LHValue");
1780 static const SG::AuxElement::Accessor< float > accLHCalo(
"LHCaloValue");
1781 for (
const auto eg : *elCont){
1787 if(eg->selectionisEM(isEMbit,
"isEMVLoose"))
1788 ATH_MSG_INFO(
" REGTEST: isEMVLoose " << std::hex << isEMbit << std::dec);
1790 if(eg->selectionisEM(isEMbit,
"isEMLoose"))
1791 ATH_MSG_INFO(
" REGTEST: isEMLoose " << std::hex << isEMbit << std::dec);
1793 if(eg->selectionisEM(isEMbit,
"isEMMedium"))
1794 ATH_MSG_INFO(
" REGTEST: isEMMedium " << std::hex << isEMbit << std::dec);
1796 if(eg->selectionisEM(isEMbit,
"isEMTight"))
1797 ATH_MSG_INFO(
" REGTEST: isEMTight " << std::hex << isEMbit << std::dec);
1799 if(eg->selectionisEM(isEMbit,
"isEMLHVLoose"))
1800 ATH_MSG_INFO(
" REGTEST: isEMLHVLoose " << std::hex << isEMbit << std::dec);
1802 if(eg->selectionisEM(isEMbit,
"isEMLHLoose"))
1803 ATH_MSG_INFO(
" REGTEST: isEMLHLoose " << std::hex << isEMbit << std::dec);
1805 if(eg->selectionisEM(isEMbit,
"isEMLHMedium"))
1806 ATH_MSG_INFO(
" REGTEST: isEMLHMedium " << std::hex << isEMbit << std::dec);
1808 if(eg->selectionisEM(isEMbit,
"isEMLHTight"))
1809 ATH_MSG_INFO(
" REGTEST: isEMLHTight " << std::hex << isEMbit << std::dec);
1811 if(accLH.isAvailable(*eg))
1815 if(accLHCalo.isAvailable(*eg))
1819 if(eg->passSelection(pid,
"LHVLoose"))
1823 if(eg->passSelection(pid,
"LHLoose"))
1827 if(eg->passSelection(pid,
"LHMedium"))
1831 if(eg->passSelection(pid,
"LHTight"))
1836 ATH_MSG_INFO(
" REGTEST: problems with egamma pointer" );
1837 return StatusCode::SUCCESS;
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.;
1848 ATH_MSG_INFO(
" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1849 ATH_MSG_INFO(
" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1851 ATH_MSG_INFO(
" REGTEST: problems with egamma cluster pointer" );
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()){
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());
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() );
1870 ATH_MSG_INFO(
" REGTEST: Delta eta 1st sampling= " << val_float);
1872 ATH_MSG_INFO(
" REGTEST: Delta phi 2nd sampling= " << val_float);
1874 ATH_MSG_INFO(
" REGTEST: no electron eg->trackParticle() pointer");
1909 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::ElectronContainer DUMP===========" );
1911 return StatusCode::SUCCESS;
1920 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::PhotonContainer DUMP===========" );
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;
1929 float val_float=-99;
1930 unsigned int isEMbit=0;
1932 ATH_MSG_INFO(
" REGTEST: xAOD Reconstruction variables: ");
1934 for (
const auto eg : *phCont){
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);
1947 ATH_MSG_INFO(
" REGTEST: problems with egamma pointer" );
1948 return StatusCode::SUCCESS;
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.;
1959 ATH_MSG_INFO(
" REGTEST: egamma cluster calo-frame coords. etaCalo = " << tmpeta);
1960 ATH_MSG_INFO(
" REGTEST: egamma cluster calo-frame coords. phiCalo = " << tmpphi);
1962 ATH_MSG_INFO(
" REGTEST: problems with egamma cluster pointer" );
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()){
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());
2001 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::PhotonContainer DUMP===========" );
2003 return StatusCode::SUCCESS;
2011 ATH_MSG_INFO(
"REGTEST ==========START of TrigTauContainer DUMP===========");
2016 StatusCode
sc = evtStore()->retrieve(trigTau,lastTrigTau);
2017 if (
sc.isFailure()) {
2019 return StatusCode::SUCCESS;
2023 for (
int i=0; trigTau != lastTrigTau; ++trigTau, ++
i) {
2025 ATH_MSG_INFO(
"REGTEST Looking at TrigTauContainer " << i);
2030 for (
int j=0; TrigTauItr != TrigTauItrE; ++TrigTauItr, ++
j ) {
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());
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());
2044 ATH_MSG_INFO(
"REGTEST ==========END of TrigTau DUMP===========");
2047 return StatusCode::SUCCESS;
2054 ATH_MSG_INFO(
"REGTEST ==========START of TrigTauTracksInfo DUMP===========");
2059 StatusCode sc = evtStore()->retrieve(trigTau,lastTrigTau);
2060 if (
sc.isFailure()) {
2062 return StatusCode::SUCCESS;
2066 for (
int i=0; trigTau != lastTrigTau; ++trigTau, ++
i) {
2070 ATH_MSG_INFO(
"REGTEST Looking at TrigTauTracksInfo " << i);
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());
2080 ATH_MSG_INFO(
"REGTEST TrigTauTracksInfo->charge() returns " << thisTrigTau->
charge());
2081 ATH_MSG_INFO(
"REGTEST TrigTauTracksInfo->leadingTrackPt() returns " <<
2083 ATH_MSG_INFO(
"REGTEST TrigTauTracksInfo->scalarPtSumCore() returns " <<
2085 ATH_MSG_INFO(
"REGTEST TrigTauTracksInfo->scalarPtSumIso() returns " <<
2087 ATH_MSG_INFO(
"REGTEST TrigTauTracksInfo->threeFastestTracks().pt() returns " <<
2091 ATH_MSG_INFO(
"REGTEST ==========END of TrigTauTracksInfo DUMP===========");
2094 return StatusCode::SUCCESS;
2103 ATH_MSG_INFO(
"REGTEST ==========START of HLTResult DUMP===========");
2106 StatusCode
sc=
evtStore()->retrieve( hltResult,
"HLTResult_L2");
2107 if(
sc.isFailure() || !hltResult ) {
2109 return StatusCode::SUCCESS;
2111 ATH_MSG_INFO(
"REGTEST HLTResult_L2 Successfully Retrieved");
2114 ATH_MSG_INFO(
"REGTEST HLTResult_L2->size() returns " << hltResult->
size());
2118 ATH_MSG_INFO(
"REGTEST ==========END of HLTResult DUMP===========");
2122 return StatusCode::SUCCESS;
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",
2157 bool gotTruthMap =
false;
2160 StatusCode
sc=
evtStore()->retrieve(pTruthMap,
"TrigInDetTrackTruthMap");
2163 ATH_MSG_WARNING(
" could not retrieve TrackTruthMap with key TrigInDetTruthMap");
2169 else ATH_MSG_DEBUG(
" didn't find any TrackTruthMap objects with key TrigInDetTruthMap");
2171 ATH_MSG_INFO(
"REGTEST ==========START of TrigInDetTrackCollection DUMP===========");
2173 for (
int iTag=0; iTag < ntag; iTag++) {
2175 StatusCode
sc =
evtStore()->retrieve(trigInDetTrackCollection,TrigInDetTrackTags[iTag] );
2176 if (
sc.isFailure()) {
2177 ATH_MSG_DEBUG(
"REGTEST No TrigInDetTrackCollection found with key " << TrigInDetTrackTags[iTag]);
2180 ATH_MSG_INFO(
"REGTEST TrigInDetTrackCollections retrieved with key "
2181 << TrigInDetTrackTags[iTag]);
2183 ATH_MSG_INFO(
"REGTEST TrigInDetTrackCollection->size() returns " << trigInDetTrackCollection->
size());
2188 for (
int j=0; trkItr != trkItrE; ++trkItr, ++j ) {
2190 ATH_MSG_INFO(
"REGTEST Looking at TrigInDetTrack " << j);
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());
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());
2200 ATH_MSG_INFO(
"REGTEST Looking at TrigInDetFitTrack->param()");
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());
2215 ATH_MSG_INFO(
"REGTEST Looking at covarience matrix: ");
2217 const std::vector<double>*
const my_cov = my_param->
cov();
2219 ATH_MSG_INFO(
"REGTEST covarience matrix NULL (not stored)");
2221 std::vector<double> tempcov = *my_cov;
2222 std::vector<double>::iterator iter;
2224 for(iter = tempcov.begin(), k=0; iter != tempcov.end(); ++iter, ++k){
2225 ATH_MSG_INFO(
"REGTEST TrigInDetTrackFitPar->cov() element " << k <<
" is " << (*iter));
2229 if (!(pTruthMap->
hasTruth((*trkItr)))) {
2245 if (pSiTruth->
cptr() != 0) {
2254 if (pTRTtruth->
cptr() != 0) {
2264 ATH_MSG_INFO(
"REGTEST ==========END of TrigInDetTrackCollection DUMP===========");
2267 return StatusCode::SUCCESS;
2276 ATH_MSG_INFO(
"REGTEST ==========START of TrigVertexCollection DUMP===========");
2281 StatusCode
sc = evtStore()->retrieve(trigVertex,lastTrigVertex);
2282 if (
sc.isFailure()) {
2284 return StatusCode::SUCCESS;
2286 ATH_MSG_INFO(
"REGTEST TrigVertexCollection retrieved");
2289 for (
int i=0; trigVertex != lastTrigVertex; ++trigVertex, ++
i) {
2291 ATH_MSG_INFO(
"REGTEST Looking at TrigVertexCollection " << i);
2296 for (
int j=0; VertexItr != VertexItrE; ++VertexItr, ++
j ) {
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());
2306 if(((*VertexItr)->tracks())!=NULL ){
2308 TrackInVertexList::const_iterator trkItr = (*VertexItr)->tracks()->begin();
2309 TrackInVertexList::const_iterator trkItrE = (*VertexItr)->tracks()->end();
2311 for (
int p=0; trkItr != trkItrE; ++trkItr, ++
p ) {
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());
2324 ATH_MSG_INFO(
"REGTEST ==========END of TrigVertexCollection DUMP===========");
2327 return StatusCode::SUCCESS;
2338 ATH_MSG_INFO(
"REGTEST ==========START of TrigEFBphysContainer DUMP===========");
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"
2348 int ntag= (int)
sizeof(EFBphysTags) /
sizeof(EFBphysTags[0]);
2351 for (
int itag=0; itag<ntag; itag++){
2353 StatusCode
sc =
evtStore()->retrieve(trigEFBphys, EFBphysTags[itag]);
2354 if (
sc.isFailure()) {
2355 ATH_MSG_INFO(
"REGTEST No TrigEFBphysContainer found with tag " << EFBphysTags[itag]);
2359 ATH_MSG_INFO(
"REGTEST TrigEFBphysContainer found with tag " << EFBphysTags[itag]
2360 <<
" and size " << trigEFBphys->
size());
2369 for (
int j=0; EFBphysItr != EFBphysItrE; ++EFBphysItr, ++j ) {
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());
2378 ATH_MSG_INFO(
"REGTEST TrigEFBphys->roiId() returns " << (*EFBphysItr)->roiId());
2379 ATH_MSG_INFO(
"REGTEST TrigEFBphys->particleType() returns " << (*EFBphysItr)->particleType());
2381 if( (*EFBphysItr)->secondaryDecay() != NULL){
2384 ATH_MSG_INFO(
"REGTEST pSecondDecay->eta() returns " << psecond->
eta());
2385 ATH_MSG_INFO(
"REGTEST pSecondDecay->phi() returns " << psecond->
phi());
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());
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 ");
2409 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2412 double phi = trackPerigee->parameters()[
Trk::phi];
2416 double pt = sqrt(px*px + py*py);
2417 double eta = -std::log(tan(
theta/2));
2419 ATH_MSG_INFO(
"track " << itrk <<
" pt phi eta " << pt <<
" " <<
2425 ATH_MSG_INFO(
"REGTEST ==========END of TrigEFBphysContainer DUMP===========");
2428 return StatusCode::SUCCESS;
2435 ATH_MSG_INFO(
"REGTEST ==========START of TrigL2BphysContainer DUMP===========");
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",
2445 const int ntag = (int)
sizeof(L2BphysTags) /
sizeof(L2BphysTags[0]);
2448 for (
int itag=0; itag<ntag; itag++){
2450 StatusCode
sc =
evtStore()->retrieve(trigL2Bphys, L2BphysTags[itag]);
2451 if (
sc.isFailure()) {
2452 ATH_MSG_INFO(
"REGTEST No TrigL2BphysContainer found with tag " << L2BphysTags[itag]);
2456 ATH_MSG_INFO(
"REGTEST TrigL2BphysContainer found with tag " << L2BphysTags[itag]
2457 <<
" and size " << trigL2Bphys->
size());
2466 for (
int j=0; L2BphysItr != L2BphysItrE; ++L2BphysItr, ++j ) {
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());
2475 ATH_MSG_INFO(
"REGTEST TrigL2Bphys->roiId() returns " << (*L2BphysItr)->roiId());
2476 ATH_MSG_INFO(
"REGTEST TrigL2Bphys->particleType() returns " << (*L2BphysItr)->particleType());
2478 if( (*L2BphysItr)->secondaryDecay() != NULL){
2481 ATH_MSG_INFO(
"REGTEST pSecondDecay->eta() returns " << psecond->
eta());
2482 ATH_MSG_INFO(
"REGTEST pSecondDecay->phi() returns " << psecond->
phi());
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());
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 ");
2503 const Trk::Perigee* trackPerigee=&((*(*trkIt))->perigeeParameters());
2506 double phi = trackPerigee->parameters()[
Trk::phi];
2510 double pt = sqrt(px*px + py*py);
2511 double eta = -std::log(tan(
theta/2));
2513 ATH_MSG_INFO(
"track " << itrk <<
" pt phi eta " << pt <<
" " <<
2519 ATH_MSG_INFO(
"REGTEST ==========END of TrigL2BphysContainer DUMP===========");
2522 return StatusCode::SUCCESS;
2533 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::JetContainer DUMP===========");
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;
2573 for (
int icont=0; icont<30; ++icont) {
2576 StatusCode
sc =
evtStore()->retrieve(jetCont, containerName[icont]) ;
2578 if (
sc.isFailure()) {
2583 int jetContsize = jetCont->
size();
2584 ATH_MSG_INFO(
"REGTEST Got jet container " << containerName[icont] <<
", size: " << jetContsize);
2585 if (jetContsize != 0) {
2588 for(
const auto thisjet : *jetCont) {
2599 ATH_MSG_INFO(
"REGTEST rapidity: " << thisjet->rapidity() );
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() );
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");
2623 if (constitContsize != 0) {
2721 std::vector<int> vecvalueint;
2723 int vecsize = vecvalueint.size();
2724 ATH_MSG_INFO(
"REGTEST Got NumTrkPt1000 vector, size: " << vecsize);
2727 for(
const auto & thisvalue : vecvalueint){
2729 ATH_MSG_INFO(
"REGTEST NumTrkPt1000 #" << j <<
": " << thisvalue);
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");
2736 int vecsize = vecvalueint.size();
2737 ATH_MSG_INFO(
"REGTEST Got Got NumTrkPt500 vector, size: " << vecsize);
2740 for(
const auto & thisvalue : vecvalueint){
2742 ATH_MSG_INFO(
"REGTEST NumTrkPt500 #" << j <<
": " << thisvalue);
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");
2751 std::vector<float> vecvalue;
2753 int vecsize = vecvalue.size();
2754 ATH_MSG_INFO(
"REGTEST Got JVF vector, size: " << vecsize);
2757 for(
const auto & thisvalue : vecvalue){
2759 ATH_MSG_INFO(
"REGTEST JVF #" << j <<
": " << thisvalue);
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");
2766 int vecsize = vecvalue.size();
2767 ATH_MSG_INFO(
"REGTEST Got SumPtTrkPt1000 vector, size: " << vecsize);
2770 for(
const auto & thisvalue : vecvalue){
2772 ATH_MSG_INFO(
"REGTEST SumPtTrkPt1000 #" << j <<
": " << thisvalue);
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");
2779 int vecsize = vecvalue.size();
2780 ATH_MSG_INFO(
"REGTEST Got SumPtTrkPt500 vector, size: " << vecsize);
2783 for(
const auto & thisvalue : vecvalue){
2785 ATH_MSG_INFO(
"REGTEST SumPtTrkPt500 #" << j <<
": " << thisvalue);
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");
2792 int vecsize = vecvalue.size();
2793 ATH_MSG_INFO(
"REGTEST Got TrackWidthPt1000 vector, size: " << vecsize);
2796 for(
const auto & thisvalue : vecvalue){
2798 ATH_MSG_INFO(
"REGTEST TrackWidthPt1000 #" << j <<
": " << thisvalue);
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");
2805 int vecsize = vecvalue.size();
2806 ATH_MSG_INFO(
"REGTEST Got TrackWidthPt500 vector, size: " << vecsize);
2809 for(
const auto & thisvalue : vecvalue){
2811 ATH_MSG_INFO(
"REGTEST TrackWidthPt500 #" << j <<
": " << thisvalue);
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");
2818 int vecsize = vecvalue.size();
2819 ATH_MSG_INFO(
"REGTEST Got EnergyPerSampling vector, size: " << vecsize);
2822 for(
const auto & thisvalue : vecvalue){
2824 ATH_MSG_INFO(
"REGTEST EnergyPerSampling #" << j <<
": " << thisvalue);
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");
2856 return StatusCode::SUCCESS;
2860 if (jetContsize == i)
ATH_MSG_INFO(
"REGTEST size of jet container == number of displayed jets: " << (jetContsize == i) );
2865 if (!onefilled)
ATH_MSG_DEBUG(
"There was no filled jet containers");
2867 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::JetContainer DUMP===========");
2871 return StatusCode::SUCCESS;
2880 ATH_MSG_INFO(
"REGTEST ==========START of TrigEFBjetContainer DUMP===========");
2885 StatusCode
sc = evtStore()->retrieve(trigEFBjet,lastTrigEFBjet);
2886 if (
sc.isFailure()) {
2888 return StatusCode::SUCCESS;
2890 ATH_MSG_INFO(
"REGTEST TrigEFBjetContainers retrieved");
2893 for (
int i=0; trigEFBjet != lastTrigEFBjet; ++trigEFBjet, ++
i) {
2895 ATH_MSG_INFO(
"REGTEST Looking at TrigEFBjetContainer " << i);
2900 for (
int j=0; EFBjetItr != EFBjetItrE; ++EFBjetItr, ++
j ) {
2904 ATH_MSG_INFO(
"REGTEST TrigEFBjet->prmVtx() returns " << (*EFBjetItr)->prmVtx());
2905 ATH_MSG_INFO(
"REGTEST TrigEFBjet->xComb() returns " << (*EFBjetItr)->xComb());
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());
2911 ATH_MSG_INFO(
"REGTEST TrigEFBjet->xIP2D() returns " << (*EFBjetItr)->xIP2D());
2913 ATH_MSG_INFO(
"REGTEST TrigEFBjet->xIP3D() returns " << (*EFBjetItr)->xIP3D());
2915 ATH_MSG_INFO(
"REGTEST TrigEFBjet->xCHI2() returns " << (*EFBjetItr)->xCHI2());
2917 ATH_MSG_INFO(
"REGTEST TrigEFBjet->xSV() returns " << (*EFBjetItr)->xSV());
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());
2924 ATH_MSG_INFO(
"REGTEST ==========END of TrigEFBjetContainer DUMP===========");
2927 return StatusCode::SUCCESS;
2936 ATH_MSG_INFO(
"REGTEST ==========START of TrigL2BjetContainer DUMP===========");
2941 StatusCode sc = evtStore()->retrieve(trigL2Bjet,lastTrigL2Bjet);
2942 if (
sc.isFailure()) {
2944 return StatusCode::SUCCESS;
2946 ATH_MSG_INFO(
"REGTEST TrigL2BjetContainers retrieved");
2949 for (
int i=0; trigL2Bjet != lastTrigL2Bjet; ++trigL2Bjet, ++
i) {
2951 ATH_MSG_INFO(
"REGTEST Looking at TrigL2BjetContainer " << i);
2956 for (
int j=0; L2BjetItr != L2BjetItrE; ++L2BjetItr, ++
j ) {
2959 ATH_MSG_INFO(
"REGTEST TrigL2Bjet->prmVtx() returns " << (*L2BjetItr)->prmVtx());
2960 ATH_MSG_INFO(
"REGTEST TrigL2Bjet->xComb() returns " << (*L2BjetItr)->xComb());
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());
2966 ATH_MSG_INFO(
"REGTEST TrigL2Bjet->xIP2D() returns " << (*L2BjetItr)->xIP2D());
2968 ATH_MSG_INFO(
"REGTEST TrigL2Bjet->xIP3D() returns " << (*L2BjetItr)->xIP3D());
2970 ATH_MSG_INFO(
"REGTEST TrigL2Bjet->xCHI2() returns " << (*L2BjetItr)->xCHI2());
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());
2978 ATH_MSG_INFO(
"REGTEST ==========END of TrigL2BjetContainer DUMP===========");
2981 return StatusCode::SUCCESS;
2990 ATH_MSG_INFO(
"REGTEST ==========START of MuonFeature DUMP===========");
2995 StatusCode sc = evtStore()->retrieve(MuFeature,lastMuFeature);
2996 if (
sc.isFailure()) {
2998 return StatusCode::SUCCESS;
3003 for (
int i=0; MuFeature != lastMuFeature; ++MuFeature, ++
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());
3012 ATH_MSG_INFO(
"REGTEST MuonFeature->pt() returns " << thisMuFeature->
pt());
3015 ATH_MSG_INFO(
"REGTEST MuonFeature->zeta() returns " << thisMuFeature->
zeta());
3017 ATH_MSG_INFO(
"REGTEST MuonFeature->beta() returns " << thisMuFeature->
beta());
3020 ATH_MSG_INFO(
"REGTEST ==========END of MuonFeature DUMP===========");
3023 return StatusCode::SUCCESS;
3032 ATH_MSG_INFO(
"REGTEST ==========START of CombinedMuonFeature DUMP===========");
3037 StatusCode sc = evtStore()->retrieve(CombMuon,lastCombMuon);
3038 if (
sc.isFailure()) {
3040 return StatusCode::SUCCESS;
3042 ATH_MSG_INFO(
"REGTEST CombinedMuonFeatures retrieved");
3044 for (
int i=0; CombMuon != lastCombMuon; ++CombMuon, ++
i) {
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());
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());
3059 ATH_MSG_INFO(
"CombinedMuonFeature has no muFastTrack" );
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());
3077 ATH_MSG_INFO(
"REGTEST ==========END of CombinedMuonFeature DUMP===========");
3080 return StatusCode::SUCCESS;
3086 ATH_MSG_INFO(
"REGTEST ==========START of CombinedMuonFeatureContainer DUMP===========");
3091 StatusCode sc = evtStore()->retrieve(CombMuon,lastCombMuon);
3092 if (
sc.isFailure()) {
3093 ATH_MSG_INFO(
"REGTEST No CombinedMuonFeatureContainer found");
3094 return StatusCode::SUCCESS;
3096 ATH_MSG_INFO(
"REGTEST CombinedMuonFeaturesContainer retrieved");
3098 for (
int j=0; CombMuon != lastCombMuon; ++CombMuon, ++
j) {
3099 ATH_MSG_INFO(
"REGTEST Looking at CombinedMuonFeatureContainer " << j);
3107 ATH_MSG_INFO(
"REGTEST Looking at CombinedMuonFeature " << i);
3109 ATH_MSG_INFO(
"REGTEST CombinedMuonFeature->pt() returns " << (thisCombMuFeature)->
pt());
3110 ATH_MSG_INFO(
"REGTEST CombinedMuonFeature->sigma_pt() returns " << (thisCombMuFeature)->sigma_pt());
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());
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());
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());
3137 return StatusCode::SUCCESS;
3145 ATH_MSG_INFO(
"REGTEST ==========START of TrigEMCluster DUMP===========");
3150 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3151 if (
sc.isFailure()) {
3153 return StatusCode::SUCCESS;
3157 for (
int i=0; EMCluster != lastEMCluster; ++EMCluster, ++
i) {
3161 ATH_MSG_INFO(
"REGTEST Looking at TrigEMCluster " << i);
3164 ATH_MSG_INFO(
"REGTEST TrigEMCluster->e() returns " << thisEMCluster->
e());
3165 ATH_MSG_INFO(
"REGTEST TrigEMCluster->phi() returns " << thisEMCluster->
phi());
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());
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());
3176 ATH_MSG_INFO(
"REGTEST ==========END of TrigEMCluster DUMP===========");
3179 return StatusCode::SUCCESS;
3186 ATH_MSG_INFO(
"REGTEST ==========START of TrigEMCluster DUMP===========");
3191 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3192 if (
sc.isFailure()) {
3194 return StatusCode::SUCCESS;
3199 for (
int i=0; EMCluster != lastEMCluster; ++EMCluster, ++
i) {
3203 ATH_MSG_INFO(
"REGTEST Looking at xAOD::TrigEMCluster " << i);
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());
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());
3218 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::TrigEMCluster DUMP===========");
3221 return StatusCode::SUCCESS;
3230 ATH_MSG_INFO(
"REGTEST ==========START of TrigTauClusterContainer/TrigTauClusterDetailsContainer DUMP===========");
3235 StatusCode sc = evtStore()->retrieve(TauCluster,lastTauCluster);
3236 if (
sc.isFailure()) {
3237 ATH_MSG_INFO(
"REGTEST No TrigTauClusterContainer found");
3238 return StatusCode::SUCCESS;
3240 ATH_MSG_INFO(
"REGTEST TrigTauClusterContainer retrieved");
3244 for (
int i=0; TauCluster != lastTauCluster; ++TauCluster, ++
i) {
3246 ATH_MSG_INFO(
"REGTEST Looking at TrigTauClusterContainer " << i);
3251 for (
int j=0; TauClusterItr != TauClusterItrE; ++TauClusterItr, ++
j ) {
3253 ATH_MSG_INFO(
"REGTEST Looking at TrigTauCluster " << j);
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());
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());
3270 if( (*TauClusterItr)->clusterDetails() == 0 )
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));
3286 sc = evtStore()->retrieve(TauDetailsCluster,lastTauDetailsCluster);
3287 if (
sc.isFailure()) {
3288 ATH_MSG_INFO(
"REGTEST No TrigTauDetailsClusterContainer found");
3289 return StatusCode::SUCCESS;
3291 ATH_MSG_INFO(
"REGTEST TrigTauDetailsClusterContainer retrieved");
3293 for (
int i=0; TauDetailsCluster != lastTauDetailsCluster; ++TauDetailsCluster, ++
i) {
3295 ATH_MSG_INFO(
"REGTEST Looking at TrigTauClusterDetailsContainer " << i);
3300 for (
int j=0; TauDetailsClusterItr != TauDetailsClusterItrE; ++TauDetailsClusterItr, ++
j ) {
3302 ATH_MSG_INFO(
"REGTEST Looking at TrigTauClusterDetails " << j);
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));
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));
3321 if( nDetails != nClusters)
3322 ATH_MSG_WARNING(
"REGTEST inconsistent number of TrigTauClusters ("<< nClusters<<
") and TrigTauClusterDetails ("
3323 << nDetails <<
")");
3325 ATH_MSG_INFO(
"REGTEST ==========END of TrigTauClusterContainer/TrigTauClusterDetailsContainer DUMP===========");
3329 return StatusCode::SUCCESS;
3338 ATH_MSG_INFO(
"REGTEST ==========START of TrigEMClusterContainer DUMP===========");
3343 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3344 if (
sc.isFailure()) {
3345 ATH_MSG_INFO(
"REGTEST No TrigEMClusterContainer found");
3346 return StatusCode::SUCCESS;
3348 ATH_MSG_INFO(
"REGTEST TrigEMClusterContainer retrieved");
3351 for (
int i=0; EMCluster != lastEMCluster; ++EMCluster, ++
i) {
3353 ATH_MSG_INFO(
"REGTEST Looking at TrigEMClusterContainer " << i);
3358 for (
int j=0; EMClusterItr != EMClusterItrE; ++EMClusterItr, ++
j ) {
3360 ATH_MSG_INFO(
"REGTEST Looking at TrigEMCluster " << j);
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());
3369 msg().setLevel(MSG::DEBUG);
3370 (*EMClusterItr)->print(
msg());
3371 msg().setLevel(level);
3375 ATH_MSG_INFO(
"REGTEST ==========END of TrigEMClusterContainer DUMP===========");
3378 return StatusCode::SUCCESS;
3385 ATH_MSG_INFO(
"REGTEST ==========START of xAODTrigEMClusterContainer DUMP===========");
3390 StatusCode sc = evtStore()->retrieve(EMCluster,lastEMCluster);
3391 if (
sc.isFailure()) {
3392 ATH_MSG_INFO(
"REGTEST No xAOD::TrigEMClusterContainer found");
3393 return StatusCode::SUCCESS;
3395 ATH_MSG_INFO(
"REGTEST xAOD::TrigEMClusterContainer retrieved");
3398 for (
int i=0; EMCluster != lastEMCluster; ++EMCluster, ++
i) {
3400 ATH_MSG_INFO(
"REGTEST Looking at xAOD::TrigEMClusterContainer " << i);
3405 for (
int j=0; EMClusterItr != EMClusterItrE; ++EMClusterItr, ++
j ) {
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());
3421 ATH_MSG_INFO(
"REGTEST ==========END of TrigEMClusterContainer DUMP===========");
3424 return StatusCode::SUCCESS;
3432 ATH_MSG_INFO(
"REGTEST ==========START of TileMuFeatureContainer DUMP===========");
3438 if (
sc.isFailure()) {
3439 ATH_MSG_INFO(
"REGTEST No TileMuFeatureContainer found");
3440 return StatusCode::SUCCESS;
3442 ATH_MSG_INFO(
"REGTEST TileMuFeatureContainer retrieved");
3445 ATH_MSG_INFO(
"REGTEST Looking at TileMuFeatureContainer " << i);
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());
3462 ATH_MSG_INFO(
"REGTEST ==========END of TileMuFeatureContainer DUMP===========");
3465 return StatusCode::SUCCESS;
3473 ATH_MSG_INFO(
"REGTEST ==========START of TileTrackMuFeatureContainer DUMP===========");
3478 StatusCode sc = evtStore()->retrieve(TileTrackMu, lastTileTrackMu);
3479 if (
sc.isFailure()) {
3480 ATH_MSG_INFO(
"REGTEST No TileTrackMuFeatureContainer found");
3481 return StatusCode::SUCCESS;
3483 ATH_MSG_INFO(
"REGTEST TileTrackMuFeatureContainer retrieved");
3485 for (
int i=0; TileTrackMu!=lastTileTrackMu; ++TileTrackMu, ++
i) {
3486 ATH_MSG_INFO(
"REGTEST Looking at TileTrackMuFeatureContainer " << i);
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());
3502 ATH_MSG_INFO(
"REGTEST No TileMuFeature (Something Wrong)");
3529 ATH_MSG_INFO(
"REGTEST IDScanLink->algorithmId() returns " <<
Track->algorithmId());
3531 ATH_MSG_INFO(
"REGTEST IDScanLink->NStrawHits() returns ");
3533 ATH_MSG_INFO(
"REGTEST IDScanLink->NStrawTime() returns " <<
Track->NStrawTime());
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());
3542 ATH_MSG_INFO(
"REGTEST ==========END of TileTrackMuFeatureContainer DUMP===========");
3543 ATH_MSG_DEBUG(
"dumpTileTrackMuFeatureContainer() succeeded");
3544 return StatusCode::SUCCESS;
3551 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::TauJetContainer DUMP===========" );
3553 StatusCode sc = evtStore() -> retrieve (TauJetcont,
"HLT_xAOD__TauJetContainer_TrigTauRecMerged");
3555 if (
sc.isFailure()) {
3557 ATH_MSG_INFO(
"REGTEST No Tau container HLT_xAOD__TauJetContainer_TrigTauRecMerged");
3560 return StatusCode::SUCCESS;
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() );
3572 #ifndef XAODTAU_VERSIONS_TAUJET_V3_H
3573 EFnTracks = (*tauIt)->nTracks();
3578 ATH_MSG_INFO(
"REGTEST (*tauIt)->nTracks() returns " << EFnTracks );
3581 int EFWidenTrack = -1;
3582 #ifndef XAODTAU_VERSIONS_TAUJET_V3_H
3583 EFWidenTrack = (*tauIt)->nWideTracks();
3588 ATH_MSG_INFO(
"REGTEST (*tauIt)->nWideTracks() returns " << EFWidenTrack );
3608 ATH_MSG_INFO(
"REGTEST TauDetails->trkAvgDist() returns " << trkAvgDist);
3611 ATH_MSG_INFO(
"REGTEST TauDetails->etOverPtLeadTrk() returns " << etOvPtLead);
3614 ATH_MSG_INFO(
"REGTEST TauDetails->EMRadius() returns " << emRadius);
3617 ATH_MSG_INFO(
"REGTEST TauDetails->hadRadius() returns " << hadRadius);
3620 ATH_MSG_INFO(
"REGTEST TauDetails->isolFrac() returns " << IsoFrac);
3623 ATH_MSG_INFO(
"REGTEST TauDetails->centFrac() returns " << centFrac);
3626 ATH_MSG_INFO(
"REGTEST TauDetails->ipSigLeadTrk() returns " << ipSigLeadTrk);
3629 ATH_MSG_INFO(
"REGTEST TauDetails->trFlightPathSig() returns " << trFlightPathSig);
3632 ATH_MSG_INFO(
"REGTEST TauDetails->dRmax() returns " << dRmax);
3636 ATH_MSG_INFO(
"REGTEST TauDetails->massTrkSys() returns " << massTrkSys);}
3639 ATH_MSG_INFO(
"REGTEST TauDetails->PSSFraction() returns " << PSSFraction);
3642 ATH_MSG_INFO(
"REGTEST TauDetails->EMPOverTrkSysP() returns " << EMPOverTrkSysP);
3645 ATH_MSG_INFO(
"REGTEST TauDetails->ChPiEMEOverCaloEME() returns " << ChPiEMEOverCaloEME);
3649 ATH_MSG_INFO(
"REGTEST TauDetails->etEMAtEMScale() returns " << EtEm);}
3653 ATH_MSG_INFO(
"REGTEST TauDetails->etHadAtEMScale() returns " << EtHad);}
3656 if( !(*tauIt)->jetLink().isValid() ) {
3658 return StatusCode::SUCCESS;
3661 const xAOD::Jet* pJetSeed = *((*tauIt)->jetLink());
3666 for (
int clusCount = 0; clusItr != clusItrE; ++clusItr, ++clusCount) {
3668 ATH_MSG_INFO(
"REGTEST Tau Cluster " << clusCount <<
" pt = " << (*clusItr)->pt()
3669 <<
" eta = " << (*clusItr)->eta()
3670 <<
" phi = " << (*clusItr)->phi() );
3675 for (
unsigned int trackNum = 0; trackNum < (*tauIt)->nTracks(); ++trackNum) {
3680 return StatusCode::SUCCESS;
3694 return StatusCode::SUCCESS;
3703 ATH_MSG_INFO(
"REGTEST ==========START of TauJetContainer DUMP===========");
3707 StatusCode sCode=StatusCode::FAILURE;
3709 std::string TauContainerTags[]={
"HLT_TrigTauRecMerged"};
3710 for (
int itag=0; itag < ntag; itag++) {
3712 sCode=evtStore()->retrieve(TauJetcont , TauContainerTags[itag]);
3713 if( sCode.isFailure() ){
3714 ATH_MSG_INFO(
"Failed to retrieve TauJetContainer with key " << TauContainerTags[itag]);
3720 bool IsTaurec =
false;
3721 bool Is1p3p =
false;
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());
3748 ATH_MSG_INFO(
"REGTEST TauDetails->ipZ0SinThetaSigLeadTrk() returns " <<
TauDetails->ipZ0SinThetaSigLeadTrk());
3761 ATH_MSG_INFO(
"REGTEST TauDetails->seedCalo_stripWidth2() returns " <<
TauDetails->seedCalo_stripWidth2());
3763 ATH_MSG_INFO(
"REGTEST TauDetails->seedCalo_etEMAtEMScale() returns " <<
TauDetails->seedCalo_etEMAtEMScale());
3764 ATH_MSG_INFO(
"REGTEST TauDetails->seedCalo_etHADAtEMScale() returns " <<
TauDetails->seedCalo_etHadAtEMScale());
3766 ATH_MSG_INFO(
"REGTEST TauDetails->seedCalo_nIsolLooseTrk() returns " <<
TauDetails->seedCalo_nIsolLooseTrk());
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());
3784 ATH_MSG_INFO(
"REGTEST TauDetails->seedTrk_sumEMCellEtOverLeadTrkPt() returns " <<
TauDetails->seedTrk_sumEMCellEtOverLeadTrkPt());
3785 ATH_MSG_INFO(
"REGTEST TauDetails->seedTrk_secMaxStripEt() returns " <<
TauDetails->seedTrk_secMaxStripEt());
3789 ATH_MSG_INFO(
"REGTEST TauDetails->seedTrk_nOtherCoreTrk() returns " <<
TauDetails->seedTrk_nOtherCoreTrk());
3803 ATH_MSG_INFO(
"REGTEST TauDetails->looseTrk() link present ");
3805 ATH_MSG_INFO(
"REGTEST TauDetails->looseTrk() link missing ");
3841 StatusCode
sc = evtStore()->retrieve(
TauJet, lastTauJet);
3842 if (
sc.isFailure()) {
3844 return StatusCode::FAILURE;
3854 return StatusCode::SUCCESS;
3861 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::TrackParticle DUMP===========");
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");
3872 StatusCode returnsc = StatusCode::SUCCESS;
3874 for (
unsigned int SGkey = 0; SGkey < SGkeys.size(); ++SGkey) {
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));
3881 ATH_MSG_INFO(
"REGTEST TrackParticleContainer retrieved with key " << SGkeys.at(SGkey)
3882 <<
" and size " << trackParticleContainer->
size());
3887 for (
int index = 0; trackParticleItr != trackParticleLast; ++trackParticleItr, ++
index) {
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());
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());
3912 ATH_MSG_INFO(
"REGTEST chiSquared: " << (*trackParticleItr)->chiSquared()
3913 <<
"/numberDoF: " << (*trackParticleItr)->numberDoF());
3918 msg() << MSG::INFO <<
"REGTEST ";
3919 uint8_t numberOfBLayerHits = 0;
3921 msg() <<
"/numberOfBLayerHits: " <<
static_cast<int>(numberOfBLayerHits);
3923 msg() <<
"/numberOfBLayerHits not found";
3926 uint8_t numberOfPixelHits = 0;
3928 msg() <<
"/numberOfPixelHits: " <<
static_cast<int>(numberOfPixelHits);
3930 msg() <<
"/numberOfPixelHits not found";
3933 uint8_t numberOfPixelHoles = 0;
3935 msg() <<
"/numberOfPixelHoles: " <<
static_cast<int>(numberOfPixelHoles);
3937 msg() <<
"/numberOfPixelHoles not found";
3940 uint8_t numberOfSCTHits = 0;
3942 msg() <<
"/numberOfSCTHits: " <<
static_cast<int>(numberOfSCTHits);
3944 msg() <<
"/numberOfSCTHits not found";
3947 uint8_t numberOfSCTHoles = 0;
3949 msg() <<
"/numberOfSCTHoles: " <<
static_cast<int>(numberOfSCTHoles);
3951 msg() <<
"/numberOfSCTHoles not found";
3954 uint8_t numberOfTRTHits = 0;
3956 msg() <<
"/numberOfTRTHits: " <<
static_cast<int>(numberOfTRTHits);
3958 msg() <<
"/numberOfTRTHits not found";
3961 uint8_t numberOfTRTHoles = 0;
3963 msg() <<
"/numberOfTRTHoles: " <<
static_cast<int>(numberOfTRTHoles);
3965 msg() <<
"/numberOfTRTHoles not found";
3971 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::TrackParticle DUMP===========");
3981 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::Vertex DUMP===========");
3984 StatusCode
sc =
evtStore()->retrieve(vertexContainer,
"HLT_xAOD__VertexContainer_xPrimVx");
3985 if (
sc.isFailure()) {
3987 return StatusCode::FAILURE;
3994 for (
int index = 0; vertexItr != vertexLast; ++vertexItr, ++
index) {
3999 <<
"/y: " << (*vertexItr)->y()
4000 <<
"/z: " << (*vertexItr)->z());
4003 ATH_MSG_INFO(
"REGTEST chiSquared: " << (*vertexItr)->chiSquared()
4004 <<
"/numberDoF: " << (*vertexItr)->numberDoF());
4007 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::Vertex DUMP===========");
4010 return StatusCode::SUCCESS;
4015 ATH_MSG_INFO(
"REGTEST ==========START of TDT DUMP===========" );
4018 if (chain.empty()) {
4021 std::vector<std::string> confChains =
m_trigDec->getListOfTriggers(chain);
4022 for (
const auto& item : confChains) {
4025 if (
m_trigDec->getNavigationFormat() ==
"TriggerElement") {
4030 if (passFeatures.size()) {
4031 ATH_MSG_INFO(
" " << item <<
" Passed Final IParticle features size: " << passFeatures.size());
4033 if (!li.isValid()) {
4037 std::string state =
"ACTIVE";
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() <<
"}");
4048 if (passAndFailFeatures.size()) {
4049 ATH_MSG_INFO(
" " << item <<
" Passed+Failed Final IParticle features size: " << passAndFailFeatures.size());
4051 if (!li.isValid()) {
4055 std::string state =
"ACTIVE";
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() <<
"}");
4066 if (allFeatures.size()) {
4067 ATH_MSG_INFO(
" " << item <<
" Passed+Failed ALL IParticle features size: " << allFeatures.size());
4069 if (!li.isValid()) {
4073 std::string state =
"ACTIVE";
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() <<
"}");
4085 if (
m_trigDec->getNavigationFormat() ==
"TrigComposite") {
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.");
4098 ATH_MSG_VERBOSE(
" -- Track " << std::distance(startIt, it) <<
" in this ROI, pT: " << (*it)->pt() );
4103 ATH_MSG_INFO(
"REGTEST ==========END of TDT DUMP===========" );
4104 return StatusCode::SUCCESS;
4108 ATH_MSG_INFO(
"REGTEST ==========START of xAOD::TrigCompositeContainer DUMP===========" );
4114 std::string typeNameTC;
4127 ATH_MSG_DEBUG(
"#################### Dumping container of : " << key );
4132 for (
auto tc: *cont ) {
4139 ATH_MSG_INFO(
"REGTEST ==========END of xAOD::TrigCompositeContainer DUMP===========" );
4140 return StatusCode::SUCCESS;
4147 const std::string name =
tc->linkColNames().at(element);
4148 const CLID clid =
static_cast<CLID>(
tc->linkColClids().at(element));
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);
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);
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() <<
"'");
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);
4175 }
else if (name ==
"feature") {
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());
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());
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() <<
"'");
4202 ATH_MSG_DEBUG(
" Ignoring link to '" << name <<
"' with link CLID " << clid);
4205 return StatusCode::SUCCESS;
4216 std::vector<std::string> keys;
4218 evtStore()->keys(TrigCompositeCLID, keys);
4223 std::string typeNameTC;
4225 ATH_MSG_DEBUG(
"Got " << keys.size() <<
" keys for " << typeNameTC);
4229 chainIDs.insert( chainID.
numeric() );
4231 std::set<int> converted;
4236 for (
const std::string& chain : chains) {
4239 chainIDs.insert( chainID_tmp.
numeric() );
4241 if (legMultiplicites.size() == 0) {
4242 ATH_MSG_ERROR(
"chain " << chainID_tmp <<
" has invalid configuration, no multiplicity data.");
4243 }
else if (legMultiplicites.size() > 1) {
4246 for (
size_t legNumeral = 0; legNumeral < legMultiplicites.size(); ++legNumeral) {
4248 chainIDs.insert( legID.
numeric() );
4255 for (
const std::string& key : keys)
ATH_CHECK(
evtStore()->retrieve( container, key ) );
4257 std::stringstream
ss;
4258 ss <<
"digraph {" << std::endl;
4259 ss <<
" node [shape=rectangle]" << std::endl;
4260 ss <<
" rankdir = BT" << std::endl;
4263 for (
const std::string& key : keys) {
4265 if ( not key.starts_with(
"HLTNav_") ) {
4270 ATH_MSG_DEBUG(
"Processing collection " << key <<
" to be added to the navigation graph");
4272 bool writtenHeader =
false;
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();
4284 bool doDump =
false;
4287 if (chainIDs.count(
id) == 1) {
4295 const std::vector<DecisionID>& seedDecisions = (*s)->decisions();
4297 if (chainIDs.count(
id) == 1) {
4308 if (!writtenHeader) {
4309 writtenHeader =
true;
4310 ss <<
" subgraph " << key <<
" {" << std::endl;
4311 ss <<
" label=\"" << key <<
"\"" << std::endl;
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>=";
4330 for (
unsigned decisionID : decisions) {
4332 std::string highlight = (dID.
numeric() == chainID.
numeric() ?
"<B>[CHAIN:" :
"");
4336 ss << std::hex << highlight << decisionID << (!highlight.empty() ?
"]</B>" :
"") << std::dec <<
",";
4343 ss <<
">]" << std::endl;
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") {
4350 const uint32_t seedKey =
tc->linkColKeys().at(i);
4351 const uint32_t seedIndex =
tc->linkColIndices().at(i);
4355 const std::vector<DecisionID> seedDecisions = (*seedEL)->decisions();
4356 bool doSeedLink =
false;
4358 if (chainIDs.count(
id) == 1) {
4367 ss <<
" \"" << selfKey <<
"_" << selfIndex <<
"\" -> \"" << seedKey <<
"_" << seedIndex <<
"\" [colorscheme="<<scheme<<
",color=9,fontcolor=8,label=\"seed\"]" << std::endl;
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) );
4384 const unsigned index = (isRemapped ?
tc->linkColIndicesRemap().at(i) :
tc->linkColIndices().at(i));
4387 const std::string* keyStr =
evtStore()->keyToString(key, checkCLID);
4388 if (keyStr !=
nullptr && checkCLID != linkCLID) {
4389 std::string tnameOfCheck;
4390 m_clidSvc->getTypeNameOfID(checkCLID, tnameOfCheck).ignore();
4391 ATH_MSG_ERROR(
"Inconsistent CLID " << checkCLID <<
" [" << tnameOfCheck <<
"] stored in storegate for key " << key
4392 <<
". We were expecting " << linkCLID <<
" [" << tname <<
"]");
4395 std::string tnameEscape;
4396 for (std::string::const_iterator i = tname.begin(); i != tname.end(); ++i) {
4397 unsigned char c = *i;
4399 tnameEscape +=
"<";
4400 }
else if (c ==
'>') {
4401 tnameEscape +=
">";
4408 ss <<
" \"" << selfKey <<
"_" << selfIndex <<
"\" -> \"" << key <<
"_" <<
index <<
"\" ";
4409 ss <<
"[colorscheme="<<extScheme<<
",color="<<linkColour<<
",fontcolor="<<linkColour<<
",arrowhead=empty,label=\"" << link <<
"\"]" << std::endl;
4412 const bool linkToSelf = (selfKey == key and selfIndex ==
index);
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 <<
">]";
4421 converted.insert(key +
index);
4425 if (writtenHeader) {
4426 ss <<
" }" << std::endl;
4430 ss <<
"}" << std::endl;
4432 returnValue.assign(
ss.str() );
4433 return StatusCode::SUCCESS;
4446 const std::vector< unsigned int > serialisedNavigation = navigationHandle->
serialized();
4447 ATH_MSG_INFO(
"Serialised navigation size: " << serialisedNavigation.size() );
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;
4465 unsigned int chainCounter = 0;
4466 std::map< int, std::string > hash2chain;
4467 for (
auto const& chain : testMenu->front()->chainSignatureOutputTEs() ) {
4470 std::string chainName = testMenu->front()->chainNames()[ chainCounter ];
4474 for (
auto const& signature : chain ) {
4475 for (
auto const& name : signature ) {
4477 hash2string[
hash ] = name;
4478 hash2chain[
hash ] = chainName;
4487 if ( lhs.
getCLID() == rhs.getCLID() )
return ( lhs.
getIndex() < rhs.getIndex() );
4490 else return ( lhs.
getCLID() < rhs.getCLID() );
4492 std::map< HLT::TriggerElement::FeatureAccessHelper, std::vector< HLT::TriggerElement* >,
decltype(cmpLambda) > feature2element(cmpLambda);
4495 std::vector< HLT::TriggerElement* > allTEs;
4496 testNav->
getAll( allTEs,
false );
4497 for (
auto element : allTEs ) {
4500 for (
auto helper : element->getFeatureAccessHelpers() ) {
4501 feature2element[ helper ].push_back( element );
4507 for (
auto element : allTEs ) {
4509 ATH_MSG_INFO(
"+++++++++++ " << hash2string[ element->getId() ] <<
" is terminal node" );
4511 std::queue< HLT::TriggerElement* > allAncestors;
4512 allAncestors.push( element );
4513 while ( allAncestors.size() ) {
4528 for (
auto ancestor : theseAncestors ) {
4529 allAncestors.push( ancestor );
4537 auto decisionOutput = outputNavigation.
ptr();
4540 std::map< HLT::TriggerElement const*, std::vector< int > > element2decisions;
4541 for (
const auto&
pair : feature2element ) {
4544 std::string featureName = testNav->
label(
pair.first.getCLID(),
pair.first.getIndex().subTypeIndex() );
4545 auto sgKey =
evtStore()->stringToKey( featureName,
pair.first.getCLID() );
4548 std::string storeFeatureName =
"feature";
4555 decision->typelessSetObjectLink( storeFeatureName, sgKey,
pair.first.getCLID(),
pair.first.getIndex().objectsBegin(),
pair.first.getIndex().objectsEnd() );
4558 std::set< std::string > passedChains;
4562 passedChains.insert( hash2chain[ element->
getId() ] );
4565 int decisionNumber = decisionOutput->size() - 1;
4566 element2decisions[ element ].push_back( decisionNumber );
4570 for (
auto& chain : passedChains ) {
4576 unsigned int decisionCounter = 0;
4577 for (
const auto&
pair : feature2element ) {
4580 auto decision = decisionOutput->at( decisionCounter );
4584 for (
auto element :
pair.second ) {
4586 for (
auto ancestor : theseAncestors ) {
4587 for (
int decisionIndex : element2decisions[ ancestor ] ) {
4594 return StatusCode::SUCCESS;
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method
Scalar theta() const
theta method
#define ATH_CHECK
Evaluate an expression and check for errors.
ElementLink()
Default constructor.
bool isValid() const
Test to see if the link can be dereferenced.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(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.
xAOD::TrigComposite Decision
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.
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.
DataVector< SG::View > ViewContainer
View container for recording in StoreGate.
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
DataModel_detail::const_iterator< DataVector > const_iterator
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.
ElementLink implementation for ROOT usage.
index_type index() const
Get the index of the element inside of its container.
bool isValid() const
Check if the element can be found.
sgkey_t key() const
Get the key that we reference, as a hash.
HLT::HLTResult is sumarising result of trigger decision evaluation (online/offline) It contains basic...
bool isAccepted() const
gets HLT decision
bool isPassThrough() const
forced-accepted (FA) event configuration the FA request(s) are set per chain and hlt level by the tig...
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.
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
class_id_type getCLID() const
Class ID of object.
TriggerElement is the basic ingreedient of the interface between HLT algorithms and the navigation It...
@ seededByRelation
what TEs are seeding me
te_id_type getId() const
reset internals.
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
a link optimized in size for a GenParticle in a McEventCollection
HepMC::ConstGenParticlePtr cptr() const
Dereference.
int barcode() const
Return the barcode of the target particle.
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.
const emtaus_type & getEmTauROIs() const
Get all the em/tau RoIs in the event.
float dir_zeta(void) const
float dir_phi(void) const
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.
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.
float eta() const
Eta (computed as the average of the eta values of the TileCal cells where the muon goes through).
float phi() const
Phi (average value at the TileCal radius).
float quality() const
Quality flag (0 or 1): set to 0 if the "energy deposition path" is MIP like in all three samples (tig...
const std::vector< float > & enedep() const
Energy deposition by the muons in TileCal: 1st component: energy deposited in innermost layer (A cell...
HLT chain configuration information.
const std::string & chain_name() const
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()
bool m_doDumpTileMuFeature
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_doDumpTrigMissingET
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()
void dumpTrigT2MBTSBits()
bool m_doDumpTrigEMClusterContainer
bool m_doDumpTrigPassBits
bool m_doDumpTrigEMCluster
bool m_doDumpTauJetContainer
bool m_doDumpxAODTauJetContainer
StatusCode dumpxAODVertex()
void dumpTrigVertexCounts()
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
void dumpTrigTrackCounts()
bool m_doDumpTileTrackMuFeature
bool m_doDumpTrigCompsiteNavigation
Gaudi::Property< bool > m_excludeFailedHypoNodes
bool m_doDumpxAODTrigPhotonContainer
bool m_doDumpxAODPhotonContainer
StatusCode dumpxAODMuonContainer()
bool m_doDumpxAODTrigMinBias
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
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 eta() const
get Eta (calibrated)
float e() const
get Energy (calibrated)
float energy() const
get Energy (calibrated)
float weta2() const
get cluster width (based on a 3x5 cluster - 2nd layer)
float phi() const
get Phi (calibrated)
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
Class for LVL2/EF MissingET trigger.
const Rec::TrackParticle * getIDTrackParticle() const
Get associated ID track.
TrigMuonEFCbTrack * CombinedTrack()
unsigned short int MuonType() const
bool hasSpectrometerTrack() const
bool hasExtrapolatedTrack() const
bool hasCombinedTrack() const
TrigMuonEFTrack * ExtrapolatedTrack()
TrigMuonEFTrack * SpectrometerTrack()
const TrigMuonEFInfoTrackContainer * TrackContainer() const
EDM class for holding results of EF muon isolation calculation.
int trackPosition() const
Position of the muon in the TrigMuonEFInfoTrack container.
float sumEtCone02() const
float sumEtCone04() const
float sumTrkPtCone02() const
const TrigMuonEFInfoTrack * getEFMuonInfoTrack() const
Access the muon we calculated the isolation for.
float sumEtCone01() const
float sumEtCone03() const
const TrigMuonEFInfo * getMuonInfo() const
Access the muon info object we calculated the isolation for.
float sumTrkPtCone03() const
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.
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
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...
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
float pixelClusSizeMin() 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
float pixelClusSizeMax() const
float pixelClusTotMax() const
float pixelClusTotMin() 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 ®x)
does a string contain the substring
int count(std::string s, const std::string ®x)
count how many occurances of a regx are in a string
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.
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.
@ INACTIVE
The link was inactive for all of the HLT Chains requested in the TDT.
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 requireDecision
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).
static const unsigned int Physics
ParametersT< TrackParametersDim, Charged, PerigeeSurface > Perigee
ParametersBase< TrackParametersDim, Charged > TrackParameters
@ numberOfSCTHits
number of SCT holes
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
@ numberOfTRTHits
number of TRT outliers
@ 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
@ ethad
ET leakage into hadronic calorimeter with exclusion of energy in CaloSampling::TileGap3.
@ 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
@ e132
uncalibrated energy (sum of cells) in strips in a 3x2 window in cells in eta X phi
@ e011
uncalibrated energy (sum of cells) in presampler in a 1x1 window in cells in eta X phi
@ 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.
@ EMRadius
Get E_T radius.
@ etHadAtEMScale
Get Hadronic energy at EM scale.
@ isolFrac
Get isolation fraction.
@ trkAvgDist
Get calibrated EM transverse energy (DEPRECATED since r19).
@ etEMAtEMScale
Get EM energy at EM scale.
@ centFrac
Get centrality fraction.
@ dRmax
Get maximal dR of tracks associated to calo-seeded tau.
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".
TrigT2MbtsBitsContainer_v1 TrigT2MbtsBitsContainer
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.
static constexpr CLID ID()
Helper to keep a Decision object, ElementLink and ActiveState (with respect to some requested ChainGr...
@ GhostTruthParticleCount