8#include <tracking/trackFindingCDC/findlets/minimal/FacetCreator.h>
10#include <tracking/trackFindingCDC/eventdata/segments/CDCWireHitCluster.h>
11#include <tracking/trackFindingCDC/eventdata/hits/CDCFacet.h>
12#include <tracking/trackFindingCDC/eventdata/hits/CDCWireHit.h>
14#include <tracking/trackFindingCDC/filters/base/RelationFilterUtil.h>
15#include <tracking/trackFindingCDC/fitting/FacetFitter.h>
17#include <tracking/trackFindingCDC/utilities/VectorRange.h>
18#include <tracking/trackFindingCDC/utilities/StringManipulation.h>
20#include <framework/core/ModuleParamList.templateDetails.h>
27using namespace TrackFindingCDC;
37 return "Creates hit triplet (facets) from each cluster filtered by a acceptance criterion.";
46 moduleParamList->
addParameter(prefixed(prefix,
"updateDriftLength"),
48 "Switch to reestimate the drift length",
51 moduleParamList->
addParameter(prefixed(prefix,
"leastSquareFit"),
53 "Switch to fit the facet with the least square method "
54 "for drift length estimation",
58void FacetCreator::apply(
const std::vector<CDCWireHitCluster>& inputClusters, std::vector<CDCFacet>& facets)
64 if (cluster.getBackgroundFlag()) {
67 B2ASSERT(
"Expect the clusters to be sorted", std::is_sorted(cluster.begin(), cluster.end()));
70 const std::vector<CDCWireHit*>& wireHits = cluster;
76 B2ASSERT(
"Wire neighborhood is not symmetric. Check the geometry.",
80 std::size_t nBefore = facets.size();
82 std::size_t nAfter = facets.size();
86 std::sort(facetsInCluster.
begin(), facetsInCluster.
end());
88 B2ASSERT(
"Expected all facets to be different",
89 std::adjacent_find(facetsInCluster.
begin(), facetsInCluster.
end()) ==
90 facetsInCluster.
end());
92 for (
CDCFacet& facet : facetsInCluster) {
93 facet.setICluster(iCluster);
100 std::vector<CDCFacet>& facets)
102 for (
const CDCWireHit* ptrMiddleWireHit : wireHits) {
103 if (not ptrMiddleWireHit)
continue;
104 const CDCWireHit& middleWireHit = *ptrMiddleWireHit;
107 const auto neighbors = asRange(
108 std::equal_range(wireHitRelations.begin(), wireHitRelations.end(), ptrMiddleWireHit));
111 const CDCWireHit* ptrStartWireHit(startWireHitRelation.getTo());
113 if (not ptrStartWireHit)
continue;
114 const CDCWireHit& startWireHit = *ptrStartWireHit;
118 const CDCWireHit* ptrEndWireHit(endWireHitRelation.getTo());
120 if (not ptrEndWireHit)
continue;
121 const CDCWireHit& endWireHit = *ptrEndWireHit;
125 if (ptrStartWireHit->isOnWire(ptrEndWireHit->getWire()))
continue;
136 std::vector<CDCFacet>& facets)
139 CDCRLWireHit startRLWireHit(&startWireHit, ERightLeft::c_Left);
140 CDCRLWireHit middleRLWireHit(&middleWireHit, ERightLeft::c_Left);
141 CDCRLWireHit endRLWireHit(&endWireHit, ERightLeft::c_Left);
144 for (
ERightLeft startRLInfo : {ERightLeft::c_Left, ERightLeft::c_Right}) {
146 for (
ERightLeft middleRLInfo : {ERightLeft::c_Left, ERightLeft::c_Right}) {
148 for (
ERightLeft endRLInfo : {ERightLeft::c_Left, ERightLeft::c_Right}) {
158 if (std::isnan(feasibleWeight))
continue;
180 if (not std::isnan(weight)) {
182 facets.insert(facets.end(), facet);
The Module parameter list class.
bool hasTakenFlag() const
Gets the current state of the taken marker flag.
void setCellWeight(Weight weight)
Setter for the cell weight.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) override
Expose the set of parameters of the filter to the module parameter list.
Class representing a triple of neighboring oriented wire with additional trajectory information.
void adjustFitLine() const
Adjusts the contained fit line to touch such that it touches the first and third hit.
AutomatonCell & getAutomatonCell() const
Mutable getter for the automaton cell.
void invalidateFitLine()
Clear all information in the fit.
void setEndRLInfo(const ERightLeft endRLInfo)
Setter for the right left passage information of the third oriented wire hit.
CDCRLWireHit & getStartRLWireHit()
Getter for the first oriented wire hit.
void setMiddleRLInfo(const ERightLeft middleRLInfo)
Setter for the right left passage information of the second oriented wire hit.
CDCRLWireHit & getEndRLWireHit()
Getter for the third oriented wire hit.
CDCRLWireHit & getMiddleRLWireHit()
Getter for the second oriented wire hit.
void setStartRLInfo(const ERightLeft startRLInfo)
Setter for the right left passage information of the first oriented wire hit.
Class representing an oriented hit wire including a hypotheses whether the causing track passes left ...
void setRefDriftLength(double driftLength)
Setter for the drift length at the reference position of the wire.
An aggregation of CDCWireHits.
Class representing a hit wire in the central drift chamber.
double getRefDriftLength() const
Getter for the drift length at the reference position of the wire.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the set of parameters of the filter to the module parameter list.
void addProcessingSignalListener(ProcessingSignalListener *psl)
Register a processing signal listener to be notified.
DriftLengthEstimator m_driftLengthEstimator
Instance of the drift length estimator to be used.
BridgingWireHitRelationFilter m_wireHitRelationFilter
The filter for the hit neighborhood.
bool m_param_feasibleRLOnly
Parameter : Switch to apply the rl feasibility cut.
void apply(const std::vector< CDCWireHitCluster > &inputClusters, std::vector< CDCFacet > &facets) final
Central function creating the hit triplets from the clusters.
std::vector< WeightedRelation< CDCWireHit > > m_wireHitRelations
Memory for the wire hit neighborhood in within a cluster.
bool m_param_leastSquareFit
Parameter : Switch to fit the facet with least square method for the drift length update.
std::string getDescription() final
Short description of the findlet.
ChooseableFacetFilter m_facetFilter
The filter to be used for the facet generation.
bool m_param_updateDriftLength
Parameter : Switch to reestimate the drift length.
void createFacetsForHitTriple(const CDCWireHit &startWireHit, const CDCWireHit &middleWireHit, const CDCWireHit &endWireHit, std::vector< CDCFacet > &facets)
Generates reconstruted facets on the three given wire hits by hypothesizing over the 8 left right pas...
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the parameters to a module.
FeasibleRLFacetFilter m_feasibleRLFacetFilter
The feasibility filter for the right left passage information.
void createFacets(const std::vector< CDCWireHit * > &wireHits, const std::vector< WeightedRelation< CDCWireHit > > &wireHitRelations, std::vector< CDCFacet > &facets)
Generates facets on the given wire hits generating neighboring triples of hits.
FacetCreator()
Constructor adding the filter as a subordinary processing signal listener.
static double fit(const CDCFacet &facet, int nSteps=100)
Fits a proper line to facet and returns the chi2.
void exposeParameters(ModuleParamList *moduleParamList, const std::string &prefix) final
Expose the set of parameters of the filter to the module parameter list.
A pair of iterators usable with the range base for loop.
Iterator begin() const
Begin of the range for range based for.
Iterator end() const
End of the range for range based for.
A parameter line including including an line covariance matrix which is interpreted as located in the...
Type for two related objects with a weight.
void addParameter(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module list.
ERightLeft
Enumeration to represent the distinct possibilities of the right left passage.
Abstract base class for different kinds of events.
double updateDriftLength(CDCRecoHit2D &recoHit2D)
Update the drift length of the reconstructed hit in place.
static void appendUsing(ARelationFilter &relationFilter, const std::vector< AObject * > &froms, const std::vector< AObject * > &tos, std::vector< WeightedRelation< AObject > > &weightedRelations, unsigned int maximumNumberOfRelations=std::numeric_limits< unsigned int >::max())
Appends relations between elements in the given AItems using the ARelationFilter.
Utility structure with functions related to weighted relations.