59 G4Track* aTrack = aStep->GetTrack();
60 G4ParticleDefinition* particle = aTrack->GetDefinition();
64 if (particle == G4OpticalPhoton::OpticalPhotonDefinition()) {
65 auto* info =
dynamic_cast<Simulation::TrackInfo*
>(aTrack->GetUserInformation());
66 if (!info)
return false;
67 if (info->getStatus() < 2) {
70 double fraction = info->getFraction();
71 if (qeffi == 0 or gRandom->Uniform() * fraction > qeffi) {
72 aTrack->SetTrackStatus(fStopAndKill);
76 info->setFraction(qeffi);
83 G4StepPoint* PrePosition = aStep->GetPreStepPoint();
84 if (PrePosition->GetStepStatus() != fGeomBoundary)
return false;
90 int moduleID = PrePosition->GetTouchableHandle()->GetReplicaNumber(
m_replicaDepth);
92 if (!geo->isModuleIDValid(moduleID)) {
93 B2ERROR(
"TOP::SensitiveBar: undefined module ID."
94 <<
LogVar(
"moduleID", moduleID));
98 int trackID = aTrack->GetTrackID();
99 if (trackID ==
m_trackIDs[moduleID - 1])
return false;
105 G4ThreeVector worldPosition = PrePosition->GetPosition();
106 double tracklength = aTrack->GetTrackLength() - aStep->GetStepLength();
107 double globalTime = PrePosition->GetGlobalTime();
108 G4ThreeVector momentum = PrePosition->GetMomentum();
110 ROOT::Math::XYZPoint TPosition(worldPosition.x(), worldPosition.y(), worldPosition.z());
111 ROOT::Math::XYZVector TMomentum(momentum.x(), momentum.y(), momentum.z());
112 ROOT::Math::XYZPoint TOrigin(aTrack->GetVertexPosition().x(),
113 aTrack->GetVertexPosition().y(),
114 aTrack->GetVertexPosition().z());
120 tracklength = tracklength *
Unit::mm;
122 const auto& module = geo->getModule(moduleID);
123 auto locPosition = module.pointToLocal(TPosition);
124 auto locMomentum = module.momentumToLocal(TMomentum);
125 double theta = locMomentum.Theta();
126 double phi = locMomentum.Phi();
128 int PDG = (int)(particle->GetPDGEncoding());
131 auto* hit =
m_barHits.appendNew(moduleID, PDG, TOrigin, TPosition, TMomentum,
132 globalTime, tracklength, locPosition,
void add(index_type from, index_type to, weight_type weight=1.0)
Add a new element to the relation.
std::vector< int > m_trackIDs
track ID's
RelationArray m_relParticleHit
relations
TOPGeometryPar * m_topgp
geometry parameters
StoreArray< TOPBarHit > m_barHits
collection of entrance-to-bar hits
double getPMTEfficiencyEnvelope(double energy) const
Returns PMT efficiency envelope, e.g.
const TOPGeometry * getGeometry() const
Returns pointer to geometry object using basf2 units.
static const double mm
[millimeters]
static const double eV
[electronvolt]
static const double MeV
[megaelectronvolt]
Class to store variables with their name which were sent to the logging service.