LArSoft  v09_90_00
Liquid Argon Software toolkit - https://larsoft.org/
cluster::ClusterMerger Class Reference

Class merging clusters: recomputes start and end position and hit list. More...

Inheritance diagram for cluster::ClusterMerger:
cluster::ClusterAndHitMerger

Public Types

using HitPtr_t = art::Ptr< recob::Hit >
 type of pointer to hits More...
 
using HitVector_t = std::vector< HitPtr_t >
 vector of pointers to hits More...
 
using ID_t = recob::Cluster::ID_t
 Type of cluster ID. More...
 
using ClusterEnds_t = recob::Cluster::ClusterEnds_t
 

Public Member Functions

 ClusterMerger ()=default
 
 ClusterMerger (recob::Cluster const &cluster)
 
bool Add (recob::Cluster const &cluster)
 Merges a single cluster into this object. More...
 

Accessors

float fEndWires [ClusterEnds_t::NEnds]
 Data referring to start and end of the cluster. More...
 
float fSigmaEndWires [ClusterEnds_t::NEnds]
 Uncertainty on wire coordinate of the start and end of the cluster. More...
 
float fEndTicks [ClusterEnds_t::NEnds]
 Tick coordinate of the start and end of the cluster. More...
 
float fSigmaEndTicks [ClusterEnds_t::NEnds]
 Uncertainty on tick coordinate of the start and end of the cluster. More...
 
float fEndCharges [ClusterEnds_t::NEnds]
 Charge on the start and end wire of the cluster. More...
 
float fAngles [ClusterEnds_t::NEnds]
 Angle of the start and end of the cluster, defined in [-pi,pi]. More...
 
float fOpeningAngles [ClusterEnds_t::NEnds]
 Opening angle of the cluster shape at the start and end of the cluster. More...
 
float fWidth
 A measure of the cluster width, in homogenized units. More...
 
geo::View_t fView
 View for this cluster. More...
 
geo::PlaneID fPlaneID
 Location of the start of the cluster. More...
 
unsigned int n_clusters = 0
 number of clusters added so far More...
 
float StartWire () const
 Returns the wire coordinate of the start of the cluster. More...
 
float StartTick () const
 Returns the tick coordinate of the start of the cluster. More...
 
float SigmaStartWire () const
 Returns the uncertainty on wire coordinate of the start of the cluster. More...
 
float SigmaStartTick () const
 Data referring to start and end of the cluster. More...
 
float EndWire () const
 Returns the wire coordinate of the end of the cluster. More...
 
float EndTick () const
 Returns the tick coordinate of the end of the cluster. More...
 
float SigmaEndWire () const
 Returns the uncertainty on wire coordinate of the end of the cluster. More...
 
float SigmaEndTick () const
 Returns the uncertainty on tick coordinate of the end of the cluster. More...
 
float WireCoord (ClusterEnds_t side) const
 Returns the wire coordinate of one of the end sides of the cluster. More...
 
float TickCoord (ClusterEnds_t side) const
 Returns the tick coordinate of one of the end sides of the cluster. More...
 
float SigmaWireCoord (ClusterEnds_t side) const
 Returns the uncertainty on wire coordinate of one of the end sides of the cluster. More...
 
float SigmaTickCoord (ClusterEnds_t side) const
 Returns the uncertainty on tick coordinate of one of the end sides of the cluster. More...
 
float StartCharge () const
 Returns the charge on the first wire of the cluster. More...
 
float StartAngle () const
 Returns the starting angle of the cluster. More...
 
float StartOpeningAngle () const
 Returns the opening angle at the start of the cluster. More...
 
float EndCharge () const
 Returns the charge on the last wire of the cluster. More...
 
float EndAngle () const
 Returns the ending angle of the cluster. More...
 
float EndOpeningAngle () const
 Returns the opening angle at the end of the cluster. More...
 
float EdgeCharge (ClusterEnds_t side) const
 Returns the charge on the first or last wire of the cluster. More...
 
float Angle (ClusterEnds_t side) const
 Returns the angle at either end of the cluster. More...
 
float OpeningAngle (ClusterEnds_t side) const
 Returns the opening angle at either end of the cluster. More...
 
float Width () const
 A measure of the cluster width, in homogenized units. More...
 
geo::View_t View () const
 Returns the view for this cluster. More...
 
geo::PlaneID Plane () const
 Returns the plane ID this cluster lies on. More...
 
bool hasPlane () const
 Returns whether geometry plane is valid. More...
 
void AdoptEnd (recob::Cluster const &cluster, ClusterEnds_t iEnd)
 Imports all the member of the corresponding end. More...
 
template<typename T >
static void top (T &var, T value)
 Data referring to start and end of the cluster. More...
 
template<typename T >
static void bot (T &var, T value)
 Data referring to start and end of the cluster. More...
 

Detailed Description

Class merging clusters: recomputes start and end position and hit list.

Definition at line 71 of file LineMerger_module.cc.

Member Typedef Documentation

type of pointer to hits

Definition at line 76 of file LineMerger_module.cc.

vector of pointers to hits

Definition at line 77 of file LineMerger_module.cc.

Type of cluster ID.

Definition at line 79 of file LineMerger_module.cc.

Constructor & Destructor Documentation

cluster::ClusterMerger::ClusterMerger ( )
default
cluster::ClusterMerger::ClusterMerger ( recob::Cluster const &  cluster)
inline

Definition at line 93 of file LineMerger_module.cc.

93 : ClusterMerger() { Add(cluster); }
Cluster finding and building.
bool Add(recob::Cluster const &cluster)
Merges a single cluster into this object.

Member Function Documentation

bool cluster::ClusterMerger::Add ( recob::Cluster const &  cluster)

Merges a single cluster into this object.

Parameters
clusterthe cluster to be merged
Returns
whether the addition was successful

The two ends of the cluster are merged into this one, that gets extended.

The new cluster must have the same view as the prevopus ones and must lay on the same plane. If the new cluster has invalid plane, the current one is kept; if the current plane is invalid, it is overwritten (that means that if both are invalid, the merged cluster will also have an invalid plane).

Note that this code is crap unless the cluster is track-like.

Definition at line 255 of file LineMerger_module.cc.

References recob::Cluster::EndWire(), recob::Cluster::hasPlane(), recob::Cluster::isValid(), recob::Cluster::Plane(), recob::Cluster::StartWire(), recob::Cluster::View(), and recob::Cluster::Width().

Referenced by cluster::ClusterAndHitMerger::Add().

256  {
257  if (!cluster.isValid()) return false;
258 
259  if (n_clusters == 0) { // special case: we are still empty
260  AdoptEnd(cluster, ClusterEnds_t::clStart);
261  AdoptEnd(cluster, ClusterEnds_t::clEnd);
262  fWidth = cluster.Width();
263  fView = cluster.View();
264  fPlaneID = cluster.Plane();
265  ++n_clusters;
266  return true;
267  } // if empty
268 
269  if (cluster.View() != View()) return false;
270 
271  if (cluster.hasPlane() && hasPlane() && (cluster.Plane() != Plane())) return false;
272 
273  // this code has been moved here from the old recon::Cluster::operator+
274  // of recob::Cluster v13.
275  if (cluster.StartWire() < StartWire()) { // adopt the new start
276  AdoptEnd(cluster, ClusterEnds_t::clStart);
277  }
278  if (cluster.EndWire() < EndWire()) { // adopt the new end
279  AdoptEnd(cluster, ClusterEnds_t::clEnd);
280  }
281 
282  top(fWidth, cluster.Width()); // extend width
283 
284  if (!hasPlane()) fPlaneID = cluster.Plane();
285 
286  return true;
287  } // ClusterMerger::Add(Cluster)
float EndWire() const
Returns the wire coordinate of the end of the cluster.
Cluster finding and building.
float fWidth
A measure of the cluster width, in homogenized units.
float StartWire() const
Returns the wire coordinate of the start of the cluster.
unsigned int n_clusters
number of clusters added so far
static void top(T &var, T value)
Data referring to start and end of the cluster.
void AdoptEnd(recob::Cluster const &cluster, ClusterEnds_t iEnd)
Imports all the member of the corresponding end.
bool hasPlane() const
Returns whether geometry plane is valid.
geo::View_t fView
View for this cluster.
geo::View_t View() const
Returns the view for this cluster.
geo::PlaneID Plane() const
Returns the plane ID this cluster lies on.
geo::PlaneID fPlaneID
Location of the start of the cluster.
void cluster::ClusterMerger::AdoptEnd ( recob::Cluster const &  cluster,
ClusterEnds_t  iEnd 
)
protected

Imports all the member of the corresponding end.

Definition at line 243 of file LineMerger_module.cc.

References recob::Cluster::Angle(), recob::Cluster::EdgeCharge(), recob::Cluster::OpeningAngle(), recob::Cluster::SigmaTickCoord(), recob::Cluster::SigmaWireCoord(), recob::Cluster::TickCoord(), and recob::Cluster::WireCoord().

244  {
245  const ClusterEnds_t iDestEnd = iSrcEnd;
246  fEndWires[iDestEnd] = cluster.WireCoord(iSrcEnd);
247  fSigmaEndWires[iDestEnd] = cluster.SigmaWireCoord(iSrcEnd);
248  fEndTicks[iDestEnd] = cluster.TickCoord(iSrcEnd);
249  fSigmaEndTicks[iDestEnd] = cluster.SigmaTickCoord(iSrcEnd);
250  fEndCharges[iDestEnd] = cluster.EdgeCharge(iSrcEnd);
251  fAngles[iDestEnd] = cluster.Angle(iSrcEnd);
252  fOpeningAngles[iDestEnd] = cluster.OpeningAngle(iSrcEnd);
253  } // ClusterMerger::AdoptEnd()
float fEndCharges[ClusterEnds_t::NEnds]
Charge on the start and end wire of the cluster.
Cluster finding and building.
float fOpeningAngles[ClusterEnds_t::NEnds]
Opening angle of the cluster shape at the start and end of the cluster.
recob::Cluster::ClusterEnds_t ClusterEnds_t
float fEndWires[ClusterEnds_t::NEnds]
Data referring to start and end of the cluster.
float fSigmaEndWires[ClusterEnds_t::NEnds]
Uncertainty on wire coordinate of the start and end of the cluster.
float fEndTicks[ClusterEnds_t::NEnds]
Tick coordinate of the start and end of the cluster.
float fSigmaEndTicks[ClusterEnds_t::NEnds]
Uncertainty on tick coordinate of the start and end of the cluster.
float fAngles[ClusterEnds_t::NEnds]
Angle of the start and end of the cluster, defined in [-pi,pi].
float cluster::ClusterMerger::Angle ( ClusterEnds_t  side) const
inline

Returns the angle at either end of the cluster.

Definition at line 178 of file LineMerger_module.cc.

178 { return fAngles[side]; }
float fAngles[ClusterEnds_t::NEnds]
Angle of the start and end of the cluster, defined in [-pi,pi].
template<typename T >
static void cluster::ClusterMerger::bot ( T &  var,
value 
)
inlinestaticprotected

Data referring to start and end of the cluster.

Definition at line 237 of file LineMerger_module.cc.

References value.

238  {
239  if (value < var) var = value;
240  }
double value
Definition: spectrum.C:18
float cluster::ClusterMerger::EdgeCharge ( ClusterEnds_t  side) const
inline

Returns the charge on the first or last wire of the cluster.

Definition at line 174 of file LineMerger_module.cc.

174 { return fEndCharges[side]; }
float fEndCharges[ClusterEnds_t::NEnds]
Charge on the start and end wire of the cluster.
float cluster::ClusterMerger::EndAngle ( ) const
inline

Returns the ending angle of the cluster.

Definition at line 168 of file LineMerger_module.cc.

168 { return fAngles[ClusterEnds_t::clEnd]; }
float fAngles[ClusterEnds_t::NEnds]
Angle of the start and end of the cluster, defined in [-pi,pi].
float cluster::ClusterMerger::EndCharge ( ) const
inline

Returns the charge on the last wire of the cluster.

Definition at line 165 of file LineMerger_module.cc.

165 { return fEndCharges[ClusterEnds_t::clEnd]; }
float fEndCharges[ClusterEnds_t::NEnds]
Charge on the start and end wire of the cluster.
float cluster::ClusterMerger::EndOpeningAngle ( ) const
inline

Returns the opening angle at the end of the cluster.

Definition at line 171 of file LineMerger_module.cc.

171 { return fOpeningAngles[ClusterEnds_t::clEnd]; }
float fOpeningAngles[ClusterEnds_t::NEnds]
Opening angle of the cluster shape at the start and end of the cluster.
float cluster::ClusterMerger::EndTick ( ) const
inline

Returns the tick coordinate of the end of the cluster.

Definition at line 131 of file LineMerger_module.cc.

131 { return fEndTicks[ClusterEnds_t::clEnd]; }
float fEndTicks[ClusterEnds_t::NEnds]
Tick coordinate of the start and end of the cluster.
float cluster::ClusterMerger::EndWire ( ) const
inline

Returns the wire coordinate of the end of the cluster.

Definition at line 128 of file LineMerger_module.cc.

128 { return fEndWires[ClusterEnds_t::clEnd]; }
float fEndWires[ClusterEnds_t::NEnds]
Data referring to start and end of the cluster.
bool cluster::ClusterMerger::hasPlane ( ) const
inline

Returns whether geometry plane is valid.

Definition at line 195 of file LineMerger_module.cc.

195 { return Plane().isValid; }
bool isValid
Whether this ID points to a valid element.
Definition: geo_types.h:210
geo::PlaneID Plane() const
Returns the plane ID this cluster lies on.
float cluster::ClusterMerger::OpeningAngle ( ClusterEnds_t  side) const
inline

Returns the opening angle at either end of the cluster.

Definition at line 182 of file LineMerger_module.cc.

182 { return fOpeningAngles[side]; }
float fOpeningAngles[ClusterEnds_t::NEnds]
Opening angle of the cluster shape at the start and end of the cluster.
geo::PlaneID cluster::ClusterMerger::Plane ( ) const
inline

Returns the plane ID this cluster lies on.

Definition at line 192 of file LineMerger_module.cc.

192 { return fPlaneID; }
geo::PlaneID fPlaneID
Location of the start of the cluster.
float cluster::ClusterMerger::SigmaEndTick ( ) const
inline

Returns the uncertainty on tick coordinate of the end of the cluster.

Definition at line 137 of file LineMerger_module.cc.

137 { return fSigmaEndTicks[ClusterEnds_t::clEnd]; }
float fSigmaEndTicks[ClusterEnds_t::NEnds]
Uncertainty on tick coordinate of the start and end of the cluster.
float cluster::ClusterMerger::SigmaEndWire ( ) const
inline

Returns the uncertainty on wire coordinate of the end of the cluster.

Definition at line 134 of file LineMerger_module.cc.

134 { return fSigmaEndWires[ClusterEnds_t::clEnd]; }
float fSigmaEndWires[ClusterEnds_t::NEnds]
Uncertainty on wire coordinate of the start and end of the cluster.
float cluster::ClusterMerger::SigmaStartTick ( ) const
inline

Data referring to start and end of the cluster.

Definition at line 125 of file LineMerger_module.cc.

125 { return fSigmaEndTicks[ClusterEnds_t::clStart]; }
float fSigmaEndTicks[ClusterEnds_t::NEnds]
Uncertainty on tick coordinate of the start and end of the cluster.
float cluster::ClusterMerger::SigmaStartWire ( ) const
inline

Returns the uncertainty on wire coordinate of the start of the cluster.

Definition at line 122 of file LineMerger_module.cc.

122 { return fSigmaEndWires[ClusterEnds_t::clStart]; }
float fSigmaEndWires[ClusterEnds_t::NEnds]
Uncertainty on wire coordinate of the start and end of the cluster.
float cluster::ClusterMerger::SigmaTickCoord ( ClusterEnds_t  side) const
inline

Returns the uncertainty on tick coordinate of one of the end sides of the cluster.

Definition at line 152 of file LineMerger_module.cc.

152 { return fSigmaEndTicks[side]; }
float fSigmaEndTicks[ClusterEnds_t::NEnds]
Uncertainty on tick coordinate of the start and end of the cluster.
float cluster::ClusterMerger::SigmaWireCoord ( ClusterEnds_t  side) const
inline

Returns the uncertainty on wire coordinate of one of the end sides of the cluster.

Definition at line 148 of file LineMerger_module.cc.

148 { return fSigmaEndWires[side]; }
float fSigmaEndWires[ClusterEnds_t::NEnds]
Uncertainty on wire coordinate of the start and end of the cluster.
float cluster::ClusterMerger::StartAngle ( ) const
inline

Returns the starting angle of the cluster.

Definition at line 159 of file LineMerger_module.cc.

159 { return fAngles[ClusterEnds_t::clStart]; }
float fAngles[ClusterEnds_t::NEnds]
Angle of the start and end of the cluster, defined in [-pi,pi].
float cluster::ClusterMerger::StartCharge ( ) const
inline

Returns the charge on the first wire of the cluster.

Definition at line 156 of file LineMerger_module.cc.

156 { return fEndCharges[ClusterEnds_t::clStart]; }
float fEndCharges[ClusterEnds_t::NEnds]
Charge on the start and end wire of the cluster.
float cluster::ClusterMerger::StartOpeningAngle ( ) const
inline

Returns the opening angle at the start of the cluster.

Definition at line 162 of file LineMerger_module.cc.

162 { return fOpeningAngles[ClusterEnds_t::clStart]; }
float fOpeningAngles[ClusterEnds_t::NEnds]
Opening angle of the cluster shape at the start and end of the cluster.
float cluster::ClusterMerger::StartTick ( ) const
inline

Returns the tick coordinate of the start of the cluster.

Definition at line 119 of file LineMerger_module.cc.

119 { return fEndTicks[ClusterEnds_t::clStart]; }
float fEndTicks[ClusterEnds_t::NEnds]
Tick coordinate of the start and end of the cluster.
float cluster::ClusterMerger::StartWire ( ) const
inline

Returns the wire coordinate of the start of the cluster.

Definition at line 116 of file LineMerger_module.cc.

116 { return fEndWires[ClusterEnds_t::clStart]; }
float fEndWires[ClusterEnds_t::NEnds]
Data referring to start and end of the cluster.
float cluster::ClusterMerger::TickCoord ( ClusterEnds_t  side) const
inline

Returns the tick coordinate of one of the end sides of the cluster.

Definition at line 144 of file LineMerger_module.cc.

144 { return fEndTicks[side]; }
float fEndTicks[ClusterEnds_t::NEnds]
Tick coordinate of the start and end of the cluster.
template<typename T >
static void cluster::ClusterMerger::top ( T &  var,
value 
)
inlinestaticprotected

Data referring to start and end of the cluster.

Definition at line 232 of file LineMerger_module.cc.

References value.

233  {
234  if (value > var) var = value;
235  }
double value
Definition: spectrum.C:18
geo::View_t cluster::ClusterMerger::View ( ) const
inline

Returns the view for this cluster.

Definition at line 189 of file LineMerger_module.cc.

189 { return fView; }
geo::View_t fView
View for this cluster.
float cluster::ClusterMerger::Width ( ) const
inline

A measure of the cluster width, in homogenized units.

Definition at line 186 of file LineMerger_module.cc.

186 { return fWidth; }
float fWidth
A measure of the cluster width, in homogenized units.
float cluster::ClusterMerger::WireCoord ( ClusterEnds_t  side) const
inline

Returns the wire coordinate of one of the end sides of the cluster.

Definition at line 140 of file LineMerger_module.cc.

140 { return fEndWires[side]; }
float fEndWires[ClusterEnds_t::NEnds]
Data referring to start and end of the cluster.

Member Data Documentation

float cluster::ClusterMerger::fAngles[ClusterEnds_t::NEnds]
protected

Angle of the start and end of the cluster, defined in [-pi,pi].

Definition at line 214 of file LineMerger_module.cc.

float cluster::ClusterMerger::fEndCharges[ClusterEnds_t::NEnds]
protected

Charge on the start and end wire of the cluster.

Definition at line 211 of file LineMerger_module.cc.

float cluster::ClusterMerger::fEndTicks[ClusterEnds_t::NEnds]
protected

Tick coordinate of the start and end of the cluster.

Definition at line 205 of file LineMerger_module.cc.

float cluster::ClusterMerger::fEndWires[ClusterEnds_t::NEnds]
protected

Data referring to start and end of the cluster.

Definition at line 199 of file LineMerger_module.cc.

float cluster::ClusterMerger::fOpeningAngles[ClusterEnds_t::NEnds]
protected

Opening angle of the cluster shape at the start and end of the cluster.

Definition at line 217 of file LineMerger_module.cc.

geo::PlaneID cluster::ClusterMerger::fPlaneID
protected

Location of the start of the cluster.

Definition at line 224 of file LineMerger_module.cc.

float cluster::ClusterMerger::fSigmaEndTicks[ClusterEnds_t::NEnds]
protected

Uncertainty on tick coordinate of the start and end of the cluster.

Definition at line 208 of file LineMerger_module.cc.

float cluster::ClusterMerger::fSigmaEndWires[ClusterEnds_t::NEnds]
protected

Uncertainty on wire coordinate of the start and end of the cluster.

Definition at line 202 of file LineMerger_module.cc.

geo::View_t cluster::ClusterMerger::fView
protected

View for this cluster.

Definition at line 222 of file LineMerger_module.cc.

float cluster::ClusterMerger::fWidth
protected

A measure of the cluster width, in homogenized units.

Definition at line 220 of file LineMerger_module.cc.

unsigned int cluster::ClusterMerger::n_clusters = 0
protected

number of clusters added so far

Definition at line 226 of file LineMerger_module.cc.


The documentation for this class was generated from the following file: