/* 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 .
*
*/
// C++ headers
#include
// ROOT headers
#include "TRefArray.h"
// MAUS headers
#include "src/common_cpp/DataStructure/SciFiStraightPRTrack.hh"
namespace MAUS {
// Constructors
SciFiStraightPRTrack::SciFiStraightPRTrack() : _tracker(-1), _num_points(-1),
_x0(-1.0), _mx(-1.0), _x_chisq(-1.0),
_y0(-1.0), _my(-1.0), _y_chisq(-1.0) {
// Do nothing
}
SciFiStraightPRTrack::SciFiStraightPRTrack(int tracker, int num_points,
double x0, double mx, double x_chisq,
double y0, double my, double y_chisq)
: _tracker(-1), _num_points(-1),
_x0(-1.0), _mx(-1.0), _x_chisq(-1.0),
_y0(-1.0), _my(-1.0), _y_chisq(-1.0) {
_tracker = tracker;
_num_points = num_points;
_x0 = x0;
_mx = mx;
_x_chisq = x_chisq;
_y0 = y0;
_my = my;
_y_chisq = y_chisq;
}
SciFiStraightPRTrack::SciFiStraightPRTrack(int tracker, int num_points,
SimpleLine line_x, SimpleLine line_y)
: _tracker(-1), _num_points(-1),
_x0(-1.0), _mx(-1.0), _x_chisq(-1.0),
_y0(-1.0), _my(-1.0), _y_chisq(-1.0) {
_x0 = line_x.get_c();
_mx = line_x.get_m();
_x_chisq = line_x.get_chisq();
_y0 = line_y.get_c();
_my = line_y.get_m();
_y_chisq = line_y.get_chisq();
_tracker = tracker;
_num_points = num_points;
}
SciFiStraightPRTrack::SciFiStraightPRTrack(const SciFiStraightPRTrack &strk)
: _tracker(strk.get_tracker()),
_num_points(strk.get_num_points()),
_x0(strk.get_x0()),
_mx(strk.get_mx()),
_x_chisq(strk.get_x_chisq()),
_y0(strk.get_y0()),
_my(strk.get_my()),
_y_chisq(strk.get_y_chisq()) {
_spoints = new TRefArray(*strk.get_spacepoints());
}
// Destructor
SciFiStraightPRTrack::~SciFiStraightPRTrack() {}
// Assignment operator
SciFiStraightPRTrack &SciFiStraightPRTrack::operator=(const SciFiStraightPRTrack &strk) {
if (this == &strk) {
return *this;
}
_tracker = strk.get_tracker();
_num_points = strk.get_num_points();
_x0 = strk.get_x0();
_mx = strk.get_mx();
_x_chisq = strk.get_x_chisq();
_y0 = strk.get_y0();
_my = strk.get_my();
_y_chisq = strk.get_y_chisq();
_spoints = new TRefArray(*(strk.get_spacepoints()));
return *this;
}
} // ~namespace MAUS