9 #include "Pandora/AlgorithmHeaders.h"    21 VertexSplittingAlgorithm::VertexSplittingAlgorithm() : m_splitDisplacementSquared(4.
f * 4.
f), m_vertexDisplacementSquared(1.
f * 1.
f)
    33     PANDORA_RETURN_RESULT_IF(STATUS_CODE_SUCCESS, !=, PandoraContentApi::GetCurrentList(*
this, pVertexList));
    35     if (pVertexList->empty())
    36         return STATUS_CODE_NOT_INITIALIZED;
    38     if (pVertexList->size() != 1)
    39         return STATUS_CODE_OUT_OF_RANGE;
    41     const Cluster *
const pCluster(slidingFitResult.
GetCluster());
    44     const Vertex *
const pSelectedVertex(*(pVertexList->begin()));
    46     if (VERTEX_3D != pSelectedVertex->GetVertexType())
    47         return STATUS_CODE_INVALID_PARAMETER;
    55         return STATUS_CODE_NOT_FOUND;
    57     bool foundSplit(
false);
    60     if (STATUS_CODE_SUCCESS != statusCode)
    63     const float splitDisplacementSquared((splitPosition - theVertex2D).GetMagnitudeSquared());
    64     const float vertexDisplacementSquared(
    65         std::min((splitPosition - innerVertex2D).GetMagnitudeSquared(), (splitPosition - outerVertex2D).GetMagnitudeSquared()));
    68         (splitDisplacementSquared < vertexDisplacementSquared))
    74         return STATUS_CODE_NOT_FOUND;
    76     return STATUS_CODE_SUCCESS;
    84     PANDORA_RETURN_RESULT_IF_AND_IF(
    85         STATUS_CODE_SUCCESS, STATUS_CODE_NOT_FOUND, !=, XmlHelper::ReadValue(xmlHandle, 
"SplitDisplacement", splitDisplacement));
    89     PANDORA_RETURN_RESULT_IF_AND_IF(
    90         STATUS_CODE_SUCCESS, STATUS_CODE_NOT_FOUND, !=, XmlHelper::ReadValue(xmlHandle, 
"VertexDisplacement", vertexDisplacement));
 virtual pandora::StatusCode ReadSettings(const pandora::TiXmlHandle xmlHandle)
 
pandora::StatusCode FindBestSplitPosition(const TwoDSlidingFitResult &slidingFitResult, pandora::CartesianVector &splitPosition) const 
Use sliding linear fit to identify the best split position. 
 
Header file for the vertex splitting algorithm class. 
 
static pandora::CartesianVector ProjectPosition(const pandora::Pandora &pandora, const pandora::CartesianVector &position3D, const pandora::HitType view)
Project 3D position into a given 2D view. 
 
static pandora::HitType GetClusterHitType(const pandora::Cluster *const pCluster)
Get the hit type associated with a two dimensional cluster. 
 
Header file for the geometry helper class. 
 
Header file for the cluster helper class. 
 
pandora::CartesianVector GetGlobalMinLayerPosition() const 
Get global position corresponding to the fit result in minimum fit layer. 
 
float m_vertexDisplacementSquared
Maximum displacement squared. 
 
const pandora::Cluster * GetCluster() const 
Get the address of the cluster, if originally provided. 
 
T min(sqlite3 *const db, std::string const &table_name, std::string const &column_name)
 
float m_splitDisplacementSquared
Maximum displacement squared. 
 
pandora::StatusCode GetGlobalFitProjection(const pandora::CartesianVector &inputPosition, pandora::CartesianVector &projectedPosition) const 
Get projected position on global fit for a given position vector. 
 
pandora::StatusCode ReadSettings(const pandora::TiXmlHandle xmlHandle)
 
boost::graph_traits< ModuleGraph >::vertex_descriptor Vertex
 
std::list< Vertex > VertexList
 
pandora::CartesianVector GetGlobalMaxLayerPosition() const 
Get global position corresponding to the fit result in maximum fit layer. 
 
TwoDSlidingFitResult class.