12 #include <Geant4/G4Step.hh>
19 detector_( detector ),
39 G4VPhysicalVolume* volume = aStep->GetPreStepPoint()->GetTouchableHandle()->GetVolume();
42 G4double edep = aStep->GetTotalEnergyDeposit() / GeV;
44 const G4Track* aTrack = aStep->GetTrack();
50 bool geantino =
false;
54 if (aTrack->GetParticleDefinition()->GetPDGEncoding() == 0 &&
55 aTrack->GetParticleDefinition()->GetParticleName().find(
"geantino") != string::npos)
59 G4StepPoint * prePoint = aStep->GetPreStepPoint();
60 G4StepPoint * postPoint = aStep->GetPostStepPoint();
64 switch (prePoint->GetStepStatus())
73 hit->
set_x( 0, prePoint->GetPosition().x() / cm);
74 hit->
set_y( 0, prePoint->GetPosition().y() / cm );
75 hit->
set_z( 0, prePoint->GetPosition().z() / cm );
77 hit->
set_t( 0, prePoint->GetGlobalTime() / nanosecond );
83 if ( G4VUserTrackInformation* p = aTrack->GetUserInformation() )
89 saveshower = pp->GetShower();
100 hit->
set_x( 1, postPoint->GetPosition().x() / cm );
101 hit->
set_y( 1, postPoint->GetPosition().y() / cm );
102 hit->
set_z( 1, postPoint->GetPosition().z() / cm );
104 hit->
set_t( 1, postPoint->GetGlobalTime() / nanosecond );
113 if ( G4VUserTrackInformation* p = aTrack->GetUserInformation() )
128 if (postPoint->GetStepStatus() == fGeomBoundary || postPoint->GetStepStatus() == fWorldBoundary|| aTrack->GetTrackStatus() == fStopAndKill)
133 hits_->
AddHit(layer_id, hit);
171 hitnodename =
"G4HIT_" + detector_->
GetName();
175 hits_ = findNode::getClass<PHG4HitContainer>( topNode , hitnodename.c_str() );
179 { std::cout <<
"PHG4ConeSteppingAction::SetTopNode - unable to find " << hitnodename << std::endl; }
bool IsInConeActive(G4VPhysicalVolume *)
void SuperDetector(const std::string &name)
virtual ~PHG4ConeSteppingAction()
destructor
virtual void SetInterfacePointers(PHCompositeNode *)
reimplemented from base class
PHG4ConeSteppingAction(PHG4ConeDetector *)
constructor
virtual bool UserSteppingAction(const G4Step *, bool)
stepping action
virtual std::string GetName() const
ConstIterator AddHit(PHG4Hit *newhit)
virtual void set_y(const int i, const float f)
virtual void set_shower_id(const int i)
virtual float get_edep() const
virtual void set_t(const int i, const float f)
virtual void Reset()
Clear Event.
virtual void set_z(const int i, const float f)
virtual void set_x(const int i, const float f)
virtual PHG4HitDefs::keytype get_hit_id() const
virtual void set_trkid(const int i)
virtual void set_edep(const float f)
virtual void add_g4hit_id(int volume, PHG4HitDefs::keytype id)