/* This file is part of MAUS: http://micewww.pp.rl.ac.uk:8080/projects/maus
*
* MAUS is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* MAUS is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with MAUS. If not, see .
*
*/
#include
// MAUS headers
#include "src/common_cpp/DataStructure/SciFiHelicalPRTrack.hh"
namespace MAUS {
// Constructors
SciFiHelicalPRTrack::SciFiHelicalPRTrack()
: SciFiBasePRTrack(),
_tracker(-1),
_num_points(-1),
_charge(0),
_R(-1.0),
_phi0(-1.0),
_dsdz(-1.0),
_line_sz_c(-1.0),
_line_sz_chisq(-1.0),
_circle_x0(-1.0),
_circle_y0(-1.0),
_circle_chisq(-1.0),
_chisq(-1.0),
_chisq_dof(-1.0),
_point_spread(-1.0),
_pos0(-1.0, -1.0, -1.0),
_phi(0) {
}
SciFiHelicalPRTrack::SciFiHelicalPRTrack(int tracker, int num_points, int charge, ThreeVector pos0,
double phi0, SimpleCircle circle, SimpleLine line_sz,
double chisq, double chisq_dof, double point_spread,
DoubleArray phi, SciFiSpacePointPArray spoints,
const DoubleArray& covariance) :
SciFiBasePRTrack(covariance, spoints),
_tracker(tracker),
_num_points(num_points),
_charge(charge),
_R(circle.get_R()),
_phi0(phi0),
_dsdz(line_sz.get_m()),
_line_sz_c(line_sz.get_c()),
_line_sz_chisq(line_sz.get_chisq()),
_circle_x0(circle.get_x0()),
_circle_y0(circle.get_y0()),
_circle_chisq(circle.get_chisq()),
_chisq(chisq),
_chisq_dof(chisq_dof),
_point_spread(point_spread),
_pos0(pos0),
_phi(phi) {
}
SciFiHelicalPRTrack::SciFiHelicalPRTrack(int tracker, int num_points, int charge, ThreeVector pos0,
double phi0, SimpleCircle circle, SimpleLine line_sz,
double point_spread, DoubleArray phi,
SciFiSpacePointPArray spoints,
const DoubleArray& covariance) :
SciFiBasePRTrack(covariance, spoints),
_tracker(tracker),
_num_points(num_points),
_charge(charge),
_R(circle.get_R()),
_phi0(phi0),
_dsdz(line_sz.get_m()),
_line_sz_c(line_sz.get_c()),
_line_sz_chisq(line_sz.get_chisq()),
_circle_x0(circle.get_x0()),
_circle_y0(circle.get_y0()),
_circle_chisq(circle.get_chisq()),
_chisq(0.0),
_chisq_dof(0.0),
_point_spread(point_spread),
_pos0(pos0),
_phi(phi) {
_chisq = std::sqrt(_circle_chisq*_circle_chisq + _line_sz_chisq*_line_sz_chisq);
_chisq_dof = _chisq / (_num_points - 2);
}
// Destructor
SciFiHelicalPRTrack::~SciFiHelicalPRTrack() {
// Do nothing
}
// Assignment operator
SciFiHelicalPRTrack &SciFiHelicalPRTrack::operator=(const SciFiHelicalPRTrack &htrk) {
if (this == &htrk) {
return *this;
}
SciFiBasePRTrack::operator=(htrk);
_R = htrk.get_R();
_phi0 = htrk.get_phi0();
_dsdz = htrk.get_dsdz();
_line_sz_c = htrk.get_line_sz_c();
_line_sz_chisq = htrk.get_line_sz_chisq();
_circle_chisq = htrk.get_circle_chisq();
_circle_x0 = htrk.get_circle_x0();
_circle_y0 = htrk.get_circle_y0();
_chisq = htrk.get_chisq();
_chisq_dof = htrk.get_chisq_dof();
_num_points = htrk.get_num_points();
_charge = htrk.get_charge();
_tracker = htrk.get_tracker();
_point_spread = htrk.get_point_spread();
_pos0 = htrk.get_pos0();
_phi = htrk.get_phi();
return *this;
}
SciFiHelicalPRTrack::SciFiHelicalPRTrack(const SciFiHelicalPRTrack &htrk)
: SciFiBasePRTrack(htrk),
_tracker(htrk.get_tracker()),
_num_points(htrk.get_num_points()),
_charge(htrk.get_charge()),
_R(htrk.get_R()),
_phi0(htrk.get_phi0()),
_dsdz(htrk.get_dsdz()),
_line_sz_c(htrk.get_line_sz_c()),
_line_sz_chisq(htrk.get_line_sz_chisq()),
_circle_x0(htrk.get_circle_x0()),
_circle_y0(htrk.get_circle_y0()),
_circle_chisq(htrk.get_circle_chisq()),
_chisq(htrk.get_chisq()),
_chisq_dof(htrk.get_chisq_dof()),
_point_spread(htrk.get_point_spread()),
_pos0(htrk.get_pos0()),
_phi(htrk.get_phi()) {
}
} // ~namespace MAUS