28 #ifndef APRIL_PERFECT_PFO_CREATION_ALGORITHM_H
29 #define APRIL_PERFECT_PFO_CREATION_ALGORITHM_H
31 #include "Pandora/Algorithm.h"
33 #include "Api/PandoraContentApi.h"
35 namespace april_content
47 class Factory :
public pandora::AlgorithmFactory
50 pandora::Algorithm *CreateAlgorithm()
const;
59 typedef PandoraContentApi::ParticleFlowObject::Parameters PfoParameters;
61 pandora::StatusCode Run();
62 pandora::StatusCode ReadSettings(
const pandora::TiXmlHandle xmlHandle);
77 pandora::StatusCode
PopulateTrackBasedPfo(
const pandora::Track *
const pTrack, PfoParameters &pfoParameters,
const bool readSiblingInfo =
true)
const;
126 const pandora::CartesianVector
GetEnergyWeightedCentroid(
const pandora::Cluster *
const pCluster,
const unsigned int innerPseudoLayer,
127 const unsigned int outerPseudoLayer)
const;
129 pandora::StatusCode TrackCollection(
const pandora::MCParticle *
const pPfoTarget, PfoParameters &pfoParameters)
const;
131 void SetPfoParametersFromTracks(
int &nTracksUsed, PfoParameters &pfoParameters)
const;
132 void SetPfoParametersFromClusters(
const pandora::MCParticle *
const pPfoTarget,
const int nTracksUsed, PfoParameters &pfoParameters)
const;
133 pandora::StatusCode SetPfoParametersFromClusters()
const;
134 pandora::StatusCode TrackClusterAssociation(
const pandora::MCParticle *
const pPfoTarget, PfoParameters &pfoParameters)
const;
138 bool m_collapsedMCParticlesToPfoTarget;
145 inline pandora::Algorithm *PerfectPfoCreationAlgorithm::Factory::CreateAlgorithm()
const
pandora::StatusCode SetDaughterTrackBasedPfoParameters(const pandora::Track *const pTrack, PfoParameters &pfoParameters) const
Set the parameters for a track-based pfo, where the pfo target has one or more daughter tracks...
pandora::StatusCode CreateTrackBasedPfos() const
Create particle flow objects starting from tracks in the main tracker. The pfos will account for asso...
Definition: PerfectPfoCreationAlgorithm.cc:485
pandora::StatusCode CreateNeutralPfos() const
Create particle flow objects corresponding to neutral particles, These pfos consist only of clusters ...
pandora::StatusCode SetSiblingTrackBasedPfoParameters(const pandora::Track *const pTrack, PfoParameters &pfoParameters) const
Set the parameters for a track-based pfo, where pfo target consists of two or more sibling tracks...
PerfectPfoCreationAlgorithm()
Default constructor.
Definition: PerfectPfoCreationAlgorithm.cc:41
Factory class for instantiating algorithm.
Definition: PerfectPfoCreationAlgorithm.h:47
pandora::StatusCode SetTrackBasedPfoParameters(const pandora::Track *const pTrack, PfoParameters &pfoParameters) const
Set the basic parameters for a track-based pfo.
pandora::StatusCode PopulateTrackBasedPfo(const pandora::Track *const pTrack, PfoParameters &pfoParameters, const bool readSiblingInfo=true) const
Add relevant tracks and clusters to a track-based pfo.
PerfectPfoCreationAlgorithm class.
Definition: PerfectPfoCreationAlgorithm.h:41
const pandora::CartesianVector GetEnergyWeightedCentroid(const pandora::Cluster *const pCluster, const unsigned int innerPseudoLayer, const unsigned int outerPseudoLayer) const
Get the energy-weighted centroid for a specified cluster, calculated over a particular pseudo layer r...
Definition: PerfectPfoCreationAlgorithm.cc:599
std::string m_outputPfoListName
The output pfo list name.
Definition: PerfectPfoCreationAlgorithm.h:136
pandora::StatusCode SetSimpleTrackBasedPfoParameters(const pandora::Track *const pTrack, PfoParameters &pfoParameters) const
Set the parameters for a simple track-based pfo, where the track has no associations with other track...
std::string m_associationAlgorithmName
The name of track-cluster alg.
Definition: PerfectPfoCreationAlgorithm.h:137