/* This file is part of MAUS: http://micewww.pp.rl.ac.uk/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 "src/common_cpp/DataStructure/SciFiTrack.hh"
namespace MAUS {
SciFiTrack::SciFiTrack(): _tracker(-1),
_chi2(-1),
_ndf(-1),
_P_value(-1),
_charge(0),
_trackpoints(0),
_seed_position(),
_seed_momentum(),
_seed_covariance_matrix(0) {
}
SciFiTrack::SciFiTrack(const SciFiTrack &a_track): _tracker(-1),
_chi2(-1),
_ndf(-1),
_P_value(-1),
_charge(0),
_trackpoints(0),
_seed_position(),
_seed_momentum(),
_seed_covariance_matrix(0) {
_tracker = a_track.tracker();
_chi2 = a_track.chi2();
_ndf = a_track.ndf();
_P_value = a_track.P_value();
_charge = a_track.charge();
_algorithm_used = a_track._algorithm_used;
_seed_position = a_track._seed_position;
_seed_momentum = a_track._seed_momentum;
_trackpoints.resize(a_track._trackpoints.size());
for (size_t i = 0; i < a_track._trackpoints.size(); ++i) {
_trackpoints[i] = new SciFiTrackPoint(*a_track._trackpoints[i]);
}
// _seed_state_vector.resize(a_track._seed_state_vector.size());
// for (size_t i = 0; i < a_track._seed_state_vector.size(); ++i) {
// _seed_state_vector[i] = a_track._seed_state_vector[i];
// }
_seed_covariance_matrix.resize(a_track._seed_covariance_matrix.size());
for (size_t i = 0; i < a_track._seed_covariance_matrix.size(); ++i) {
_seed_covariance_matrix[i] = a_track._seed_covariance_matrix[i];
}
}
SciFiTrack& SciFiTrack::operator=(const SciFiTrack &a_track) {
if (this == &a_track) {
return *this;
}
_tracker = a_track.tracker();
_chi2 = a_track.chi2();
_ndf = a_track.ndf();
_P_value = a_track.P_value();
_charge = a_track.charge();
_algorithm_used = a_track._algorithm_used;
_seed_position = a_track._seed_position;
_seed_momentum = a_track._seed_momentum;
_trackpoints.resize(a_track._trackpoints.size());
for (size_t i = 0; i < a_track._trackpoints.size(); ++i) {
_trackpoints[i] = new SciFiTrackPoint(*a_track._trackpoints[i]);
}
// _seed_state_vector.resize(a_track._seed_state_vector.size());
// for (size_t i = 0; i < a_track._seed_state_vector.size(); ++i) {
// _seed_state_vector[i] = a_track._seed_state_vector[i];
// }
_seed_covariance_matrix.resize(a_track._seed_covariance_matrix.size());
for (size_t i = 0; i < a_track._seed_covariance_matrix.size(); ++i) {
_seed_covariance_matrix[i] = a_track._seed_covariance_matrix[i];
}
return *this;
}
// void SciFiTrack::set_scifitrackpoints(SciFiTrackPointPArray points) {
// // Delete any existing track points.
// std::vector::iterator track_point;
// for (track_point = _trackpoints.begin();
// track_point!= _trackpoints.end(); ++track_point) {
// delete (*track_point);
// }
//
// // Make the deep copy.
// _trackpoints.resize(points.size());
// for (size_t i = 0; i < points.size(); ++i) {
// _trackpoints[i] = new SciFiTrackPoint(*points.at(i));
// }
// }
SciFiTrack::~SciFiTrack() {
// Delete track points in this track.
std::vector::iterator track_point;
for (track_point = _trackpoints.begin();
track_point!= _trackpoints.end(); ++track_point) {
delete (*track_point);
}
}
// void SciFiTrack::SetSeedState(double* state, unsigned int size) {
// _seed_state_vector.resize(size);
// for ( unsigned int i = 0; i < size; ++i ) {
// _seed_state_vector[i] = state[i];
// }
// }
void SciFiTrack::SetSeedCovariance(double* covariance, unsigned int size) {
_seed_covariance_matrix.resize(size);
for ( unsigned int i = 0; i < size; ++i ) {
_seed_covariance_matrix[i] = covariance[i];
}
}
} // ~namespace MAUS