28 #ifndef APRIL_SEMI_PERFECT_PFO_CREATION_ALGORITHM_H
29 #define APRIL_SEMI_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 void TrackCollection(
const pandora::MCParticle *
const pPfoTarget, PfoParameters &pfoParameters)
const;
130 void CaloHitCollection(
const pandora::MCParticle *
const pPfoTarget, PfoParameters &pfoParameters)
const;
132 void SetPfoParametersFromTracks(
int &nTracksUsed, PfoParameters &pfoParameters)
const;
133 void SetPfoParametersFromClusters(
const pandora::MCParticle *
const pPfoTarget,
const int nTracksUsed, PfoParameters &pfoParameters)
const;
134 pandora::StatusCode SetPfoParametersFromClusters()
const;
135 pandora::StatusCode TrackClusterAssociation(
const pandora::MCParticle *
const pPfoTarget, PfoParameters &pfoParameters)
const;
145 inline pandora::Algorithm *SemiPerfectPfoCreationAlgorithm::Factory::CreateAlgorithm()
const
152 #endif // #ifndef APRIL_PERFECT_PFO_CREATION_ALGORITHM_H
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...
Factory class for instantiating algorithm.
Definition: SemiPerfectPfoCreationAlgorithm.h:47
SemiPerfectPfoCreationAlgorithm class.
Definition: SemiPerfectPfoCreationAlgorithm.h:41
pandora::StatusCode SetTrackBasedPfoParameters(const pandora::Track *const pTrack, PfoParameters &pfoParameters) const
Set the basic parameters for a track-based pfo.
std::string m_outputPfoListName
The output pfo list name.
Definition: SemiPerfectPfoCreationAlgorithm.h:137
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...
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.
pandora::StatusCode CreateTrackBasedPfos() const
Create particle flow objects starting from tracks in the main tracker. The pfos will account for asso...
Definition: SemiPerfectPfoCreationAlgorithm.cc:353
SemiPerfectPfoCreationAlgorithm()
Default constructor.
Definition: SemiPerfectPfoCreationAlgorithm.cc:38
pandora::StatusCode CreateNeutralPfos() const
Create particle flow objects corresponding to neutral particles, These pfos consist only of clusters ...
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: SemiPerfectPfoCreationAlgorithm.cc:450
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...
std::string m_associationAlgorithmName
The name of track-cluster alg.
Definition: SemiPerfectPfoCreationAlgorithm.h:138