Belle II Software  release-08-01-10
SensitiveDetector< SimHitClass, TrueHitClass > Class Template Reference

Sensitive Detector implementation of PXD and SVD. More...

#include <SensitiveDetector.h>

Inheritance diagram for SensitiveDetector< SimHitClass, TrueHitClass >:
Collaboration diagram for SensitiveDetector< SimHitClass, TrueHitClass >:

Public Member Functions

 SensitiveDetector (VXD::SensorInfoBase *sensorInfo)
 Construct instance and take over ownership of the sensorInfo pointer.
 
void setOptions (bool seeNeutrons, bool onlyPrimaryTrueHits, float distanceTolerance, float electronTolerance, float minimumElectrons)
 Set all common options. More...
 
SensorInfoBasegetSensorInfo ()
 Return a pointer to the SensorInfo associated with this instance.
 
VxdID getSensorID () const
 Return the VxdID belonging to this sensitive detector.
 

Static Public Member Functions

static const std::map< std::string, RelationArray::EConsolidationAction > & getMCParticleRelations ()
 Return a list of all registered Relations with MCParticles.
 
static void setActive (bool activeStatus)
 Enable/Disable all Sensitive Detectors. More...
 
static void registerMCParticleRelation (const std::string &name, RelationArray::EConsolidationAction ignoreAction=RelationArray::c_negativeWeight)
 Register an relation involving MCParticles. More...
 
static void registerMCParticleRelation (const RelationArray &relation, RelationArray::EConsolidationAction ignoreAction=RelationArray::c_negativeWeight)
 Overload to make it easer to register MCParticle relations. More...
 

Protected Member Functions

std::vector< unsigned int > simplifyEnergyDeposit (const SensorTraversal::range &points)
 Simplify the energy deposition profile using Douglas-Peuker-Algorithm We normally force a Geant4 step after 5µm but energy deposition does not necessarily vary much between these short steps. More...
 
StepInformation findMidPoint (const SensorTraversal &traversal)
 Find the mid-point of the track traversal. More...
 

Private Member Functions

int saveTrueHit (const SensorTraversal &traversal) override
 Save the actual TrueHit for a given sensor traversal information. More...
 
int saveSimHit (const SensorTraversal &traversal, const SensorTraversal::range &points) override
 Save a SimHit for a track along the given points. More...
 
void saveRelations (const SensorTraversal &traversal, int trueHitIndex, std::vector< std::pair< unsigned int, float >> simHitIndices) override
 Save the relations between MCParticle, TrueHit and SimHits. More...
 
std::array< float, 3 > vecToFloat (const G4ThreeVector &vec)
 Convert G4ThreeVector (aka Hep3Vector) to float array to store in TrueHit/SimHit classes. More...
 
bool step (G4Step *step, G4TouchableHistory *) override
 Process a single Geant4 Step. More...
 
bool finishTrack ()
 Process a track once all steps are known. More...
 
std::vector< std::pair< unsigned int, float > > createSimHits ()
 Determine which SimHits to create. More...
 
virtual bool ProcessHits (G4Step *aStep, G4TouchableHistory *aROhist)
 Check if recording hits is enabled and if so call step() and set the correct MCParticle flag. More...
 

Private Attributes

StoreArray< SimHitClass > m_simhits
 StoreArray for the SimHits.
 
StoreArray< TrueHitClass > m_truehits
 StoreArray for the TrueHits.
 
StoreArray< MCParticlem_mcparticles
 StoreArray for the MCParticles, needed by relations.
 
RelationArray m_relMCSimHits {m_mcparticles, m_simhits}
 Relation between MCParticle and SimHits.
 
RelationArray m_relMCTrueHits {m_mcparticles, m_truehits}
 Relation between MCParticle and TrueHits.
 
RelationArray m_relTrueSimHits {m_truehits, m_simhits}
 Relation between TrueHits and SimHits.
 
SensorInfoBasem_info {0}
 Pointer to the SensorInfo associated with this instance.
 
std::stack< SensorTraversalm_tracks
 stack of SensorTraversal information for all tracks not finished so far
 
float m_distanceTolerance {0}
 maximum distance between step point and linear interpolation of sensor traversal before a new simhit object is created
 
float m_electronTolerance {0}
 maximum relative difference between electron density of two steps where they can be considered similar enough to be merged
 
float m_minimumElectrons {0}
 minimum number of electrons a track must deposit for SimHit/TrueHits to be created
 
bool m_seeNeutrons {false}
 also create SimHit/TrueHit objects for neutrons (or charged particles which deposit less than m_minimumElectrons electrons
 
bool m_onlyPrimaryTrueHits {false}
 only create TrueHits for primary particles
 
Const::EDetector m_subdetector
 Subdetector the class belongs to.
 

Static Private Attributes

static std::map< std::string, RelationArray::EConsolidationActions_mcRelations
 Static set holding all relations which have to be updated at the end of the Event.
 
static bool s_active
 Static bool which indicates wether recording of hits is enabled.
 

Detailed Description

template<class SimHitClass, class TrueHitClass>
class Belle2::VXD::SensitiveDetector< SimHitClass, TrueHitClass >

Sensitive Detector implementation of PXD and SVD.

This class provides the actual implementation of the hit generation for PXD and SVD. It is templated to be able to create the corresponding output collection.

It generates two different kinds of Hits:

  • SimHits which correspond to Geant4 steps inside the sensitive volume. There will be several SimHits per traversal, since the step length of Geant4 is limited to provide detailed information about energy deposition.
  • TrueHits are aggregated objects which store the position where a particle crossed the detector plane (local z=0). There can be only one TrueHit per traversal of one sensor, but there may be more than one TrueHit for curling Tracks. TrueHits also carry information about the particle momenta before and after entering the silicon (or at start/end point if the track started/ended inside the silicon. MODIFIED July 2013 (based largely on suggestions by Martin Ritter):
    1. Every particle that either enters or leaves the sensitive volume and deposits some energy there, will create a TrueHit.
    2. The (u,v,w) position of the TrueHit are the coordinates of the midpoint of the track inside the sensitive volume (rather of the x-ing point with z=0): the w (z) coordinate is added to TrueHits.
    3. Each MC particle entering the sensitive volume will be un-ignored, so that the TrueHits created by secondaries entering the sensitive volume will be attributed to the correct MCParticle (that is, not to its primary ancestor).
    4. SimHit relations to MCParticles that don't produce a TrueHit and get re-attributed (to their primary ancestor) will have negative sign. This concerns the secondaries created inside the sensitive volume that don't reach another sensitive volume.
Template Parameters
SimHitClassClass to use when generating SimHits
TrueHitClassClass to use when generating TrueHits

Definition at line 64 of file SensitiveDetector.h.

Member Function Documentation

◆ createSimHits()

std::vector< std::pair< unsigned int, float > > createSimHits ( )
privateinherited

Determine which SimHits to create.

A SimHit is a linear approximation of the particle trajectory. As such we try to combine as many Geant4 steps as possible by defining a distance tolerance and using the Douglas-Peucker algortihm to determine the required number of SimHits to keep the maximum distance of all Geant4 steps below that tolerance.

Returns
indices and electrons of all created simhits

Definition at line 126 of file SensitiveDetectorBase.cc.

127  {
128  SensorTraversal& traversal = m_tracks.top();
129  //List of created simhit indices to be able to create relations
130  std::vector<std::pair<unsigned int, float>> simhits;
131 
132  //We need to check how close the steps would be to a linear approximation
133  //of the traversal and split the track if they are too far away. To do
134  //this we check the whole track and split it at the point with the
135  //largest distance recursively until the largest distance is inside the
136  //tolerance. For that we need a stack of segments and check each segment
137  //in turn until they fulfill the criteria.
138  static std::stack<SensorTraversal::range> stack;
139  //Lets push the full segment, first step point to last step point, on the
140  //stack. We use inclusive range, so the second iterator is still included
141  stack.push(make_pair(traversal.begin(), traversal.end() - 1));
142  //Iterators needed for checking
143  SensorTraversal::iterator firstPoint, finalPoint, splitPoint;
144 
145  //Check all segments ...
146  while (!stack.empty()) {
147  //Get first and last point
148  std::tie(firstPoint, finalPoint) = stack.top();
149  //Remove segment from stack
150  stack.pop();
151  //Direction of the segment
152  const G4ThreeVector n = (finalPoint->position - firstPoint->position).unit();
153  //find largest distance to segment by looping over all intermediate points
154  double maxDistance(0);
155  for (auto nextPoint = firstPoint + 1; nextPoint != finalPoint; ++nextPoint) {
156  //Calculate distances between point p and line segment,
157  //x = a + t*n, where a is a point on the line and n is the unit vector
158  //pointing in line direction. distance = ||(p-a) - ((p-a)*n)*n||
159  const G4ThreeVector pa = nextPoint->position - firstPoint->position;
160  const double dist = (pa - (pa * n) * n).mag();
161  //Update splitpoint if distance is larger then previously known
162  if (dist > maxDistance) {
163  splitPoint = nextPoint;
164  maxDistance = dist;
165  }
166  }
167  //If we are above the tolerance we split the track
168  if (maxDistance > m_distanceTolerance) {
169  //If we split in this order, all created simhits will be in correct
170  //order. That is not a requirement but a nice side effect.
171  stack.push(make_pair(splitPoint, finalPoint));
172  stack.push(make_pair(firstPoint, splitPoint));
173  continue;
174  }
175  //Otherwise we create a SimHit
176  //FIXME: check for m_minimumElectrons?
177  int simHitIndex = saveSimHit(traversal, std::make_pair(firstPoint, finalPoint));
178  simhits.push_back(std::make_pair(simHitIndex, finalPoint->electrons - firstPoint->electrons));
179  }
180  return simhits;
181  }
float m_distanceTolerance
maximum distance between step point and linear interpolation of sensor traversal before a new simhit ...
virtual int saveSimHit(const SensorTraversal &traversal, const SensorTraversal::range &points)=0
Save a SimHit for this track including the given points.
std::stack< SensorTraversal > m_tracks
stack of SensorTraversal information for all tracks not finished so far

◆ findMidPoint()

StepInformation findMidPoint ( const SensorTraversal traversal)
protectedinherited

Find the mid-point of the track traversal.

This function will return the position and momentum at the center of the track traversal, using cubic spline interpolation between the actual geant4 steps. Center is defined as "half the flight length" in this case.

Parameters
traversalinformation on the particle traversal to be used when finding the midpoint
Returns
position and momentum at the mid point

Definition at line 274 of file SensitiveDetectorBase.cc.

◆ finishTrack()

bool finishTrack ( )
privateinherited

Process a track once all steps are known.

This function decides whether TrueHit/SimHits will be saved

Definition at line 94 of file SensitiveDetectorBase.cc.

◆ ProcessHits()

bool ProcessHits ( G4Step *  aStep,
G4TouchableHistory *  aROhist 
)
inlineprivatevirtualinherited

Check if recording hits is enabled and if so call step() and set the correct MCParticle flag.

Called by Geant4 for each step inside the sensitive volumes attached

Definition at line 94 of file SensitiveDetectorBase.h.

◆ registerMCParticleRelation() [1/2]

static void registerMCParticleRelation ( const RelationArray relation,
RelationArray::EConsolidationAction  ignoreAction = RelationArray::c_negativeWeight 
)
inlinestaticinherited

Overload to make it easer to register MCParticle relations.

Parameters
relationRelationArray to register
ignoreAction

Definition at line 66 of file SensitiveDetectorBase.h.

◆ registerMCParticleRelation() [2/2]

void registerMCParticleRelation ( const std::string &  name,
RelationArray::EConsolidationAction  ignoreAction = RelationArray::c_negativeWeight 
)
staticinherited

Register an relation involving MCParticles.

All Relations which point from an MCParticle to something have to be registered with addMCParticleRelation() because the index of the MCParticles might change at the end of the event. During simulation, the TrackID should be used as index of the MCParticle

Parameters
nameName of the relation to register
ignoreAction

Definition at line 22 of file SensitiveDetectorBase.cc.

◆ saveRelations()

void saveRelations ( const SensorTraversal traversal,
int  trueHitIndex,
std::vector< std::pair< unsigned int, float >>  simHitIndices 
)
overrideprivatevirtual

Save the relations between MCParticle, TrueHit and SimHits.

Parameters
traversalinformation on the particle traversal to be used when creating the Relations
trueHitIndexindex of the TrueHit, <0 if no TrueHit was created
simHitIndicesindices of the SimHits along with the number of electrons deposited in each SimHit

Implements SensitiveDetectorBase.

Definition at line 185 of file SensitiveDetector.h.

187  {
188  m_relMCSimHits.add(traversal.getTrackID(), simHitIndices.begin(), simHitIndices.end());
189  //If there is no truehit there are obviously no relations ;)
190  if (trueHitIndex >= 0) {
191  m_relMCTrueHits.add(traversal.getTrackID(), trueHitIndex, traversal.getElectrons());
192  m_relTrueSimHits.add(trueHitIndex, simHitIndices.begin(), simHitIndices.end());
193  }
194  }
void add(index_type from, index_type to, weight_type weight=1.0)
Add a new element to the relation.
RelationArray m_relMCTrueHits
Relation between MCParticle and TrueHits.
RelationArray m_relMCSimHits
Relation between MCParticle and SimHits.
RelationArray m_relTrueSimHits
Relation between TrueHits and SimHits.

◆ saveSimHit()

int saveSimHit ( const SensorTraversal traversal,
const SensorTraversal::range points 
)
overrideprivatevirtual

Save a SimHit for a track along the given points.

Parameters
traversalinformation on the particle traversal to be used when creating the SimHit
pointspair of iterators to the first and last step position to be used for the SimHit
Returns
the index of the created SimHit in its StoreArray

Implements SensitiveDetectorBase.

Definition at line 163 of file SensitiveDetector.h.

◆ saveTrueHit()

int saveTrueHit ( const SensorTraversal traversal)
overrideprivatevirtual

Save the actual TrueHit for a given sensor traversal information.

Parameters
traversalinformation on the particle traversal to be used when creating the TrueHit
Returns
the index of the created TrueHit in its StoreArray

Implements SensitiveDetectorBase.

Definition at line 137 of file SensitiveDetector.h.

◆ setActive()

static void setActive ( bool  activeStatus)
inlinestaticinherited

Enable/Disable all Sensitive Detectors.

By default, all sensitive detectors won't create hits to make it possible to use the Geant4 Navigator for non-simulation purposes. Only during simulation the sensitive detectors will be enabled to record hits

Parameters
activeStatusbool to indicate wether hits should be recorded

Definition at line 50 of file SensitiveDetectorBase.h.

◆ setOptions()

void setOptions ( bool  seeNeutrons,
bool  onlyPrimaryTrueHits,
float  distanceTolerance,
float  electronTolerance,
float  minimumElectrons 
)
inlineinherited

Set all common options.

Parameters
seeNeutronsif true, simhits are also stored for neutrons
onlyPrimaryTrueHitsif true, truehits will only be created for primary particles
distanceTolerancemaximal distance of step position from linear approximation.
electronTolerancemaximum deviation of energy deposition from linear approximation in electrons
minimumElectronsminimum number of electrons to be deposited before SimHits are created.

Definition at line 60 of file SensitiveDetectorBase.h.

62  {
63  m_seeNeutrons = seeNeutrons;
64  m_onlyPrimaryTrueHits = onlyPrimaryTrueHits;
65  m_distanceTolerance = distanceTolerance;
66  m_electronTolerance = electronTolerance;
67  m_minimumElectrons = minimumElectrons;
68  }
float m_minimumElectrons
minimum number of electrons a track must deposit for SimHit/TrueHits to be created
bool m_onlyPrimaryTrueHits
only create TrueHits for primary particles
float m_electronTolerance
maximum relative difference between electron density of two steps where they can be considered simila...
bool m_seeNeutrons
also create SimHit/TrueHit objects for neutrons (or charged particles which deposit less than m_minim...

◆ simplifyEnergyDeposit()

std::vector< unsigned int > simplifyEnergyDeposit ( const SensorTraversal::range points)
protectedinherited

Simplify the energy deposition profile using Douglas-Peuker-Algorithm We normally force a Geant4 step after 5µm but energy deposition does not necessarily vary much between these short steps.

Saving all steps would be a waste of space so we define a tolerance (in electrons) and keep only the points needed so that no point is further away from the profile than this tolerance.

Parameters
pointspair of iterators to the first and last point of the energy deposition profile
Returns
list of encoded EnergyDeposit values representing the simplified energy deposition profile.

Definition at line 183 of file SensitiveDetectorBase.cc.

◆ step()

bool step ( G4Step *  step,
G4TouchableHistory *   
)
overrideprivatevirtualinherited

Process a single Geant4 Step.

This function stores the necessary information to create the TrueHits and SimHits and will call finishTrack() if a track leaves the volume or is stopped inside the volume.

Implements SensitiveDetectorBase.

Definition at line 28 of file SensitiveDetectorBase.cc.

◆ vecToFloat()

std::array<float, 3> vecToFloat ( const G4ThreeVector &  vec)
inlineprivate

Convert G4ThreeVector (aka Hep3Vector) to float array to store in TrueHit/SimHit classes.

Parameters
vecvector to convert
Returns
array containing x,y,z as floats

Definition at line 102 of file SensitiveDetector.h.


The documentation for this class was generated from the following file: