8 #include <tracking/ckf/pxd/utilities/PXDMCUtil.h>
10 #include <tracking/ckf/pxd/entities/CKFToPXDState.h>
11 #include <tracking/mcMatcher/TrackMatchLookUp.h>
12 #include <tracking/dataobjects/RecoTrack.h>
13 #include <pxd/dataobjects/PXDCluster.h>
14 #include <tracking/spacePointCreation/SpacePoint.h>
15 #include <tracking/trackFindingCDC/utilities/Algorithms.h>
21 const auto isSameMCTrack = [&mcRecoTrack](
const RecoTrack & clusterRecoTrack) {
22 return &clusterRecoTrack == mcRecoTrack;
26 const std::string& mcRecoTrackStoreArrayName = mcRecoTrack->
getArrayName();
29 const auto& relatedMCTracksToCluster = relatedCluster.getRelationsTo<
RecoTrack>(mcRecoTrackStoreArrayName);
30 if (not TrackFindingCDC::any(relatedMCTracksToCluster, isSameMCTrack)) {
38 B2ASSERT(
"Invalid MC information", recoHitInformationOfHit);
45 const auto& itToFirstEntryInDetector = std::find_if(recoHitInformationList.begin(), recoHitInformationList.end(),
47 return hitInformation->getTrackingDetector() == detector;
49 const auto& itToFirstEntryAfterDetector = std::find_if(itToFirstEntryInDetector, recoHitInformationList.end(),
51 return hitInformation->getTrackingDetector() != detector;
54 if (itToFirstEntryAfterDetector == recoHitInformationList.end()) {
60 const auto* firstHitAfterDetector = *itToFirstEntryAfterDetector;
61 return firstHitAfterDetector->getSortingParameter() >= recoHitInformationOfHit->
getSortingParameter();
67 const auto hitIsCorrectSpecialisation = [
this, mcRecoTrack](
const SpacePoint * spacePoint) {
71 const unsigned int numberOfCorrectHits = std::count_if(hits.begin(), hits.end(), hitIsCorrectSpecialisation);
72 return numberOfCorrectHits;
77 const RecoTrack* seed = states.front()->getSeed();
79 B2ASSERT(
"Path without a seed?", seed);
81 if (states.size() <= 1) {
86 const std::string& seedTrackStoreArrayName = seed->getArrayName();
93 B2DEBUG(29,
"Seed is a fake");
97 std::vector<const SpacePoint*> spacePoints;
99 const SpacePoint* spacePoint = state->getHit();
101 spacePoints.push_back(spacePoint);
107 B2DEBUG(29,
"Have found " << numberOfCorrectHits <<
" correct out of " << spacePoints.size() <<
" hits");
108 return numberOfCorrectHits == spacePoints.size();
Specialized CKF State for extrapolating into the PXD.
bool pxdHitIsCorrect(const RecoTrack *mcRecoTrack, const SpacePoint *spacePoint) const
Returns true, of the space point is related to the mc track and if it is on the first half.
bool allStatesCorrect(const std::vector< TrackFindingCDC::WithWeight< const CKFToPXDState * >> &states) const
Are all hits related to the same MC track the seed is related to?
unsigned int getNumberOfCorrectPXDHits(const RecoTrack *mcRecoTrack, const std::vector< const SpacePoint * > &hits) const
How many of the given space points are also in the MC track? Runs pxdHitIsCorrect on all of them.
The PXD Cluster class This class stores all information about reconstructed PXD clusters The position...
This is the Reconstruction Event-Data Model Track.
std::vector< RecoHitInformation * > getRecoHitInformations(bool getSorted=false) const
Return a list of all RecoHitInformations associated with the RecoTrack.
RecoHitInformation * getRecoHitInformation(HitType *hit) const
Return the reco hit information for a generic hit from the storeArray.
std::string getArrayName() const
Get name of array this object is stored in, or "" if not found.
RelationVector< TO > getRelationsTo(const std::string &name="", const std::string &namedRelation="") const
Get the relations that point from this object to another store array.
TO * getRelatedTo(const std::string &name="", const std::string &namedRelation="") const
Get the object to which this object has a relation.
SpacePoint typically is build from 1 PXDCluster or 1-2 SVDClusters.
A mixin class to attach a weight to an object.
Class to provide convenient methods to look up matching information between pattern recognition and M...
const RecoTrack * getRelatedMCRecoTrack(const RecoTrack &prRecoTrack) const
Looks for a related Monte Carlo track for the given pattern recognition track and return it if found.
Abstract base class for different kinds of events.