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 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
#include "DataFormats/TrackReco/interface/TrackExtra.h"
#include "DataFormats/TrackReco/interface/fillCovariance.h"

using namespace reco;

TrackExtra::TrackExtra(const Point &outerPosition,
                       const Vector &outerMomentum,
                       bool ok,
                       const Point &innerPosition,
                       const Vector &innerMomentum,
                       bool iok,
                       const CovarianceMatrix &outerCov,
                       unsigned int outerId,
                       const CovarianceMatrix &innerCov,
                       unsigned int innerId,
                       PropagationDirection seedDir,
                       edm::RefToBase<TrajectorySeed> seedRef)
    :

      TrackExtraBase(),
      outerPosition_(outerPosition),
      outerMomentum_(outerMomentum),
      outerOk_(ok),
      outerDetId_(outerId),
      innerPosition_(innerPosition),
      innerMomentum_(innerMomentum),
      innerOk_(iok),
      innerDetId_(innerId),
      seedDir_(seedDir),
      seedRef_(seedRef) {
  index idx = 0;
  for (index i = 0; i < dimension; ++i) {
    for (index j = 0; j <= i; ++j) {
      outerCovariance_[idx] = outerCov(i, j);
      innerCovariance_[idx] = innerCov(i, j);
      ++idx;
    }
  }
}

TrackExtra::CovarianceMatrix TrackExtra::outerStateCovariance() const {
  CovarianceMatrix v;
  fillCovariance(v, outerCovariance_);
  return v;
}

TrackExtra::CovarianceMatrix TrackExtra::innerStateCovariance() const {
  CovarianceMatrix v;
  fillCovariance(v, innerCovariance_);
  return v;
}

TrackExtra::CovarianceMatrix &TrackExtra::fillOuter(CovarianceMatrix &v) const {
  return fillCovariance(v, outerCovariance_);
}

TrackExtra::CovarianceMatrix &TrackExtra::fillInner(CovarianceMatrix &v) const {
  return fillCovariance(v, innerCovariance_);
}