/* 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 . * */ /** @class MAUS::DataStructure::Global::SpacePoint * @ingroup globalrecon * @brief A reconstructed point in 4D space, matching a detector measurement. * @author Ian Taylor, University of Warwick * @date 2013/03/01 * * The measurement of a single detector element, represented as a 4D * point in space, with an associated set of errors. */ #ifndef _SRC_COMMON_CPP_DATASTRUCTURE_GLOBALSPACEPOINT_HH_ #define _SRC_COMMON_CPP_DATASTRUCTURE_GLOBALSPACEPOINT_HH_ // C++ headers #include #include // ROOT headers #include "Rtypes.h" // MAUS headers #include "src/common_cpp/Utils/VersionNumber.hh" #include "src/common_cpp/DataStructure/Global/ReconEnums.hh" #include "src/common_cpp/DataStructure/Global/BasePoint.hh" namespace MAUS { namespace DataStructure { namespace Global { // Only elements in the DataStructure should inherit from TObject. class SpacePoint : public BasePoint { public: /// Default constructor - initialises to 0/NULL SpacePoint(); /// Copy constructor - any pointers are deep copied SpacePoint(const SpacePoint &space_point); /// Destructor virtual ~SpacePoint(); /// Assignment operator - any pointers are deep copied SpacePoint& operator=(const SpacePoint &space_point); /// Clone method. This allows us to create a new object and change /// that object, without changing the original. This should be the /// standard copy method within a mapper. SpacePoint* Clone() const; // Getters and Setters for the member variables /// Set the calibrated 'charge' or energy deposit of the matching /// detector measurement. void set_charge(double charge); /// Get the calibrated 'charge' or energy deposit of the matching /// detector measurement. double get_charge() const; private: /// The calibrated 'charge' or energy deposit of the detector /// measurement. double _charge; MAUS_VERSIONED_CLASS_DEF(SpacePoint); }; // ~class SpacePoint } // ~namespace Global } // ~namespace DataStructure } // ~namespace MAUS #endif