/* 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 .
*/
#ifndef _SRC_COMMON_CPP_DATASTRUCTURE_EMREVENT_
#define _SRC_COMMON_CPP_DATASTRUCTURE_EMREVENT_
#include
#include "Utils/VersionNumber.hh"
#include "DataStructure/EMRPlaneHit.hh"
namespace MAUS {
typedef std::vector EMRPlaneHitArray;
/** @class EMREvent comment
*
*/
class EMREvent {
public:
/** Default constructor - initialises to 0/NULL */
EMREvent();
/** Copy constructor - any pointers are deep copied */
EMREvent(const EMREvent& _emrevent);
/** Equality operator - any pointers are deep copied */
EMREvent& operator=(const EMREvent& _emrevent);
/** Destructor - any member pointers are deleted */
virtual ~EMREvent();
/** Returns */
EMRPlaneHitArray GetEMRPlaneHitArray() const;
/** Sets */
void SetEMRPlaneHitArray(EMRPlaneHitArray emrplanehitarray);
/** Returns */
bool GetInitialTrigger() const;
/** Sets */
void SetInitialTrigger(bool initial_trigger);
/** Returns */
bool GetHasPrimary() const;
/** Sets */
void SetHasPrimary(bool has_primary);
/** Returns */
double GetRangePrimary() const;
/** Sets */
void SetRangePrimary(double range_primary);
/** Returns */
bool GetHasSecondary() const;
/** Sets */
void SetHasSecondary(bool has_secondary);
/** Returns */
double GetRangeSecondary() const;
/** Sets */
void SetRangeSecondary(double range_secondary);
/** Returns */
double GetSecondaryToPrimaryTrackDistance() const;
/** Sets */
void SetSecondaryToPrimaryTrackDistance(double secondary_to_primary_track_distance);
/** Returns */
double GetTotalChargeMA() const;
/** Sets */
void SetTotalChargeMA(double total_charge_MA);
/** Returns */
double GetChargeRatioMA() const;
/** Sets */
void SetChargeRatioMA(double charge_MA_ratio);
/** Returns */
double GetTotalChargeSA() const;
/** Sets */
void SetTotalChargeSA(double total_charge_SA);
/** Returns */
double GetChargeRatioSA() const;
/** Sets */
void SetChargeRatioSA(double charge_SA_ratio);
private:
EMRPlaneHitArray _emrplanehitarray;
bool _initial_trigger;
bool _has_primary;
double _range_primary;
bool _has_secondary;
double _range_secondary;
double _secondary_to_primary_track_distance;
double _total_charge_MA;
double _charge_ratio_MA;
double _total_charge_SA;
double _charge_ratio_SA;
MAUS_VERSIONED_CLASS_DEF(EMREvent)
};
}
#endif // _SRC_COMMON_CPP_DATASTRUCTURE_EMREVENT_