/* 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 . * */ #ifndef _SRC_COMMON_CPP_DATASTRUCTURE_SCIFITRACK_HH_ #define _SRC_COMMON_CPP_DATASTRUCTURE_SCIFITRACK_HH_ #include // C++ headers #include // MAUS headers #include "src/common_cpp/DataStructure/SciFiTrackPoint.hh" namespace MAUS { class SciFiTrack { public: /** @brief Constructor. */ SciFiTrack(); /** @brief Destructor, deletes the track points */ virtual ~SciFiTrack(); /** @brief Copy constructor, deeps copies the track points */ SciFiTrack(const SciFiTrack &a_track); /** @brief Assignment operator, deeps copies the track points */ SciFiTrack& operator=(const SciFiTrack &a_track); /** @brief Sets the tracker number. */ void set_tracker(int tracker) { _tracker = tracker; } /** @brief Sets the filtered chi2. */ void set_chi2(double chi2) { _chi2 = chi2; } /** @brief Sets the ndf for this track. */ void set_ndf(int ndf) { _ndf = ndf; } /** @brief Sets the P-value for the chi2 and ndf found. */ void set_P_value(double p_value) { _P_value = p_value; } /** @brief Sets the charge of the fitted particle. */ void set_charge(int charge) { _charge = charge; } /** @brief Sets trackpoints vector, shallow copy */ void set_scifitrackpoints(SciFiTrackPointPArray points) { _trackpoints = points; } /** @brief Returns the tracker number. */ int tracker() const { return _tracker; } /** @brief Returns the filtered chi2. */ double chi2() const { return _chi2; } /** @brief Returns the ndf. */ int ndf() const { return _ndf; } /** @brief Returns the P-value. */ double P_value() const { return _P_value; } /** @brief Returns the charge of the fitted particle. */ int charge() const { return _charge; } /** @brief Returns the array of SciFiTrackPoints which belong to this track. */ SciFiTrackPointPArray scifitrackpoints() const { return _trackpoints; } /** @brief Adds a SciFiTrackPoint to the member array. */ void add_scifitrackpoint(SciFiTrackPoint* trackpoint) { _trackpoints.push_back(trackpoint); } /** @brief Enumeration of the possible types of SciFi tracks. */ enum AlgorithmUsed { kalman_straight, kalman_helical }; /** @brief Returns the type of algorithm used to reconstruct this track. */ int GetAlgorithmUsed() const { return static_cast (_algorithm_used); } void SetAlgorithmUsed(int algorithm) { _algorithm_used = (AlgorithmUsed) algorithm; } private: int _tracker; double _chi2; int _ndf; double _P_value; int _charge; AlgorithmUsed _algorithm_used; SciFiTrackPointPArray _trackpoints; MAUS_VERSIONED_CLASS_DEF(SciFiTrack) }; typedef std::vector SciFiTrackPArray; } // ~namespace MAUS #endif