27 #include "canvas/Persistency/Common/FindManyP.h" 119 return fEndWires[ClusterEnds_t::clStart];
126 return fEndTicks[ClusterEnds_t::clStart];
133 return fSigmaEndWires[ClusterEnds_t::clStart];
140 return fSigmaEndTicks[ClusterEnds_t::clStart];
147 return fEndWires[ClusterEnds_t::clEnd];
154 return fEndTicks[ClusterEnds_t::clEnd];
161 return fSigmaEndWires[ClusterEnds_t::clEnd];
168 return fSigmaEndTicks[ClusterEnds_t::clEnd];
175 return fEndWires[side];
183 return fEndTicks[side];
191 return fSigmaEndWires[side];
199 return fSigmaEndTicks[side];
207 return fEndCharges[ClusterEnds_t::clStart];
214 return fAngles[ClusterEnds_t::clStart];
221 return fOpeningAngles[ClusterEnds_t::clStart];
228 return fEndCharges[ClusterEnds_t::clEnd];
235 return fAngles[ClusterEnds_t::clEnd];
242 return fOpeningAngles[ClusterEnds_t::clEnd];
249 return fEndCharges[side];
257 return fAngles[side];
265 return fOpeningAngles[side];
294 return Plane().isValid;
299 float fEndWires[ClusterEnds_t::NEnds];
302 float fSigmaEndWires[ClusterEnds_t::NEnds];
305 float fEndTicks[ClusterEnds_t::NEnds];
308 float fSigmaEndTicks[ClusterEnds_t::NEnds];
311 float fEndCharges[ClusterEnds_t::NEnds];
314 float fAngles[ClusterEnds_t::NEnds];
317 float fOpeningAngles[ClusterEnds_t::NEnds];
326 unsigned int n_clusters = 0;
331 template <
typename T>
335 if (value > var) var =
value;
337 template <
typename T>
341 if (value < var) var =
value;
349 fEndWires[iDestEnd] = cluster.
WireCoord(iSrcEnd);
351 fEndTicks[iDestEnd] = cluster.
TickCoord(iSrcEnd);
353 fEndCharges[iDestEnd] = cluster.
EdgeCharge(iSrcEnd);
354 fAngles[iDestEnd] = cluster.
Angle(iSrcEnd);
355 fOpeningAngles[iDestEnd] = cluster.
OpeningAngle(iSrcEnd);
361 if (!cluster.
isValid())
return false;
363 if (n_clusters == 0) {
364 AdoptEnd(cluster, ClusterEnds_t::clStart);
365 AdoptEnd(cluster, ClusterEnds_t::clEnd);
366 fWidth = cluster.
Width();
367 fView = cluster.
View();
368 fPlaneID = cluster.
Plane();
373 if (cluster.
View() !=
View())
return false;
380 AdoptEnd(cluster, ClusterEnds_t::clStart);
382 if (cluster.
EndWire() < EndWire()) {
383 AdoptEnd(cluster, ClusterEnds_t::clEnd);
388 if (!hasPlane()) fPlaneID = cluster.
Plane();
406 Add(cluster, cluster_hits);
449 hits.insert(prepend ? hits.begin() : hits.end(), cluster_hits.begin(), cluster_hits.end());
462 AddHits(cluster_hits, prepend);
470 ,
fSlope(pset.get<
double>(
"Slope"))
473 produces<std::vector<recob::Cluster>>();
474 produces<art::Assns<recob::Cluster, recob::Hit>>();
490 constexpr
size_t nViews = 3;
493 std::array<std::vector<size_t>, nViews> ClsIndices;
496 std::array<std::vector<int>, nViews> Cls_matches;
499 for (
size_t i = 0; i < clusterVecHandle->size(); ++i) {
505 switch (cl->
View()) {
512 Cls_matches[view].push_back(0);
513 ClsIndices[view].push_back(i);
516 auto SuperClusters = std::make_unique<std::vector<recob::Cluster>>();
517 auto assn = std::make_unique<art::Assns<recob::Cluster, recob::Hit>>();
526 for (
size_t i = 0; i < nViews; ++i) {
528 int clustersfound = 0;
531 for (
size_t c = 0;
c < ClsIndices[i].size(); ++
c) {
532 if (Cls_matches[i][clsnum1] == 1) {
540 recob::Cluster const& StartingCluster = clusterVecHandle->at(ClsIndices[i][
c]);
544 Cls_matches[i][clsnum1] = 1;
548 for (
size_t c2 = 0; c2 < ClsIndices[i].size(); ++c2) {
550 if (Cls_matches[i][clsnum2] == 1) {
555 const recob::Cluster& cl2(clusterVecHandle->at(ClsIndices[i][c2]));
578 if (sameSlope && (sameEndpoint != 0)) {
583 cl1.Add(cl2, fmh.at(ClsIndices[i][c2]), sameEndpoint == 1);
584 Cls_matches[i][clsnum2] = 1;
592 ClusterParamAlgo.ImportHits(gser, cl1.Hits());
595 SuperClusters->emplace_back(cl1.StartWire(),
596 cl1.SigmaStartWire(),
598 cl1.SigmaStartTick(),
601 cl1.StartOpeningAngle(),
608 cl1.EndOpeningAngle(),
609 ClusterParamAlgo.Integral().value(),
610 ClusterParamAlgo.IntegralStdDev().value(),
611 ClusterParamAlgo.SummedADC().value(),
612 ClusterParamAlgo.SummedADCStdDev().value(),
613 ClusterParamAlgo.NHits(),
614 ClusterParamAlgo.MultipleHitDensity(),
630 for (
size_t i = 0; i < SuperClusters->size(); ++i)
642 double sl1 = atan(slope1);
643 double sl2 = atan(slope2);
662 std::sqrt((
pow(sclendwire - cl2startwire, 2) * 13.5) +
pow(sclendtime - cl2starttime, 2));
666 std::sqrt((
pow(sclstartwire - cl2endwire, 2) * 13.5) +
pow(sclstarttime - cl2endtime, 2));
float EndOpeningAngle() const
Returns the opening angle at the end of the cluster.
MaybeLogger_< ELseverityLevel::ELsev_info, true > LogVerbatim
int EndpointCompatibility(float sclstartwire, float sclstarttime, float sclendwire, float sclendtime, float cl2startwire, float cl2starttime, float cl2endwire, float cl2endtime)
float EndWire() const
Returns the wire coordinate of the end of the cluster.
ClusterAndHitMerger(recob::Cluster const &cluster, HitVector_t const &cluster_hits)
float SigmaStartWire() const
Returns the uncertainty on wire coordinate of the start of the cluster.
float StartAngle() const
Returns the starting angle of the cluster.
float SigmaWireCoord(ClusterEnds_t side) const
Returns the uncertainty on wire coordinate of one of the end sides of the cluster.
float EdgeCharge(ClusterEnds_t side) const
Returns the charge on the first or last wire of the cluster.
float Angle(ClusterEnds_t side) const
Returns the angle at either end of the cluster.
ClusterMerger(recob::Cluster const &cluster)
float SigmaTickCoord(ClusterEnds_t side) const
Returns the uncertainty on tick coordinate of one of the end sides of the cluster.
AdcChannelData::View View
enum geo::_plane_proj View_t
Enumerate the possible plane projections.
void AddHits(TCSlice &slc, Trajectory &tj, unsigned short ipt, bool &sigOK)
float TickCoord(ClusterEnds_t side) const
Returns the tick coordinate of one of the end sides of the cluster.
void produce(art::Event &evt) override
EDProducer(fhicl::ParameterSet const &pset)
The data type to uniquely identify a Plane.
float EdgeCharge(ClusterEnds_t side) const
Returns the charge on the first or last wire of the cluster.
float SigmaTickCoord(ClusterEnds_t side) const
Returns the uncertainty on tick coordinate of one of the end sides of the cluster.
float StartWire() const
Returns the wire coordinate of the start of the cluster.
Planes which measure Z direction.
Set of hits with a 2D structure.
geo::PlaneID Plane() const
Returns the plane ID this cluster lies on.
Cluster finding and building.
static void bot(T &var, T value)
float fWidth
A measure of the cluster width, in homogenized units.
bool isValid() const
Returns if the cluster is valid (that is, if its ID is not invalid)
float SigmaStartTick() const
float StartWire() const
Returns the wire coordinate of the start of the cluster.
art framework interface to geometry description
static const SentryArgument_t Sentry
An instance of the sentry object.
float StartOpeningAngle() const
Returns the opening angle at the start of the cluster.
LineMerger(fhicl::ParameterSet const &pset)
bool Add(recob::Cluster const &cluster, HitVector_t const &cluster_hits, bool prepend=false)
Merges a single cluster into this object.
float TickCoord(ClusterEnds_t side) const
Returns the tick coordinate of one of the end sides of the cluster.
bool getByLabel(std::string const &label, std::string const &instance, Handle< PROD > &result) const
#define DEFINE_ART_MODULE(klass)
static void top(T &var, T value)
std::string fClusterModuleLabel
Wrapper for ClusterParamsAlgBase objects to accept diverse input.
void AdoptEnd(recob::Cluster const &cluster, ClusterEnds_t iEnd)
Imports all the member of the corresponding end.
float SigmaEndWire() const
Returns the uncertainty on wire coordinate of the end of the cluster.
float Width() const
A measure of the cluster width, in homogenized units.
float SigmaEndTick() const
Returns the uncertainty on tick coordinate of the end of the cluster.
Wrapper for ClusterParamsAlgBase objects to accept arbitrary input.
ProductID put(std::unique_ptr< PROD > &&edp, std::string const &instance={})
bool CreateAssn(PRODUCER const &prod, art::Event &evt, std::vector< T > const &a, art::Ptr< U > const &b, art::Assns< U, T > &assn, std::string a_instance, size_t indx=UINT_MAX)
Creates a single one-to-one association.
double distance(double x1, double y1, double z1, double x2, double y2, double z2)
float Angle(ClusterEnds_t side) const
Returns the angle at either end of the cluster.
float WireCoord(ClusterEnds_t side) const
Returns the wire coordinate of one of the end sides of the cluster.
Definition of data types for geometry description.
bool hasPlane() const
Returns whether geometry plane is valid.
float SigmaWireCoord(ClusterEnds_t side) const
Returns the uncertainty on wire coordinate of one of the end sides of the cluster.
Q_EXPORT QTSManip setw(int w)
float StartTick() const
Returns the tick coordinate of the start of the cluster.
Class merging clusters: recomputes start and end position and hit list.
float Width() const
A measure of the cluster width, in homogenized units.
HitVector_t hits
hits in the cluster
HitVector_t const & Hits() const
Returns a constant reference to the current list of hits.
geo::View_t View() const
Returns the view for this cluster.
Declaration of signal hit object.
geo::View_t fView
View for this cluster.
float StartCharge() const
Returns the charge on the first wire of the cluster.
float OpeningAngle(ClusterEnds_t side) const
Returns the opening angle at either end of the cluster.
ID_t ID() const
Identifier of this cluster.
bool SlopeCompatibility(double slope1, double slope2)
unsigned int NHits() const
Number of hits in the cluster.
bool hasPlane() const
Returns whether geometry plane is valid.
double distance2(double x, double y, double z, double *p)
geo::View_t View() const
Returns the view for this cluster.
Interface to class computing cluster parameters.
geo::PlaneID Plane() const
Returns the plane ID this cluster lies on.
std::vector< HitPtr_t > HitVector_t
vector of pointers to hits
recob::tracking::Plane Plane
Class merging clusters: recomputes start and end position and hit list.
float OpeningAngle(ClusterEnds_t side) const
Returns the opening angle at either end of the cluster.
Q_EXPORT QTSManip setfill(int f)
float EndAngle() const
Returns the ending angle of the cluster.
recob::Cluster::ID_t ID_t
Type of cluster ID.
float WireCoord(ClusterEnds_t side) const
Returns the wire coordinate of one of the end sides of the cluster.
int ID_t
Type of cluster ID.
void AddHits(HitVector_t const &cluster_hits, bool prepend)
geo::PlaneID fPlaneID
Location of the start of the cluster.
float EndCharge() const
Returns the charge on the last wire of the cluster.
float EndTick() const
Returns the tick coordinate of the end of the cluster.
bool Add(recob::Cluster const &cluster)
Merges a single cluster into this object.
float EndWire() const
Returns the wire coordinate of the end of the cluster.