LArSoft  v07_13_02
Liquid Argon Software toolkit - http://larsoft.org/
IsolatedClusterMopUpAlgorithm.h
Go to the documentation of this file.
1 
8 #ifndef LAR_ISOLATED_CLUSTER_MOP_UP_ALGORITHM_H
9 #define LAR_ISOLATED_CLUSTER_MOP_UP_ALGORITHM_H 1
10 
11 #include "Pandora/Algorithm.h"
12 
14 
15 #include <unordered_map>
16 
17 namespace lar_content
18 {
19 
20 template<typename, unsigned int> class KDTreeLinkerAlgo;
21 template<typename, unsigned int> class KDTreeNodeInfoT;
22 
23 //------------------------------------------------------------------------------------------------------------------------------------------
24 
29 {
30 public:
35 
36 private:
37  void ClusterMopUp(const pandora::ClusterList &pfoClusters, const pandora::ClusterList &remnantClusters) const;
38 
45  void DissolveClustersToHits(const pandora::ClusterList &clusterList, pandora::CaloHitList &caloHitList) const;
46 
47  typedef std::unordered_map<const pandora::CaloHit*, const pandora::Cluster*> CaloHitToClusterMap;
48 
56  void GetCaloHitToClusterMap(const pandora::CaloHitList &caloHitList, const pandora::ClusterList &clusterList, CaloHitToClusterMap &caloHitToClusterMap) const;
57 
58  pandora::StatusCode ReadSettings(const pandora::TiXmlHandle xmlHandle);
59 
62  typedef std::vector<HitKDNode2D> HitKDNode2DList;
63 
64  unsigned int m_maxCaloHitsInCluster;
67 };
68 
69 } // namespace lar_content
70 
71 #endif // #ifndef LAR_ISOLATED_CLUSTER_MOP_UP_ALGORITHM_H
pandora::StatusCode ReadSettings(const pandora::TiXmlHandle xmlHandle)
void ClusterMopUp(const pandora::ClusterList &pfoClusters, const pandora::ClusterList &remnantClusters) const
Cluster mop up for a single view. This function is responsible for instructing pandora to make cluste...
KDTreeLinkerAlgo< const pandora::CaloHit *, 2 > HitKDTree2D
Class that implements the KDTree partition of 2D space and a closest point search algorithm...
unsigned int m_maxCaloHitsInCluster
The maximum number of hits in a cluster to be dissolved.
void DissolveClustersToHits(const pandora::ClusterList &clusterList, pandora::CaloHitList &caloHitList) const
Examine a list of clusters, identify and delete remnants; receive the list of newly available hits...
Data stored in each KDTree node. The dim1/dim2 fields are usually the duplication of some PFRecHit va...
bool m_addHitsAsIsolated
Whether to add hits to clusters as "isolated" (don&#39;t contribute to spatial properties) ...
KDTreeNodeInfoT< const pandora::CaloHit *, 2 > HitKDNode2D
Header file for the cluster mop up algorithm base class.
float m_maxHitClusterDistance
The maximum hit to cluster distance for isolated hit merging.
std::unordered_map< const pandora::CaloHit *, const pandora::Cluster * > CaloHitToClusterMap
void GetCaloHitToClusterMap(const pandora::CaloHitList &caloHitList, const pandora::ClusterList &clusterList, CaloHitToClusterMap &caloHitToClusterMap) const
Look for isolated hit additions, considering a list of candidate hits and a list of host clusters...