/* 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_SCIFITRACKPOINT_HH_ #define _SRC_COMMON_CPP_DATASTRUCTURE_SCIFITRACKPOINT_HH_ // C headers #include #include #include // C++ headers #include #include #include "TMath.h" #include "TMatrixD.h" // ROOT headers #include "TObject.h" #include "TRef.h" #include "src/common_cpp/Utils/VersionNumber.hh" #include "src/common_cpp/DataStructure/SciFiCluster.hh" #include "src/common_cpp/DataStructure/ThreeVector.hh" namespace MAUS { class SciFiTrackPoint : public TObject { public: /** @brief Constructor. */ SciFiTrackPoint(); /** @brief Destructor. */ virtual ~SciFiTrackPoint(); /** @brief Copy constructor. */ SciFiTrackPoint(const SciFiTrackPoint &site); /** @brief Assignment operator. */ SciFiTrackPoint& operator=(const SciFiTrackPoint& site); /** @brief Sets spill number. */ void set_spill(int spill) { _spill = spill; } /** @brief Sets event number. */ void set_event(int event) { _event = event; } /** @brief Sets tracker number. */ void set_tracker(int tracker) { _tracker = tracker; } /** @brief Sets station number. */ void set_station(int station) { _station = station; } /** @brief Sets plane number. */ void set_plane(int plane) { _plane = plane; } /** @brief Sets channel number. */ void set_channel(double channel) { _channel = channel; } /** @brief Sets the filtered chi2 for this track point. */ void set_chi2(double chi2) { _chi2 = chi2; } /** @brief Sets the x coordinate. */ void set_pos(ThreeVector pos) { _pos = pos; } /** @brief Sets the x momentum component. */ void set_mom(ThreeVector mom) { _mom = mom; } /** @brief Sets the covariance matrix. */ void set_covariance(std::vector covariance) { _covariance = covariance; } /** @brief Sets the errors vector. */ void set_errors(std::vector errors) { _errors = errors; } /** @brief Sets pull (residual of the projected state). */ void set_pull(double pull) { _pull = pull; } /** @brief Sets residual for the filtered state. */ void set_residual(double residual) { _residual = residual; } /** @brief Sets residual for the smoothed state. */ void set_smoothed_residual(double s_residual) { _smoothed_residual = s_residual; } /** @brief Set the mother cluster using a TRef*. */ void set_cluster(TRef* const cluster) { _cluster = cluster; } /** @brief Set the mother cluster using a SciFiCluster*. */ void set_cluster_tobject(TObject* const cluster) { *_cluster = cluster; } /** @brief Set the mother cluster using a SciFiCluster*. */ void set_cluster_pointer(SciFiCluster* const cluster) { *_cluster = cluster; } /** @brief Returns the tracker number. */ int tracker() const { return _tracker; } /** @brief Returns the station number. */ int station() const { return _station; } /** @brief Returns the plane number. */ int plane() const { return _plane; } /** @brief Returns the channel number. */ double channel() const { return _channel; } /** @brief Returns filtered chi2 value. */ double chi2() const { return _chi2; } /** @brief Returns the x position. */ ThreeVector pos() const { return _pos; } /** @brief Returns the x momentum component. */ ThreeVector mom() const { return _mom; } /** @brief Returns the covariance matrix. */ std::vector covariance() const { return _covariance; } /** @brief Returns the covariance matrix. */ std::vector errors() const { return _errors; } /** @brief Returns the residual of the projected state. */ double pull() const { return _pull; } /** @brief Returns the residual of the filtered state. */ double residual() const { return _residual; } /** @brief Returns the residual of the smoothed state. */ double smoothed_residual() const { return _smoothed_residual; } /** @brief Returns the spill number. */ int spill() const { return _spill; } /** @brief Returns the event number. */ int event() const { return _event; } /** @brief Returns the mother clusters as a TRef*. */ TRef* get_cluster() const { return _cluster; } /** @brief Returns the mother cluster as a TObject pointer */ TObject* get_cluster_tobject() const { return _cluster->GetObject(); } /** @brief Returns the mother clusters as an array of pointers. */ SciFiCluster* get_cluster_pointer() const { return static_cast(_cluster->GetObject()); } private: /** @brief The number of the spill the trackpoint belongs to. */ int _spill; /** @brief The number of the event the trackpoint belongs to. */ int _event; /** @brief The tracker the trackpoint belongs to. */ int _tracker; /** @brief The station the trackpoint belongs to. */ int _station; /** @brief The plane the trackpoint belongs to. */ int _plane; /** @brief The channel measurement corresponding to the trackpoint. */ double _channel; /** @brief filtered chi2 */ double _chi2; /** @brief position */ ThreeVector _pos; /** @brief momentum */ ThreeVector _mom; /** @brief Covariance matrix for the state vector [x, px, y, py, pz] */ std::vector _covariance; /** @brief Errors vector for the state vector [x, px, y, py, pz] */ std::vector _errors; /** @brief projected residual */ double _pull; /** @brief filtered residual */ double _residual; /** @brief smoothed residual */ double _smoothed_residual; /** @brief A pointer to the cluster used to form the state - does not assume control of memory */ TRef* _cluster; MAUS_VERSIONED_CLASS_DEF(SciFiTrackPoint) }; typedef std::vector SciFiTrackPointPArray; } // ~namespace MAUS #endif