LArSoft
v09_90_00
Liquid Argon Software toolkit - https://larsoft.org/
|
LongitudinalExtensionAlgorithm class. More...
#include "LongitudinalExtensionAlgorithm.h"
Public Member Functions | |
LongitudinalExtensionAlgorithm () | |
Default constructor. More... | |
Protected Types | |
typedef std::unordered_map< const pandora::Cluster *, ClusterAssociation > | ClusterAssociationMap |
typedef std::unordered_map< const pandora::Cluster *, ClusterAssociationMap > | ClusterAssociationMatrix |
typedef std::unordered_map< const pandora::Cluster *, pandora::ClusterList > | ClusterMergeMap |
Protected Member Functions | |
void | PopulateClusterMergeMap (const pandora::ClusterVector &clusterVector, ClusterMergeMap &clusterMergeMatrix) const |
Form associations between pointing clusters. More... | |
virtual pandora::StatusCode | Run () |
void | MergeClusters (pandora::ClusterVector &clusterVector, ClusterMergeMap &clusterMergeMap) const |
Merge associated clusters. More... | |
void | CollectAssociatedClusters (const pandora::Cluster *const pSeedCluster, const ClusterMergeMap &clusterMergeMap, pandora::ClusterList &associatedClusterList) const |
Collect up all clusters associations related to a given seed cluster. More... | |
void | CollectAssociatedClusters (const pandora::Cluster *const pSeedCluster, const pandora::Cluster *const pCurrentCluster, const ClusterMergeMap &clusterMergeMap, const pandora::ClusterSet &clusterVetoList, pandora::ClusterList &associatedClusterList) const |
Collect up all clusters associations related to a given seed cluster. More... | |
void | GetSortedListOfCleanClusters (const pandora::ClusterVector &inputClusters, pandora::ClusterVector &outputClusters) const |
Sort the selected clusters, so that they have a well-defined ordering. More... | |
Protected Attributes | |
std::string | m_inputClusterListName |
The name of the input cluster list. If not specified, will access current list. More... | |
Private Member Functions | |
void | GetListOfCleanClusters (const pandora::ClusterList *const pClusterList, pandora::ClusterVector &clusterVector) const |
Populate cluster vector with subset of cluster list, containing clusters judged to be clean. More... | |
void | FillClusterAssociationMatrix (const pandora::ClusterVector &clusterVector, ClusterAssociationMatrix &clusterAssociationMatrix) const |
Fill the cluster association matrix. More... | |
void | FillClusterMergeMap (const ClusterAssociationMatrix &clusterAssociationMatrix, ClusterMergeMap &clusterMergeMap) const |
Fill the cluster merge map. More... | |
void | FillClusterAssociationMatrix (const LArPointingCluster &clusterI, const LArPointingCluster &clusterJ, ClusterAssociationMatrix &clusterAssociationMatrix) const |
Form association between two pointing clusters. More... | |
pandora::StatusCode | ReadSettings (const pandora::TiXmlHandle xmlHandle) |
Private Attributes | |
float | m_clusterMinLength |
float | m_clusterMinLayerOccupancy |
float | m_nodeMaxDisplacement |
float | m_nodeMaxCosRelativeAngle |
float | m_emissionMaxLongitudinalDisplacement |
float | m_emissionMaxTransverseDisplacement |
float | m_emissionMaxCosRelativeAngle |
LongitudinalExtensionAlgorithm class.
Definition at line 21 of file LongitudinalExtensionAlgorithm.h.
|
protectedinherited |
Definition at line 97 of file ClusterExtensionAlgorithm.h.
|
protectedinherited |
Definition at line 98 of file ClusterExtensionAlgorithm.h.
|
protectedinherited |
Definition at line 27 of file ClusterMergingAlgorithm.h.
lar_content::LongitudinalExtensionAlgorithm::LongitudinalExtensionAlgorithm | ( | ) |
Default constructor.
Definition at line 21 of file LongitudinalExtensionAlgorithm.cc.
|
protectedinherited |
Collect up all clusters associations related to a given seed cluster.
pSeedCluster | pointer to the initial cluster |
clusterMergeMap | the map of cluster associations |
associatedClusterList | the output list of associated clusters |
|
protectedinherited |
Collect up all clusters associations related to a given seed cluster.
pSeedCluster | pointer to the initial cluster |
pCurrentCluster | pointer to the current cluster |
clusterMergeMap | the map of cluster associations |
clusterVetoList | the list of clusters that have already been merged |
associatedClusterList | the output list of associated clusters |
|
privatevirtual |
Fill the cluster association matrix.
clusterVector | the input vector of clusters |
clusterAssociationMatrix | the matrix of associations |
Implements lar_content::ClusterExtensionAlgorithm.
Referenced by GetListOfCleanClusters().
|
private |
Form association between two pointing clusters.
clusterI | the first pointing cluster |
clusterJ | the second pointing cluster |
clusterAssociationMatrix | the matrix of cluster associations |
Definition at line 89 of file LongitudinalExtensionAlgorithm.cc.
References f, lar_content::LArPointingClusterHelper::GetClosestVertices(), lar_content::LArPointingCluster::GetCluster(), lar_content::LArPointingCluster::Vertex::GetDirection(), lar_content::LArPointingClusterHelper::GetImpactParameters(), lar_content::LArClusterHelper::GetLayerOccupancy(), lar_content::LArPointingClusterHelper::GetLength(), lar_content::LArPointingCluster::Vertex::GetPosition(), lar_content::LArPointingCluster::Vertex::GetRms(), lar_content::ClusterExtensionAlgorithm::ClusterAssociation::INNER, lar_content::LArPointingCluster::Vertex::IsInitialized(), lar_content::LArPointingCluster::Vertex::IsInnerVertex(), m_clusterMinLayerOccupancy, m_emissionMaxCosRelativeAngle, m_emissionMaxLongitudinalDisplacement, m_emissionMaxTransverseDisplacement, m_nodeMaxCosRelativeAngle, m_nodeMaxDisplacement, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::NONE, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::OUTER, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::STRONG, and lar_content::ClusterExtensionAlgorithm::ClusterAssociation::WEAK.
|
privatevirtual |
Fill the cluster merge map.
clusterAssociationMatrix | the matrix of cluster associations |
clusterMergeMap | the map of cluster merges |
Implements lar_content::ClusterExtensionAlgorithm.
Definition at line 190 of file LongitudinalExtensionAlgorithm.cc.
References f, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::GetDaughter(), lar_content::ClusterExtensionAlgorithm::ClusterAssociation::GetFigureOfMerit(), lar_content::ClusterExtensionAlgorithm::ClusterAssociation::GetParent(), lar_content::ClusterExtensionAlgorithm::ClusterAssociation::INNER, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::NONE, lar_content::ClusterExtensionAlgorithm::ClusterAssociation::OUTER, lar_content::LArClusterHelper::SortByNHits(), lar_content::ClusterExtensionAlgorithm::ClusterAssociation::STRONG, and lar_content::ClusterExtensionAlgorithm::ClusterAssociation::UNDEFINED.
|
privatevirtual |
Populate cluster vector with subset of cluster list, containing clusters judged to be clean.
pClusterList | address of the cluster list |
clusterVector | to receive the populated cluster vector |
Implements lar_content::ClusterMergingAlgorithm.
Definition at line 34 of file LongitudinalExtensionAlgorithm.cc.
References FillClusterAssociationMatrix(), lar_content::LArPointingCluster::GetCluster(), lar_content::LArClusterHelper::GetLayerOccupancy(), lar_content::LArClusterHelper::GetLengthSquared(), m_clusterMinLayerOccupancy, m_clusterMinLength, and lar_content::LArClusterHelper::SortByNHits().
|
protectedinherited |
Sort the selected clusters, so that they have a well-defined ordering.
inputClusters | the input vector of clusters |
outputClusters | the output vector of clusters |
Definition at line 135 of file ClusterMergingAlgorithm.cc.
|
protectedinherited |
Merge associated clusters.
clusterVector | the vector of clean clusters |
clusterMergeMap | the matrix of cluster associations |
Definition at line 62 of file ClusterMergingAlgorithm.cc.
|
protectedvirtualinherited |
Form associations between pointing clusters.
clusterVector | the vector of clean clusters |
clusterMergeMap | the matrix of cluster associations |
Implements lar_content::ClusterMergingAlgorithm.
Definition at line 18 of file ClusterExtensionAlgorithm.cc.
|
privatevirtual |
Reimplemented from lar_content::ClusterMergingAlgorithm.
Definition at line 370 of file LongitudinalExtensionAlgorithm.cc.
References m_clusterMinLayerOccupancy, m_clusterMinLength, m_emissionMaxCosRelativeAngle, m_emissionMaxLongitudinalDisplacement, m_emissionMaxTransverseDisplacement, m_nodeMaxCosRelativeAngle, m_nodeMaxDisplacement, and lar_content::ClusterMergingAlgorithm::ReadSettings().
|
protectedvirtualinherited |
Definition at line 20 of file ClusterMergingAlgorithm.cc.
|
private |
Definition at line 47 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), GetListOfCleanClusters(), and ReadSettings().
|
private |
Definition at line 46 of file LongitudinalExtensionAlgorithm.h.
Referenced by GetListOfCleanClusters(), and ReadSettings().
|
private |
Definition at line 52 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), and ReadSettings().
|
private |
Definition at line 50 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), and ReadSettings().
|
private |
Definition at line 51 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), and ReadSettings().
|
protectedinherited |
The name of the input cluster list. If not specified, will access current list.
Definition at line 83 of file ClusterMergingAlgorithm.h.
|
private |
Definition at line 49 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), and ReadSettings().
|
private |
Definition at line 48 of file LongitudinalExtensionAlgorithm.h.
Referenced by FillClusterAssociationMatrix(), and ReadSettings().