8 #include <tracking/trackFindingCDC/fitting/CDCObservations2D.h> 
   10 #include <tracking/trackFindingCDC/fitting/EigenObservationMatrix.h> 
   12 #include <tracking/trackFindingCDC/eventdata/tracks/CDCTrack.h> 
   13 #include <tracking/trackFindingCDC/eventdata/tracks/CDCAxialSegmentPair.h> 
   14 #include <tracking/trackFindingCDC/eventdata/segments/CDCSegment3D.h> 
   15 #include <tracking/trackFindingCDC/eventdata/segments/CDCSegment2D.h> 
   16 #include <tracking/trackFindingCDC/eventdata/segments/CDCWireHitSegment.h> 
   17 #include <tracking/trackFindingCDC/eventdata/hits/CDCFacet.h> 
   18 #include <tracking/trackFindingCDC/eventdata/hits/CDCRLWireHitTriple.h> 
   19 #include <tracking/trackFindingCDC/eventdata/hits/CDCRLWireHitPair.h> 
   20 #include <tracking/trackFindingCDC/eventdata/hits/CDCRLWireHit.h> 
   21 #include <tracking/trackFindingCDC/eventdata/hits/CDCWireHit.h> 
   23 #include <tracking/trackFindingCDC/eventdata/trajectories/CDCTrajectory2D.h> 
   25 #include <tracking/trackFindingCDC/topology/CDCWire.h> 
   27 #include <tracking/trackFindingCDC/geometry/Vector2D.h> 
   30 using namespace TrackFindingCDC;
 
   41   if (std::isnan(x)) 
return 0;
 
   42   if (std::isnan(y)) 
return 0;
 
   44   if (std::isnan(signedRadius)) {
 
   45     B2WARNING(
"Signed radius is nan. Skipping observation");
 
   49   if (std::isnan(weight)) {
 
   50     B2WARNING(
"Weight is nan. Skipping observation");
 
   64   return fill(pos2D.
x(), pos2D.
y(), signedRadius, weight);
 
   71   double signedDriftLength = 0;
 
   72   if (
m_fitPos == EFitPos::c_RLDriftCircle and isValid(rlInfo)) {
 
   75     signedDriftLength = 0;
 
   85     variance = fabs(driftLength);
 
   89     if (abs(rlInfo) != 1) {
 
   95   return fill(wireRefPos2D, signedDriftLength, 1 / variance);
 
  101     return append(*(wireHit), rlInfo);
 
  116   double signedDriftLength = 0;
 
  117   if (
m_fitPos == EFitPos::c_RLDriftCircle and isValid(rlInfo)) {
 
  118     signedDriftLength = 
static_cast<double>(rlInfo) * driftLength;
 
  120     signedDriftLength = 0;
 
  129     variance = fabs(driftLength);
 
  133     if (abs(rlInfo) != 1) {
 
  136       variance = driftLengthVariance;
 
  140   return fill(wireRefPos2D, signedDriftLength, 1 / variance);
 
  156   if (
m_fitPos == EFitPos::c_RecoPos) {
 
  161     return append(rlWireHitTriple);
 
  168   double signedDriftLength = 0;
 
  169   if (
m_fitPos == EFitPos::c_RecoPos) {
 
  171     signedDriftLength = 0;
 
  179   } 
else if (
m_fitPos == EFitPos::c_RLDriftCircle) {
 
  182   } 
else if (
m_fitPos == EFitPos::c_WirePos) {
 
  184     signedDriftLength = 0;
 
  196     variance = std::fabs(driftLength);
 
  197   } 
else if (
m_fitVariance == EFitVariance::c_Pseudo or abs(rlInfo) != 1) {
 
  203   return fill(fitPos2D, signedDriftLength, 1 / variance);
 
  209   double signedDriftLength = 0;
 
  210   if (
m_fitPos == EFitPos::c_RecoPos) {
 
  212     signedDriftLength = 0;
 
  213   } 
else if (
m_fitPos == EFitPos::c_RLDriftCircle) {
 
  216   } 
else if (
m_fitPos == EFitPos::c_WirePos) {
 
  218     signedDriftLength = 0;
 
  230     variance = std::fabs(driftLength);
 
  231   } 
else if (
m_fitVariance == EFitVariance::c_Pseudo or abs(rlInfo) != 1) {
 
  237   return fill(fitPos2D, signedDriftLength, 1 / variance);
 
  242   std::size_t nAppendedHits = 0;
 
  244     nAppendedHits += 
append(recoHit2D);
 
  246   return nAppendedHits;
 
  251   std::size_t nAppendedHits = 0;
 
  253     nAppendedHits += 
append(recoHit3D);
 
  255   return nAppendedHits;
 
  260   std::size_t nAppendedHits = 0;
 
  262   if (ptrStartSegment2D) {
 
  263     const CDCSegment2D& startSegment2D = *ptrStartSegment2D;
 
  268   if (ptrEndSegment2D) {
 
  272   return nAppendedHits;
 
  277   std::size_t nAppendedHits = 0;
 
  279     nAppendedHits += 
append(recoHit3D);
 
  281   return nAppendedHits;
 
  286   std::size_t nAppendedHits = 0;
 
  287   for (
const CDCWire* ptrWire : wires) {
 
  288     if (not ptrWire) 
continue;
 
  289     const CDCWire& wire = *ptrWire;
 
  291     const double driftLength = 0.0;
 
  292     const double weight = 1.0;
 
  293     nAppendedHits += 
fill(wirePos, driftLength, weight);
 
  295   return nAppendedHits;
 
  300   std::size_t nAppendedHits = 0;
 
  301   for (
const CDCWireHit* ptrWireHit : wireHits) {
 
  302     if (not ptrWireHit) 
continue;
 
  304     nAppendedHits += 
append(wireHit);
 
  306   return nAppendedHits;
 
  316   std::size_t result = 0;
 
  317   Index nObservations = 
size();
 
  319   for (Index iObservation = 0; iObservation < nObservations; ++iObservation) {
 
  321     bool hasDriftLength = (driftLength != 0.0);
 
  322     result += hasDriftLength ? 1 : 0;
 
  330   std::size_t n = 
size();
 
  331   if (n == 0) 
return Vector2D(NAN, NAN);
 
  332   std::size_t i = n / 2;
 
  347   Eigen::Matrix<double, 1, 2> eigenOrigin(origin.
x(), origin.
y());
 
  348   EigenObservationMatrix eigenObservations = getEigenObservationMatrix(
this);
 
  349   eigenObservations.leftCols<2>().rowwise() -= eigenOrigin;
 
Class representing a pair of reconstructed axial segements in adjacent superlayer.
const CDCAxialSegment2D * getStartSegment() const
Getter for the start segment.
const CDCAxialSegment2D * getEndSegment() const
Getter for the end segment.
Class representing a triple of neighboring oriented wire with additional trajectory information.
CDCRecoHit2D getEndRecoHit2D() const
Getter for the third reconstucted hit.
CDCRecoHit2D getMiddleRecoHit2D() const
Getter for the second reconstucted hit.
CDCRecoHit2D getStartRecoHit2D() const
Getter for the first reconstucted hit.
EFitPos m_fitPos
Indicator which positional information should preferably be extracted from hits in calls to append.
static double getPseudoDriftLengthVariance(double driftLength, double driftLengthVariance)
Gets the pseudo variance.
double getX(int iObservation) const
Getter for the x value of the observation at the given index.
Vector2D getBackPos2D() const
Get the postion of the first observation.
Vector2D centralize()
Picks one observation as a reference point and transform all observations to that new origin.
double getY(int iObservation) const
Getter for the y value of the observation at the given index.
Vector2D getCentralPoint() const
Extracts the observation center that is at the index in the middle.
std::size_t append(const CDCWireHit &wireHit, ERightLeft rlInfo=ERightLeft::c_Unknown)
Appends the hit circle at wire reference position without a right left passage hypotheses.
double getDriftLength(int iObservation) const
Getter for the signed drift radius of the observation at the given index.
Vector2D getFrontPos2D() const
Get the postion of the first observation.
std::size_t appendRange(const CDCSegment2D &segment2D)
Appends all reconstructed hits from the two dimensional segment.
std::size_t fill(double x, double y, double signedRadius=0.0, double weight=1.0)
Appends the observed position.
void passiveMoveBy(const Vector2D &origin)
Moves all observations passively such that the given vector becomes to origin of the new coordinate s...
double getTotalPerpS(const CDCTrajectory2D &trajectory2D) const
Calculate the total transvers travel distance traversed by these observations comparing the travel di...
EFitVariance m_fitVariance
Indicator which variance information should preferably be extracted from hits in calls to append.
std::size_t size() const
Returns the number of observations stored.
std::size_t getNObservationsWithDriftRadius() const
Returns the number of observations having a drift radius radius.
std::vector< double > m_observations
Memory for the individual observations.
A pair of oriented wire hits.
CDCRLWireHit & getFromRLWireHit()
Getter for the first oriented wire hit.
CDCRLWireHit & getToRLWireHit()
Getter for the second oriented wire hit.
Class representing a triple of neighboring wire hits.
CDCRLWireHit & getEndRLWireHit()
Getter for the third oriented wire hit.
CDCRLWireHit & getMiddleRLWireHit()
Getter for the second oriented wire hit.
CDCRLWireHit & getStartRLWireHit()
Getter for the first oriented wire hit.
Class representing an oriented hit wire including a hypotheses whether the causing track passes left ...
double getRefDriftLengthVariance() const
Getter for the variance of the drift length at the reference position of the wire.
double getRefDriftLength() const
Getter for the drift length at the reference position of the wire.
const Vector2D & getRefPos2D() const
The two dimensional reference position of the underlying wire.
ERightLeft getRLInfo() const
Getter for the right left passage information.
Class representing a two dimensional reconstructed hit in the central drift chamber.
double getRefDriftLengthVariance() const
Getter for the uncertainty in the drift length at the wire reference position.
double getRefDriftLength() const
Getter for the drift length at the wire reference position.
double getSignedRefDriftLength() const
Getter for the drift length at the wire reference position signed with the right left passage hypothe...
Vector2D getRecoPos2D() const
Getter for the position in the reference plane.
const CDCWire & getWire() const
Getter for the wire the reconstructed hit assoziated to.
ERightLeft getRLInfo() const
Getter for the right left passage information.
Class representing a three dimensional reconstructed hit.
double getSignedRecoDriftLength() const
Returns the drift length next to the reconstructed position.
Vector2D getRecoWirePos2D() const
Returns the position of the wire in the xy plain the reconstructed position is located in.
double getRecoDriftLengthVariance() const
Returns the drift length variance next to the reconstructed position.
const Vector2D & getRecoPos2D() const
Getter for the 2d position of the hit.
ERightLeft getRLInfo() const
Getter for the right left passage information.
A reconstructed sequence of two dimensional hits in one super layer.
A segment consisting of three dimensional reconstructed hits.
Class representing a sequence of three dimensional reconstructed hits.
Particle trajectory as it is seen in xy projection represented as a circle.
double calcArcLength2DBetween(const Vector2D &fromPoint, const Vector2D &toPoint) const
Calculate the travel distance between the two given positions Returns the travel distance on the traj...
A segment consisting of two dimensional reconsturcted hits.
Class representing a hit wire in the central drift chamber.
double getRefDriftLengthVariance() const
Getter for the variance of the drift length at the reference position of the wire.
double getRefDriftLength() const
Getter for the drift length at the reference position of the wire.
static constexpr const double c_simpleDriftLengthVariance
A default value for the drift length variance if no variance from the drift length translation is ava...
const Vector2D & getRefPos2D() const
The two dimensional reference position (z=0) of the underlying wire.
Class representing a sense wire in the central drift chamber.
const Vector2D & getRefPos2D() const
Getter for the wire reference position for 2D tracking Gives the wire's reference position projected ...
A two dimensional vector which is equipped with functions for correct handeling  of orientation relat...
double x() const
Getter for the x coordinate.
double normSquared() const
Calculates  .
bool hasNAN() const
Checks if one of the coordinates is NAN.
double y() const
Getter for the y coordinate.
ERightLeft
Enumeration to represent the distinct possibilities of the right left passage.
Abstract base class for different kinds of events.