Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
#include "Alignment/ReferenceTrajectories/interface/ReferenceTrajectoryBase.h"

ReferenceTrajectoryBase::ReferenceTrajectoryBase(unsigned int nPar,
                                                 unsigned int nHits,
                                                 unsigned int nVirtualPar,
                                                 unsigned int nVirtualMeas)
    : theValidityFlag(false),
      theParamCovFlag(false),
      theNumberOfHits(nHits),
      theNumberOfPars(nPar),
      theNumberOfVirtualMeas(nVirtualMeas),
      theNumberOfVirtualPars(nVirtualPar),
      theTsosVec(),
      theRecHits(),
      theMeasurements(nMeasPerHit * nHits + nVirtualMeas),
      theMeasurementsCov(nMeasPerHit * nHits + nVirtualMeas, 0),
      theTrajectoryPositions(nMeasPerHit * nHits),
      theTrajectoryPositionCov(nMeasPerHit * nHits, 0),
      theParameters(nPar),
      theParameterCov(nPar, 0),
      theDerivatives(nMeasPerHit * nHits + nVirtualMeas, nPar + nVirtualPar, 0),
      theInnerTrajectoryToCurvilinear(5, 5, 0),
      theInnerLocalToTrajectory(5, 5, 0) {
  theTsosVec.reserve(nHits);
  theRecHits.reserve(nHits);
}

unsigned int ReferenceTrajectoryBase::numberOfUsedRecHits(
    const TransientTrackingRecHit::ConstRecHitContainer& recHits) const {
  unsigned int nUsedHits = 0;
  TransientTrackingRecHit::ConstRecHitContainer::const_iterator itHit;
  for (itHit = recHits.begin(); itHit != recHits.end(); ++itHit)
    if (useRecHit(*itHit))
      ++nUsedHits;
  return nUsedHits;
}

bool ReferenceTrajectoryBase::useRecHit(const TransientTrackingRecHit::ConstRecHitPointer& hitPtr) const {
  return hitPtr->isValid();
}