103 lines
4.2 KiB
C++
103 lines
4.2 KiB
C++
//
|
|
// ********************************************************************
|
|
// * License and Disclaimer *
|
|
// * *
|
|
// * The Geant4 software is copyright of the Copyright Holders of *
|
|
// * the Geant4 Collaboration. It is provided under the terms and *
|
|
// * conditions of the Geant4 Software License, included in the file *
|
|
// * LICENSE and available at http://cern.ch/geant4/license . These *
|
|
// * include a list of copyright holders. *
|
|
// * *
|
|
// * Neither the authors of this software system, nor their employing *
|
|
// * institutes,nor the agencies providing financial support for this *
|
|
// * work make any representation or warranty, express or implied, *
|
|
// * regarding this software system or assume any liability for its *
|
|
// * use. Please see the license in the file LICENSE and URL above *
|
|
// * for the full disclaimer and the limitation of liability. *
|
|
// * *
|
|
// * This code implementation is the result of the scientific and *
|
|
// * technical work of the GEANT4 collaboration. *
|
|
// * By using, copying, modifying or distributing the software (or *
|
|
// * any work based on the software) you agree to acknowledge its *
|
|
// * use in resulting scientific publications, and indicate your *
|
|
// * acceptance of all terms of the Geant4 Software license. *
|
|
// ********************************************************************
|
|
//
|
|
// $Id: LXeUserEventInformation.hh 68752 2013-04-05 10:23:47Z gcosmo $
|
|
//
|
|
/// \file optical/LXe/include/LXeUserEventInformation.hh
|
|
/// \brief Definition of the LXeUserEventInformation class
|
|
//
|
|
#include "G4VUserEventInformation.hh"
|
|
#include "G4ThreeVector.hh"
|
|
#include "globals.hh"
|
|
|
|
#ifndef LXeUserEventInformation_h
|
|
#define LXeUserEventInformation_h 1
|
|
|
|
class LXeUserEventInformation : public G4VUserEventInformation
|
|
{
|
|
public:
|
|
|
|
LXeUserEventInformation();
|
|
virtual ~LXeUserEventInformation();
|
|
|
|
inline virtual void Print()const{};
|
|
|
|
void IncPhotonCount_Scint(){fPhotonCount_Scint++;}
|
|
void IncPhotonCount_Ceren(){fPhotonCount_Ceren++;}
|
|
void IncEDep(G4double dep){fTotE+=dep;}
|
|
void IncAbsorption(){fAbsorptionCount++;}
|
|
void IncBoundaryAbsorption(){fBoundaryAbsorptionCount++;}
|
|
void IncHitCount(G4int i=1){fHitCount+=i;}
|
|
|
|
void SetEWeightPos(const G4ThreeVector& p){fEWeightPos=p;}
|
|
void SetReconPos(const G4ThreeVector& p){fReconPos=p;}
|
|
void SetConvPos(const G4ThreeVector& p){fConvPos=p;fConvPosSet=true;}
|
|
void SetPosMax(const G4ThreeVector& p,G4double edep){fPosMax=p;fEdepMax=edep;}
|
|
|
|
G4int GetPhotonCount_Scint()const {return fPhotonCount_Scint;}
|
|
G4int GetPhotonCount_Ceren()const {return fPhotonCount_Ceren;}
|
|
G4int GetHitCount()const {return fHitCount;}
|
|
G4double GetEDep()const {return fTotE;}
|
|
G4int GetAbsorptionCount()const {return fAbsorptionCount;}
|
|
G4int GetBoundaryAbsorptionCount() const {return fBoundaryAbsorptionCount;}
|
|
|
|
G4ThreeVector GetEWeightPos(){return fEWeightPos;}
|
|
G4ThreeVector GetReconPos(){return fReconPos;}
|
|
G4ThreeVector GetConvPos(){return fConvPos;}
|
|
G4ThreeVector GetPosMax(){return fPosMax;}
|
|
G4double GetEDepMax(){return fEdepMax;}
|
|
G4double IsConvPosSet(){return fConvPosSet;}
|
|
|
|
//Gets the total photon count produced
|
|
G4int GetPhotonCount(){return fPhotonCount_Scint+fPhotonCount_Ceren;}
|
|
|
|
void IncPMTSAboveThreshold(){fPMTsAboveThreshold++;}
|
|
G4int GetPMTSAboveThreshold(){return fPMTsAboveThreshold;}
|
|
|
|
private:
|
|
|
|
G4int fHitCount;
|
|
G4int fPhotonCount_Scint;
|
|
G4int fPhotonCount_Ceren;
|
|
G4int fAbsorptionCount;
|
|
G4int fBoundaryAbsorptionCount;
|
|
|
|
G4double fTotE;
|
|
|
|
//These only have meaning if totE > 0
|
|
//If totE = 0 then these wont be set by EndOfEventAction
|
|
G4ThreeVector fEWeightPos;
|
|
G4ThreeVector fReconPos; //Also relies on hitCount>0
|
|
G4ThreeVector fConvPos;//true (initial) converstion position
|
|
G4bool fConvPosSet;
|
|
G4ThreeVector fPosMax;
|
|
G4double fEdepMax;
|
|
|
|
G4int fPMTsAboveThreshold;
|
|
|
|
};
|
|
|
|
#endif
|