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 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
/****************************************************************************
 *
 * This is a part of TOTEM offline software.
 * Authors:
 *   Hubert Niewiadomski
 *   Jan Kašpar (jan.kaspar@gmail.com)
 *
 ****************************************************************************/

#include "DataFormats/CTPPSReco/interface/TotemRPLocalTrack.h"

//----------------------------------------------------------------------------------------------------

TMatrixD TotemRPLocalTrack::trackPointInterpolationCovariance(double z) const {
  TMatrixD h(2, 4);
  h(0, 0) = 1;
  h(1, 1) = 1;
  h(0, 2) = z - z0_;
  h(1, 3) = z - z0_;

  TMatrixD cov_matr(dimension, dimension);
  for (int i = 0; i < dimension; ++i)
    for (int j = 0; j < dimension; ++j)
      cov_matr(i, j) = CovarianceMatrixElement(i, j);

  TMatrixD V_hT(cov_matr, TMatrixD::kMultTranspose, h);
  //h*=V_hT;
  //return h;
  return TMatrixD(h, TMatrixD::kMult, V_hT);
}

//----------------------------------------------------------------------------------------------------

TotemRPLocalTrack::TotemRPLocalTrack(double z0,
                                     const TVectorD &track_params_vector,
                                     const TMatrixD &par_covariance_matrix,
                                     double chiSquared)
    : z0_(z0), chiSquared_(chiSquared), valid_(true) {
  for (int i = 0; i < dimension; ++i) {
    track_params_vector_[i] = track_params_vector[i];
    for (int j = 0; j < dimension; ++j) {
      CovarianceMatrixElement(i, j) = par_covariance_matrix(i, j);
    }
  }
}

//----------------------------------------------------------------------------------------------------

TVectorD TotemRPLocalTrack::parameterVector() const {
  TVectorD v(dimension);

  for (int i = 0; i < dimension; ++i)
    v[i] = track_params_vector_[i];

  return v;
}

//----------------------------------------------------------------------------------------------------

void TotemRPLocalTrack::setParameterVector(const TVectorD &track_params_vector) {
  for (int i = 0; i < dimension; ++i)
    track_params_vector_[i] = track_params_vector[i];
}

//----------------------------------------------------------------------------------------------------

TMatrixD TotemRPLocalTrack::covarianceMatrix() const {
  TMatrixD m(dimension, dimension);

  for (int i = 0; i < dimension; ++i)
    for (int j = 0; j < dimension; ++j)
      m(i, j) = CovarianceMatrixElement(i, j);

  return m;
}

//----------------------------------------------------------------------------------------------------

void TotemRPLocalTrack::setCovarianceMatrix(const TMatrixD &par_covariance_matrix) {
  for (int i = 0; i < dimension; ++i)
    for (int j = 0; j < dimension; ++j)
      CovarianceMatrixElement(i, j) = par_covariance_matrix(i, j);
}

//----------------------------------------------------------------------------------------------------

bool operator<(const TotemRPLocalTrack &l, const TotemRPLocalTrack &r) {
  if (l.z0_ < r.z0_)
    return true;
  if (l.z0_ > r.z0_)
    return true;

  for (int i = 0; i < TotemRPLocalTrack::dimension; ++i) {
    if (l.track_params_vector_[i] < r.track_params_vector_[i])
      return true;
    if (l.track_params_vector_[i] > r.track_params_vector_[i])
      return true;
  }

  return false;
}