2022-10-13 14:32:30 -04:00
|
|
|
|
|
|
|
#ifndef CloverEventAction_h
|
|
|
|
#define CloverEventAction_h 1
|
|
|
|
|
|
|
|
#include "G4UserEventAction.hh"
|
2024-02-15 11:18:34 -05:00
|
|
|
#include "G4AnalysisManager.hh"
|
|
|
|
#include "globals.hh"
|
2022-10-13 14:32:30 -04:00
|
|
|
|
|
|
|
#include "CloverCrystalHit.hh"
|
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
/// Event action class
|
|
|
|
///
|
|
|
|
/// In EndOfEventAction(), it prints the accumulated quantities of the energy
|
|
|
|
/// deposit and track lengths of charged particles in Crystal
|
|
|
|
/// stored in the hits collections.
|
|
|
|
|
|
|
|
class CloverEventAction : public G4UserEventAction
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
CloverEventAction();
|
|
|
|
virtual ~CloverEventAction();
|
|
|
|
|
|
|
|
virtual void BeginOfEventAction(const G4Event* event);
|
|
|
|
virtual void EndOfEventAction(const G4Event* event);
|
|
|
|
|
|
|
|
std::vector<G4double>& GetdEList() {return fdEList;};
|
|
|
|
std::vector<G4double>& GetStepLengthList() {return fdLList;};
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
// methods
|
|
|
|
CloverCrystalHitsCollection* GetHitsCollection(G4int hcID, const G4Event* event) const;
|
|
|
|
void PrintEventStatistics(G4double absoEdep, G4double absoTrackLength) const;
|
|
|
|
|
|
|
|
// data members
|
|
|
|
G4int fCrystalHCID; // Hit collection ID
|
|
|
|
|
|
|
|
G4int fNDet;
|
|
|
|
|
|
|
|
std::vector<G4double> fdEList; // dE of each crystal
|
|
|
|
std::vector<G4double> fdLList; // step length of each crystal
|
|
|
|
|
|
|
|
//std::vector<G4double> fLastPost; //last tracking position
|
|
|
|
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
//....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|