333 auto tTopo = resources.tTopo_;
334 auto trackertruth = resources.trackerHitAssoc_;
335 auto const & csctruth = *resources.cscHitAssoc_;
336 auto const& dttruth = *resources.dtHitAssoc_;
337 auto const& rpctruth = *resources.rpcHitAssoc_;
339 int tracker_nshared = 0;
340 int muon_nshared = 0;
341 int global_nshared = 0;
343 double tracker_quality = 0;
344 double tracker_quality_cut;
348 double muon_quality = 0;
349 double muon_quality_cut;
353 double global_quality = 0;
355 double tracker_purity = 0;
356 double muon_purity = 0;
357 double global_purity = 0;
368 tPC.reserve(TPCollectionH.
size());
369 for(
auto const& ref: TPCollectionH) {
373 bool any_trackingParticle_matched =
false;
376 for (TrackHitsCollection::const_iterator track=tC.begin(); track!=tC.end(); track++, tindex++) {
378 <<
"\n"<<
"reco::Track "<<tindex
379 <<
", number of RecHits = "<< (track->second - track->first) <<
"\n";
381 tracker_matchedIds_valid.clear();
382 muon_matchedIds_valid.clear();
384 tracker_matchedIds_INVALID.clear();
385 muon_matchedIds_INVALID.clear();
387 int n_matching_simhits = 0;
391 int n_tracker_all = 0;
397 int n_tracker_valid = 0;
398 int n_muon_valid = 0;
403 int n_tracker_matched_valid = 0;
404 int n_muon_matched_valid = 0;
405 int n_dt_matched_valid = 0;
406 int n_csc_matched_valid = 0;
407 int n_rpc_matched_valid = 0;
410 int n_tracker_INVALID = 0;
411 int n_muon_INVALID = 0;
412 int n_dt_INVALID = 0;
413 int n_csc_INVALID = 0;
414 int n_rpc_INVALID = 0;
416 int n_tracker_matched_INVALID = 0;
417 int n_muon_matched_INVALID = 0;
418 int n_dt_matched_INVALID = 0;
419 int n_csc_matched_INVALID = 0;
420 int n_rpc_matched_INVALID = 0;
423 getMatchedIds(tracker_matchedIds_valid, muon_matchedIds_valid,
424 tracker_matchedIds_INVALID, muon_matchedIds_INVALID,
425 n_tracker_valid, n_dt_valid, n_csc_valid, n_rpc_valid,
426 n_tracker_matched_valid, n_dt_matched_valid, n_csc_matched_valid, n_rpc_matched_valid,
427 n_tracker_INVALID, n_dt_INVALID, n_csc_INVALID, n_rpc_INVALID,
428 n_tracker_matched_INVALID, n_dt_matched_INVALID, n_csc_matched_INVALID, n_rpc_matched_INVALID,
429 track->first, track->second,
430 trackertruth, dttruth, csctruth, rpctruth,
433 n_matching_simhits = tracker_matchedIds_valid.size() + muon_matchedIds_valid.size() +
434 tracker_matchedIds_INVALID.size() +muon_matchedIds_INVALID.size();
436 n_muon_valid = n_dt_valid + n_csc_valid + n_rpc_valid;
437 n_valid = n_tracker_valid + n_muon_valid;
438 n_muon_INVALID = n_dt_INVALID + n_csc_INVALID + n_rpc_INVALID;
439 n_INVALID = n_tracker_INVALID + n_muon_INVALID;
442 n_tracker_all = n_tracker_valid + n_tracker_INVALID;
443 n_dt_all = n_dt_valid + n_dt_INVALID;
444 n_csc_all = n_csc_valid + n_csc_INVALID;
445 n_rpc_all = n_rpc_valid + n_rpc_INVALID;
446 n_all = n_valid + n_INVALID;
448 n_muon_matched_valid = n_dt_matched_valid + n_csc_matched_valid + n_rpc_matched_valid;
449 n_muon_matched_INVALID = n_dt_matched_INVALID + n_csc_matched_INVALID + n_rpc_matched_INVALID;
452 int n_tracker_selected_hits = n_tracker_valid;
453 int n_muon_selected_hits = n_muon_valid;
454 int n_dt_selected_hits = n_dt_valid;
455 int n_csc_selected_hits = n_csc_valid;
456 int n_rpc_selected_hits = n_rpc_valid;
459 int n_tracker_matched = n_tracker_matched_valid;
460 int n_muon_matched = n_muon_matched_valid;
461 int n_dt_matched = n_dt_matched_valid;
462 int n_csc_matched = n_csc_matched_valid;
463 int n_rpc_matched = n_rpc_matched_valid;
470 InvMuonHits =
" ***INVALID MUON HITS***";
471 ZeroHitMuon =
" ***ZERO-HIT MUON***";
473 n_muon_selected_hits = n_muon_INVALID;
474 n_dt_selected_hits = n_dt_INVALID;
475 n_csc_selected_hits = n_csc_INVALID;
476 n_rpc_selected_hits = n_rpc_INVALID;
478 n_muon_matched = n_muon_matched_INVALID;
479 n_dt_matched = n_dt_matched_INVALID;
480 n_csc_matched = n_csc_matched_INVALID;
481 n_rpc_matched = n_rpc_matched_INVALID;
484 int n_selected_hits = n_tracker_selected_hits + n_muon_selected_hits;
485 int n_matched = n_tracker_matched + n_muon_matched;
488 <<
"\n"<<
"# TrackingRecHits: "<<(track->second - track->first)
489 <<
"\n"<<
"# used RecHits = " <<n_all <<
" ("<<n_tracker_all<<
"/"
490 <<n_dt_all<<
"/"<<n_csc_all<<
"/"<<n_rpc_all<<
" in Tracker/DT/CSC/RPC)"<<
", obtained from " << n_matching_simhits <<
" SimHits"
491 <<
"\n"<<
"# selected RecHits = " <<n_selected_hits <<
" (" <<n_tracker_selected_hits<<
"/"
492 <<n_dt_selected_hits<<
"/"<<n_csc_selected_hits<<
"/"<<n_rpc_selected_hits<<
" in Tracker/DT/CSC/RPC)"<<InvMuonHits
493 <<
"\n"<<
"# matched RecHits = " <<n_matched<<
" ("<<n_tracker_matched<<
"/"
494 <<n_dt_matched<<
"/"<<n_csc_matched<<
"/"<<n_rpc_matched<<
" in Tracker/DT/CSC/RPC)";
496 if (printRtS && n_all>0 && n_matching_simhits==0)
498 <<
"*** WARNING in MuonAssociatorByHitsHelper::associateSimToReco: no matching PSimHit found for this reco::Track !";
500 if (n_matching_simhits != 0) {
502 for (TrackingParticleCollection::const_iterator trpart = tPC.begin(); trpart != tPC.end(); ++trpart, ++tpindex) {
505 int n_tracker_recounted_simhits = 0;
506 int n_muon_simhits = 0;
507 int n_global_simhits = 0;
510 int n_tracker_selected_simhits = 0;
511 int n_muon_selected_simhits = 0;
512 int n_global_selected_simhits = 0;
515 tracker_nshared =
getShared(tracker_matchedIds_valid, trpart);
516 muon_nshared =
getShared(muon_matchedIds_valid, trpart);
519 muon_nshared =
getShared(muon_matchedIds_INVALID, trpart);
521 global_nshared = tracker_nshared + muon_nshared;
522 if (global_nshared == 0)
continue;
588 n_tracker_recounted_simhits = trpart->numberOfTrackerHits();
590 n_muon_simhits = trpart->numberOfHits() - trpart->numberOfTrackerHits();
593 if (trpart->numberOfHits()==0) {
595 n_tracker_recounted_simhits = tracker_nshared;
596 n_muon_simhits = muon_nshared;
598 n_global_simhits = n_tracker_recounted_simhits + n_muon_simhits;
601 n_muon_selected_simhits = n_muon_simhits;
602 n_global_selected_simhits = n_muon_selected_simhits;
605 n_tracker_selected_simhits = n_tracker_recounted_simhits;
606 n_global_selected_simhits += n_tracker_selected_simhits;
610 else if (n_tracker_selected_simhits!=0)
611 tracker_quality =
static_cast<double>(tracker_nshared)/static_cast<double>(n_tracker_selected_simhits);
612 else tracker_quality = 0;
615 else if (n_muon_selected_simhits!=0)
616 muon_quality =
static_cast<double>(muon_nshared)/static_cast<double>(n_muon_selected_simhits);
617 else muon_quality = 0;
620 if (n_global_selected_simhits != 0) {
622 global_quality = global_nshared;
624 global_quality =
static_cast<double>(global_nshared)/static_cast<double>(n_global_selected_simhits);
626 else global_quality = 0;
629 if (n_selected_hits != 0) {
631 global_purity = global_nshared;
633 global_purity =
static_cast<double>(global_nshared)/static_cast<double>(n_selected_hits);
635 else global_purity = 0;
637 bool trackerOk =
false;
638 if (n_tracker_selected_hits != 0) {
639 if (tracker_quality > tracker_quality_cut) trackerOk =
true;
641 tracker_purity =
static_cast<double>(tracker_nshared)/static_cast<double>(n_tracker_selected_hits);
651 if (n_muon_selected_hits != 0) {
652 if (muon_quality > muon_quality_cut) muonOk =
true;
654 muon_purity =
static_cast<double>(muon_nshared)/static_cast<double>(n_muon_selected_hits);
661 bool matchOk = trackerOk || muonOk;
665 matchOk = trackerOk && muonOk;
669 outputCollection[tpindex].push_back(IndexMatch(tindex,global_quality));
670 any_trackingParticle_matched =
true;
673 <<
"************************************************************************************************************************"
674 <<
"\n"<<
"TrackingParticle " << tpindex <<
", q = "<<(*trpart).charge()<<
", p = "<<(*trpart).p()
675 <<
", pT = "<<(*trpart).pt()<<
", eta = "<<(*trpart).eta()<<
", phi = "<<(*trpart).phi()
676 <<
"\n"<<
" pdg code = "<<(*trpart).pdgId()
677 <<
", made of "<<(*trpart).numberOfHits()<<
" PSimHits, recounted "<<n_global_simhits<<
" PSimHits"
678 <<
" (tracker:"<<n_tracker_recounted_simhits<<
"/muons:"<<n_muon_simhits<<
")"
679 <<
", from "<<(*trpart).g4Tracks().size()<<
" SimTrack:";
681 g4T!=(*trpart).g4Track_end();
684 <<
" Id:"<<(*g4T).trackId()<<
"/Evt:("<<(*g4T).eventId().event()<<
","<<(*g4T).eventId().bunchCrossing()<<
")";
687 <<
"\t selected "<<n_global_selected_simhits<<
" PSimHits"
688 <<
" (tracker:"<<n_tracker_selected_simhits<<
"/muons:"<<n_muon_selected_simhits<<
")"
689 <<
"\n\t **MATCHED** with quality = "<<global_quality<<
" (tracker: "<<tracker_quality<<
" / muon: "<<muon_quality<<
")"
690 <<
"\n\t and purity = "<<global_purity<<
" (tracker: "<<tracker_purity<<
" / muon: "<<muon_purity<<
")"
691 <<
"\n\t N shared hits = "<<global_nshared<<
" (tracker: "<<tracker_nshared<<
" / muon: "<<muon_nshared<<
")"
692 <<
"\n" <<
" to: reco::Track "<<tindex<<ZeroHitMuon
693 <<
"\n\t"<<
" made of "<<n_selected_hits<<
" RecHits (tracker:"<<n_tracker_valid<<
"/muons:"<<n_muon_selected_hits<<
")";
697 if (global_nshared != 0) {
699 <<
"************************************************************************************************************************"
700 <<
"\n"<<
"TrackingParticle " << tpindex <<
", q = "<<(*trpart).charge()<<
", p = "<<(*trpart).p()
701 <<
", pT = "<<(*trpart).pt()<<
", eta = "<<(*trpart).eta()<<
", phi = "<<(*trpart).phi()
702 <<
"\n"<<
" pdg code = "<<(*trpart).pdgId()
703 <<
", made of "<<(*trpart).numberOfHits()<<
" PSimHits, recounted "<<n_global_simhits<<
" PSimHits"
704 <<
" (tracker:"<<n_tracker_recounted_simhits<<
"/muons:"<<n_muon_simhits<<
")"
705 <<
", from "<<(*trpart).g4Tracks().size()<<
" SimTrack:";
707 g4T!=(*trpart).g4Track_end();
710 <<
" Id:"<<(*g4T).trackId()<<
"/Evt:("<<(*g4T).eventId().event()<<
","<<(*g4T).eventId().bunchCrossing()<<
")";
713 <<
"\t selected "<<n_global_selected_simhits<<
" PSimHits"
714 <<
" (tracker:"<<n_tracker_selected_simhits<<
"/muons:"<<n_muon_selected_simhits<<
")"
715 <<
"\n\t NOT matched to reco::Track "<<tindex<<ZeroHitMuon
716 <<
" with quality = "<<global_quality<<
" (tracker: "<<tracker_quality<<
" / muon: "<<muon_quality<<
")"
717 <<
"\n\t and purity = "<<global_purity<<
" (tracker: "<<tracker_purity<<
" / muon: "<<muon_purity<<
")"
718 <<
"\n\t N shared hits = "<<global_nshared<<
" (tracker: "<<tracker_nshared<<
" / muon: "<<muon_nshared<<
")";
725 if (!any_trackingParticle_matched) {
728 <<
"************************************************************************************************************************"
729 <<
"\n NO TrackingParticle associated to ANY input reco::Track ! \n"
730 <<
"************************************************************************************************************************"<<
"\n";
733 <<
"************************************************************************************************************************"<<
"\n";
736 for (IndexAssociation::iterator it = outputCollection.begin(), ed = outputCollection.end(); it != ed; ++it) {
737 std::sort(it->second.begin(), it->second.end());
739 return outputCollection;
void getMatchedIds(MapOfMatchedIds &tracker_matchedIds_valid, MapOfMatchedIds &muon_matchedIds_valid, MapOfMatchedIds &tracker_matchedIds_INVALID, MapOfMatchedIds &muon_matchedIds_INVALID, int &n_tracker_valid, int &n_dt_valid, int &n_csc_valid, int &n_rpc_valid, int &n_tracker_matched_valid, int &n_dt_matched_valid, int &n_csc_matched_valid, int &n_rpc_matched_valid, int &n_tracker_INVALID, int &n_dt_INVALID, int &n_csc_INVALID, int &n_rpc_INVALID, int &n_tracker_matched_INVALID, int &n_dt_matched_INVALID, int &n_csc_matched_INVALID, int &n_rpc_matched_INVALID, trackingRecHit_iterator begin, trackingRecHit_iterator end, const TrackerHitAssociator *trackertruth, const DTHitAssociator &dttruth, const CSCHitAssociator &csctruth, const RPCHitAssociator &rpctruth, bool printRts, const TrackerTopology *) const
std::vector< TrackingParticle > TrackingParticleCollection
unsigned int NHitCut_muon
const bool ThreeHitTracksAreSpecial
std::map< size_t, std::vector< IndexMatch > > IndexAssociation
int getShared(MapOfMatchedIds &matchedIds, TrackingParticleCollection::const_iterator trpart) const
double EfficiencyCut_track
const bool AbsoluteNumberOfHits_muon
unsigned int NHitCut_track
const bool AbsoluteNumberOfHits_track
std::vector< SimTrack >::const_iterator g4t_iterator
const bool acceptOneStubMatchings
boost::ptr_vector< uint_SimHitIdpr_pair > MapOfMatchedIds
size_type size() const
Size of the RefVector.
double EfficiencyCut_muon
const bool includeZeroHitMuons