ATLAS Offline Software
Classes | Public Types | Public Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
TRTProcessingOfStraw Class Reference

TRT Digitization: Processing of a TRT Straws. More...

#include <TRTProcessingOfStraw.h>

Inheritance diagram for TRTProcessingOfStraw:
Collaboration diagram for TRTProcessingOfStraw:

Classes

class  cluster
 Primary ionisation cluster. More...
 

Public Types

typedef TimedHitCollection< TRTUncompressedHit >::const_iterator hitCollConstIter
 

Public Member Functions

 TRTProcessingOfStraw (const TRTDigSettings *, const InDetDD::TRT_DetectorManager *, ITRT_PAITool *, ITRT_SimDriftTimeTool *, TRTElectronicsProcessing *ep, TRTNoise *noise, TRTDigCondBase *digcond, const HepPDT::ParticleDataTable *, const TRT_ID *, ITRT_PAITool *=NULL, ITRT_PAITool *=NULL, const ITRT_CalDbTool *=NULL)
 Constructor: Calls Initialize method. More...
 
 ~TRTProcessingOfStraw ()
 Destructor. More...
 
void ProcessStraw (MagField::AtlasFieldCache &fieldCache, hitCollConstIter i, hitCollConstIter e, TRTDigit &outdigit, bool &m_alreadyPrintedPDGcodeWarning, double m_cosmicEventPhase, int strawGasType, bool emulationArflag, bool emulationKrflag, CLHEP::HepRandomEngine *rndmEngine, CLHEP::HepRandomEngine *elecProcRndmEngine, CLHEP::HepRandomEngine *elecNoiseRndmEngine, CLHEP::HepRandomEngine *paiRndmEngine)
 Process this straw all the way from Geant4 hit to output digit. More...
 
bool msgLvl (const MSG::Level lvl) const
 Test the output level. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

Protected Attributes

const TRT_IDm_id_helper
 

Private Member Functions

 TRTProcessingOfStraw (const TRTProcessingOfStraw &)
 
TRTProcessingOfStrawoperator= (const TRTProcessingOfStraw &)
 
void Initialize (const ITRT_CalDbTool *)
 Initialize. More...
 
void addClustersFromStep (const double &scaledKineticEnergy, const double &particleCharge, const double &timeOfHit, const double &prex, const double &prey, const double &prez, const double &postx, const double &posty, const double &postz, std::vector< cluster > &clusterlist, int strawGasType, CLHEP::HepRandomEngine *rndmEngine, CLHEP::HepRandomEngine *paiRndmEngine)
 This is the main function for re-simulation of the ionisation in the active gas via the PAI model. More...
 
void ClustersToDeposits (MagField::AtlasFieldCache &fieldCache, const int &hitID, const std::vector< cluster > &clusters, std::vector< TRTElectronicsProcessing::Deposit > &deposits, Amg::Vector3D TRThitGlobalPos, double m_cosmicEventPhase, int strawGasType, CLHEP::HepRandomEngine *rndmEngine)
 Transform the ioniation clusters along the particle trajectory inside a straw to energy deposits (i.e. More...
 
double setClusterZ (double cluster_z_in, bool isLong, bool isShort, bool isEC) const
 
Amg::Vector3D getGlobalPosition (int hitID, const TimedHitPtr< TRTUncompressedHit > *theHit)
 
void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

const TRTDigSettingsm_settings
 
const InDetDD::TRT_DetectorManagerm_detmgr
 
ITRT_PAIToolm_pPAItoolXe
 
ITRT_PAIToolm_pPAItoolAr
 
ITRT_PAIToolm_pPAItoolKr
 
ITRT_SimDriftTimeToolm_pSimDriftTimeTool
 
bool m_timeCorrection = false
 Time to be corrected for flight and wire propagation delays false when beamType='cosmics'. More...
 
double m_signalPropagationSpeed = 0.0
 
double m_attenuationLength = 0.0
 
bool m_useAttenuation = false
 
bool m_useMagneticFieldMap = false
 
double m_maxCrossingTime = 0.0
 
double m_minCrossingTime = 0.0
 
double m_shiftOfZeroPoint = 0.0
 
double m_innerRadiusOfStraw = 0.0
 
double m_outerRadiusOfWire = 0.0
 
double m_solenoidFieldStrength = 0.0
 
TRTTimeCorrectionm_pTimeCorrection
 
TRTElectronicsProcessingm_pElectronicsProcessing
 
TRTNoisem_pNoise
 
TRTDigCondBasem_pDigConditions
 
const HepPDT::ParticleDataTable * m_pParticleTable
 
std::vector< clusterm_clusterlist
 
std::vector< TRTElectronicsProcessing::Depositm_depositList
 
std::vector< double > m_drifttimes
 
std::vector< double > m_expattenuation
 
unsigned int m_maxelectrons = 0U
 
bool m_alreadywarnedagainstpdg0
 
std::unique_ptr< CLHEP::RandBinomialFixedPm_randBinomialXe {}
 
std::unique_ptr< CLHEP::RandBinomialFixedPm_randBinomialKr {}
 
std::unique_ptr< CLHEP::RandBinomialFixedPm_randBinomialAr {}
 
std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

TRT Digitization: Processing of a TRT Straws.


The main controlling function in ProcessStraw(). See detailed description of this.

Definition at line 55 of file TRTProcessingOfStraw.h.

Member Typedef Documentation

◆ hitCollConstIter

Definition at line 74 of file TRTProcessingOfStraw.h.

Constructor & Destructor Documentation

◆ TRTProcessingOfStraw() [1/2]

TRTProcessingOfStraw::TRTProcessingOfStraw ( const TRTDigSettings digset,
const InDetDD::TRT_DetectorManager detmgr,
ITRT_PAITool paitoolXe,
ITRT_SimDriftTimeTool simdrifttool,
TRTElectronicsProcessing ep,
TRTNoise noise,
TRTDigCondBase digcond,
const HepPDT::ParticleDataTable *  pdt,
const TRT_ID trt_id,
ITRT_PAITool paitoolAr = NULL,
ITRT_PAITool paitoolKr = NULL,
const ITRT_CalDbTool calDbTool = NULL 
)

Constructor: Calls Initialize method.

Definition at line 47 of file TRTProcessingOfStraw.cxx.

60 : AthMessaging("TRTProcessingOfStraw"),
61  m_settings(digset),
62  m_detmgr(detmgr),
63  m_pPAItoolXe(paitoolXe),
64  m_pPAItoolAr(paitoolAr),
65  m_pPAItoolKr(paitoolKr),
66  m_pSimDriftTimeTool(simdrifttool),
67 // m_time_y_eq_zero(0.0),
68 // m_ComTime(NULL),
69  m_pTimeCorrection(nullptr),
71  m_pNoise(noise),
72  m_pDigConditions(digcond),
73  m_pParticleTable(pdt),
75  m_id_helper(trt_id)
76 
77 {
78  Initialize(calDbTool);
79 }

◆ ~TRTProcessingOfStraw()

TRTProcessingOfStraw::~TRTProcessingOfStraw ( )

Destructor.

Definition at line 82 of file TRTProcessingOfStraw.cxx.

83 {
84  delete m_pTimeCorrection;
85 }

◆ TRTProcessingOfStraw() [2/2]

TRTProcessingOfStraw::TRTProcessingOfStraw ( const TRTProcessingOfStraw )
private

Member Function Documentation

◆ addClustersFromStep()

void TRTProcessingOfStraw::addClustersFromStep ( const double &  scaledKineticEnergy,
const double &  particleCharge,
const double &  timeOfHit,
const double &  prex,
const double &  prey,
const double &  prez,
const double &  postx,
const double &  posty,
const double &  postz,
std::vector< cluster > &  clusterlist,
int  strawGasType,
CLHEP::HepRandomEngine *  rndmEngine,
CLHEP::HepRandomEngine *  paiRndmEngine 
)
private

This is the main function for re-simulation of the ionisation in the active gas via the PAI model.

From the given G4 step, ionisation clusters are distributed randomly (mean free path given by TRT_PAI_Process::GetMeanFreePath()) along path. Cluster energies are given by TRT_PAI_Process::GetEnergyTransfer().

Parameters
scaledKineticEnergyThe kinetic energy a proton would have had if it had the same Lorentz gamma factor as the particle in question.
particleChargeParticle charge
timeOfHitTime of hit
prexPreStepPoint x coordinate
preyPreStepPoint y coordinate
prezPreStepPoint z coordinate
postxPostStepPoint x coordinate
postyPostStepPoint y coordinate
postzPostStepPoint z coordinate
clusterlistList of ionisation clusters along step

Definition at line 203 of file TRTProcessingOfStraw.cxx.

210 {
211 
212  // Choose the appropriate ITRT_PAITool for this straw
213  ITRT_PAITool* activePAITool;
214  if (strawGasType==0) { activePAITool = m_pPAItoolXe; }
215  else if (strawGasType==1) { activePAITool = m_pPAItoolKr; }
216  else if (strawGasType==2) { activePAITool = m_pPAItoolAr; }
217  else { activePAITool = m_pPAItoolXe; } // should never happen
218 
219  //Differences and steplength:
220  const double deltaX(postx - prex);
221  const double deltaY(posty - prey);
222  const double deltaZ(postz - prez);
223  const double stepLength(sqrt(deltaX * deltaX + deltaY * deltaY + deltaZ * deltaZ));
224 
225  const double meanFreePath(activePAITool->GetMeanFreePath( scaledKineticEnergy, particleCharge*particleCharge ));
226 
227  //How many clusters did we actually create:
228  const unsigned int numberOfClusters(CLHEP::RandPoisson::shoot(rndmEngine,stepLength / meanFreePath));
229  //fixme: use RandPoissionQ?
230 
231  //Position each of those randomly along the step, and use PAI to get their energies:
232  for (unsigned int iclus(0); iclus<numberOfClusters; ++iclus)
233  {
234  //How far along the step did the cluster get produced:
235  const double lambda(CLHEP::RandFlat::shoot(rndmEngine));
236 
237  //Append cluster (the energy is given by the PAI model):
238  double clusE(activePAITool->GetEnergyTransfer(scaledKineticEnergy, paiRndmEngine));
239  clusterlist.emplace_back(clusE, timeOfHit,
240  prex + lambda * deltaX,
241  prey + lambda * deltaY,
242  prez + lambda * deltaZ);
243  }
244 
245 
246 }

◆ ClustersToDeposits()

void TRTProcessingOfStraw::ClustersToDeposits ( MagField::AtlasFieldCache fieldCache,
const int &  hitID,
const std::vector< cluster > &  clusters,
std::vector< TRTElectronicsProcessing::Deposit > &  deposits,
Amg::Vector3D  TRThitGlobalPos,
double  m_cosmicEventPhase,
int  strawGasType,
CLHEP::HepRandomEngine *  rndmEngine 
)
private

Transform the ioniation clusters along the particle trajectory inside a straw to energy deposits (i.e.

potential fluctuations) reaching the front-end electronics. Effects taken into effect are:

  • number of primary electrons from deposited energy
  • stocastic recapture of drift electrons
  • electron drift in the magnetic field (different direction end-cap/barrel). Optionally the drift time includes spread.
  • Optionally signal wire propagation dealys are included. Each drift electron then gives rise to two signal: direct and reflected.
Parameters
hitIDId of straw
clustersionisation clusters along particle trajectory
depositsenergy deposits on wire

Definition at line 545 of file TRTProcessingOfStraw.cxx.

552 {
553 
554  //
555  // Some initial work before looping over the cluster
556  //
557 
558  deposits.clear();
559 
560  unsigned int region(TRTDigiHelper::getRegion(hitID));
561  const bool isBarrel(region<3 );
562  const bool isEC (!isBarrel);
563  const bool isShort (region==1);
564  const bool isLong (region==2);
565  //const bool isECA (region==3);
566  //const bool isECB (region==4);
567 
568  CLHEP::RandBinomialFixedP *randBinomial{};
569  if (strawGasType == 0) { randBinomial = m_randBinomialXe.get(); }
570  else if (strawGasType == 1) { randBinomial = m_randBinomialKr.get(); }
571  else if (strawGasType == 2) { randBinomial = m_randBinomialAr.get(); }
572  else { randBinomial = m_randBinomialXe.get(); } // should never happen
573 
574  double ionisationPotential = m_settings->ionisationPotential(strawGasType);
575  double smearingFactor = m_settings->smearingFactor(strawGasType);
576 
577  std::vector<cluster>::const_iterator currentClusterIter(clusters.begin());
578  const std::vector<cluster>::const_iterator endOfClusterList(clusters.end());
579 
580  // if (m_settings->doCosmicTimingPit()) {
581  // if (m_ComTime) { m_time_y_eq_zero = m_ComTime->getTime(); }
582  // else { ATH_MSG_WARNING("Configured to use ComTime tool, but did not find tool. All hits will get the same t0"); }
583  // }
584 
585  // The average drift time is affected by the magnetic field which is not uniform so we need to use the
586  // detailed magnetic field map to obtain an effective field for this straw (used in SimDriftTimeTool).
587  // This systematically affects O(ns) drift times in the end cap, but has a very small effect in the barrel.
588  Amg::Vector3D globalPosition;
589  Amg::Vector3D mField;
590  double map_x2(0.),map_y2(0.),map_z2(0.);
591  double effectiveField2(0.); // effective field squared.
592 
593  // Magnetic field is the same for all clusters in the straw so this can be called before the cluster loop.
595  {
596  globalPosition[0]=TRThitGlobalPos[0]*CLHEP::mm;
597  globalPosition[1]=TRThitGlobalPos[1]*CLHEP::mm;
598  globalPosition[2]=TRThitGlobalPos[2]*CLHEP::mm;
599 
600  // MT Field cache is stored in cache
601  fieldCache.getField (globalPosition.data(), mField.data());
602 
603  map_x2 = mField.x()*mField.x(); // would be zero for a uniform field
604  map_y2 = mField.y()*mField.y(); // would be zero for a uniform field
605  map_z2 = mField.z()*mField.z(); // would be m_solenoidfieldstrength^2 for uniform field
606  }
607 
608  // Now we are ready to loop over clusters and form timed energy deposits at the wire:
609  //
610  // 1. First determine the number of surviving drift electrons and the energy of their deposits.
611  // 2. Then determine the timing of these deposits.
612 
613  // Notes
614  //
615  // 1) It turns out that the total energy deposited (Ed) is, on average, equal to the cluster energy (Ec):
616  // <Ed> = m_ionisationPotential/m_smearingFactor * Ec/m_ionisationPotential * m_smearingFactor = Ec.
617  // Actually it exceeds this *slightly* due to the +1 electron in the calculation of nprimaryelectrons below.
618  // The energy processing below therefore exists only to model the energy *fluctuations*.
619  //
620  // 2) Gaussian approximation (for photons, HIPs etc):
621  // For large Ec (actually nprimaryelectrons > 99) a much faster Gaussian shoot replaces
622  // the Binomial and many exponential shoots. The Gaussian pdf has a mean of Ec and variance
623  // given by sigma^2 = Ec*ionisationPotential*(2-smearingFactor)/smearingFactor. That expression
624  // comes from the sum of the variances from the Binomial and Exponential. In this scheme it is
625  // sufficient (for diffusion) to divided the energy equally amongst 100 (maxelectrons) electrons.
626 
627  // straw radius
628  const double wire_r2 = m_outerRadiusOfWire*m_outerRadiusOfWire;
629  const double straw_r2 = m_innerRadiusOfStraw*m_innerRadiusOfStraw;
630 
631  // Cluster loop
632  for (;currentClusterIter!=endOfClusterList;++currentClusterIter)
633  {
634  // Get the cluster radius and energy.
635  const double cluster_x(currentClusterIter->xpos);
636  const double cluster_y(currentClusterIter->ypos);
637  const double cluster_z(this->setClusterZ(currentClusterIter->zpos, isLong, isShort, isEC));
638  const double cluster_x2(cluster_x*cluster_x);
639  const double cluster_y2(cluster_y*cluster_y);
640  double cluster_r2(cluster_x2+cluster_y2);
641 
642  // These may never occur, but could be very problematic for getAverageDriftTime(), so check and correct this now.
643  if (cluster_r2<wire_r2) cluster_r2=wire_r2; // Compression may (v. rarely) cause r to be smaller than the wire radius. If r=0 then NaN's later!
644  if (cluster_r2>straw_r2) cluster_r2=straw_r2; // Should never occur
645 
646  const double cluster_r(std::sqrt(cluster_r2)); // cluster radius
647  const double cluster_E(currentClusterIter->energy); // cluster energy
648  const unsigned int nprimaryelectrons( static_cast<unsigned int>( cluster_E / ionisationPotential + 1.0 ) );
649 
650  // Determine the number of surviving electrons and their energy sum.
651  // If nprimaryelectrons > 100 then a Gaussian approximation is good (and much quicker)
652 
653  double depositEnergy(0.); // This will be the energy deposited at the wire.
654 
655  if (nprimaryelectrons<m_maxelectrons) // Use the detailed Binomial and Exponential treatment at this low energy.
656  {
657  unsigned int nsurvivingprimaryelectrons = static_cast<unsigned int>(randBinomial->fire(rndmEngine,nprimaryelectrons) + 0.5);
658  if (nsurvivingprimaryelectrons==0) continue; // no electrons survived; move on to the next cluster.
659  const double meanElectronEnergy(ionisationPotential / smearingFactor);
660  for (unsigned int ielec(0); ielec<nsurvivingprimaryelectrons; ++ielec) {
661  depositEnergy += CLHEP::RandExpZiggurat::shoot(rndmEngine, meanElectronEnergy);
662  }
663  }
664  else // Use a Gaussian approximation
665  {
666  const double fluctSigma(sqrt(cluster_E * ionisationPotential * (2 - smearingFactor) / smearingFactor));
667  do {
668  depositEnergy = CLHEP::RandGaussZiggurat::shoot(rndmEngine, cluster_E, fluctSigma);
669  } while(depositEnergy<0.0); // very rare.
670  }
671 
672  // Now we have the depositEnergy, we need to work out the timing and attenuation
673 
674  // First calculate the "effective field" (it's never negative):
675  // Electron drift time is prolonged by the magnetic field according to an "effective field".
676  // For the endcap, the effective field is dependent on the relative (x,y) position of the cluster.
677  // It is assumed here (checked in initialize) that the local straw x-direction is parallel with
678  // the solenoid z-direction. After Garfield simulations and long thought it was found that only
679  // field perpendicular to the electron drift is of importance.
680 
681  if (!isBarrel) // Endcap
682  {
683  if (m_useMagneticFieldMap) { // Using magnetic field map
684  effectiveField2 = map_z2*cluster_y2/cluster_r2 + map_x2 + map_y2;
685  }
686  else { // Not using magnetic field map (you really should not do this!):
687  effectiveField2 = m_solenoidFieldStrength*m_solenoidFieldStrength * cluster_y2 / cluster_r2;
688  }
689  }
690  else // Barrel
691  {
692  if (m_useMagneticFieldMap) { // Using magnetic field map (here bug #91830 is corrected)
693  effectiveField2 = map_z2 + (map_x2+map_y2)*cluster_y2/cluster_r2;
694  }
695  else { // Without the mag field map (very small change in digi output)
697  }
698  }
699 
700  // If there is no field we might need to reset effectiveField2 to zero.
701  if (m_solenoidFieldStrength == 0. ) effectiveField2=0.;
702 
703  // Now we need the deposit time which is the sum of three components:
704  // 1. Time of the hit(cluster): clusterTime.
705  // 2. Drift times: either commondrifttime, or diffused m_drifttimes
706  // 3. Wire propagation times: timedirect and timereflect.
707 
708  // get the time of the hit(cluster)
709  double clusterTime(currentClusterIter->time);
710 
711  if ( m_settings->doCosmicTimingPit() )
712  { // make (x,y) dependent? i.e: + f(x,y).
713  // clusterTime = clusterTime - m_time_y_eq_zero + m_settings->jitterTimeOffset()*( CLHEP::RandFlat::shoot(rndmEngine) );
714  clusterTime = clusterTime + cosmicEventPhase + m_settings->jitterTimeOffset()*( CLHEP::RandFlat::shoot(rndmEngine) );
715  // yes it is a '+' now. Ask Alex Alonso.
716  }
717 
718  // get the wire propagation times (for direct and reflected signals)
719  double timedirect(0.), timereflect(0.);
720  m_pTimeCorrection->PropagationTime( hitID, cluster_z, timedirect, timereflect );
721 
722  // While we have the propagation times, we can calculate the exponential attenuation factor
723  double expdirect(1.0), expreflect(1.0); // Initially set to "no attenuation".
724  if (m_useAttenuation)
725  {
726  //expdirect = exp( -timedirect *m_signalPropagationSpeed / m_attenuationLength);
727  //expreflect = exp( -timereflect*m_signalPropagationSpeed / m_attenuationLength);
728  // Tabulating exp(-dist/m_attenuationLength) with only 150 elements: index [0,149].
729  // > 99.9% of output digits are the same, saves 13% CPU time.
730  // Distances the signal propagate along the wire:
731  // * distdirect is rarely negative (<0.2%) by ~ mm. In such cases there is
732  // no attenuation, which is equivalent to distdirect=0 and so is good.
733  // * distreflect is always +ve and less than 1500, and so is good.
734  // The code is protected against out of bounds in anycase.
735  const double distdirect = timedirect *m_signalPropagationSpeed;
736  const double distreflect = timereflect*m_signalPropagationSpeed;
737  const unsigned int kdirect = static_cast<unsigned int>(distdirect/10);
738  const unsigned int kreflect = static_cast<unsigned int>(distreflect/10);
739  if (kdirect<150) expdirect = m_expattenuation[kdirect]; // otherwise there
740  if (kreflect<150) expreflect = m_expattenuation[kreflect]; // is no attenuation.
741  }
742 
743  // Finally, deposit the energy on the wire using the drift-time tool (diffusion is no longer available).
744  double commondrifttime = m_pSimDriftTimeTool->getAverageDriftTime(cluster_r,effectiveField2,strawGasType);
745  double dt = clusterTime + commondrifttime;
746  deposits.emplace_back(0.5*depositEnergy*expdirect, timedirect+dt);
747  deposits.emplace_back(0.5*depositEnergy*expreflect, timereflect+dt);
748 
749  } // end of cluster loop
750 
751  }

◆ getGlobalPosition()

Amg::Vector3D TRTProcessingOfStraw::getGlobalPosition ( int  hitID,
const TimedHitPtr< TRTUncompressedHit > *  theHit 
)
private

Definition at line 754 of file TRTProcessingOfStraw.cxx.

754  {
755 
756  const int mask(0x0000001F);
757  int word_shift(5);
758  int trtID, ringID, moduleID, layerID, strawID;
759  int wheelID, planeID, sectorID;
760 
761  const InDetDD::TRT_BarrelElement *barrelElement;
762  const InDetDD::TRT_EndcapElement *endcapElement;
763 
764  if ( !(hitID & 0x00200000) ) { // barrel
765 
766  strawID = hitID & mask;
767  hitID >>= word_shift;
768  layerID = hitID & mask;
769  hitID >>= word_shift;
770  moduleID = hitID & mask;
771  hitID >>= word_shift;
772  ringID = hitID & mask;
773  trtID = hitID >> word_shift;
774 
775  barrelElement = m_detmgr->getBarrelElement(trtID, ringID, moduleID, layerID);
776 
777  if (barrelElement) {
778  const Amg::Vector3D v( (*theHit)->GetPreStepX(),(*theHit)->GetPreStepY(),(*theHit)->GetPreStepZ());
779  return barrelElement->strawTransform(strawID)*v;
780  }
781 
782  } else { // endcap
783 
784  strawID = hitID & mask;
785  hitID >>= word_shift;
786  planeID = hitID & mask;
787  hitID >>= word_shift;
788  sectorID = hitID & mask;
789  hitID >>= word_shift;
790  wheelID = hitID & mask;
791  trtID = hitID >> word_shift;
792 
793  // change trtID (which is 2/3 for endcaps) to use 0/1 in getEndcapElement
794  if (trtID == 3) trtID = 0;
795  else trtID = 1;
796 
797  endcapElement = m_detmgr->getEndcapElement(trtID, wheelID, planeID, sectorID);
798 
799  if ( endcapElement ) {
800  const Amg::Vector3D v( (*theHit)->GetPreStepX(),(*theHit)->GetPreStepY(),(*theHit)->GetPreStepZ());
801  return endcapElement->strawTransform(strawID)*v;
802  }
803 
804  }
805 
806  ATH_MSG_WARNING ( "Could not find global coordinate of a straw - drifttime calculation will be inaccurate" );
807  return {0.0,0.0,0.0};
808 
809 }

◆ Initialize()

void TRTProcessingOfStraw::Initialize ( const ITRT_CalDbTool calDbTool)
private

Initialize.

Definition at line 88 of file TRTProcessingOfStraw.cxx.

89 {
90 
97  m_timeCorrection = m_settings->timeCorrection(); // false for beamType='cosmics'
99 
100  m_maxelectrons = 100; // 100 gives good Gaussian approximation
101 
102  if (m_pPAItoolXe==nullptr) {
103  ATH_MSG_FATAL ( "TRT_PAITool for Xenon not defined! no point in continuing!" );
104  }
105  if (m_pPAItoolKr==nullptr) {
106  ATH_MSG_ERROR ( "TRT_PAITool for Krypton is not defined!!! Xenon TRT_PAITool will be used for Krypton straws!" );
108  }
109  if (m_pPAItoolAr==nullptr) {
110  ATH_MSG_ERROR ( "TRT_PAITool for Argon is not defined!!! Xenon TRT_PAITool will be used for Argon straws!" );
112  }
113 
114  ATH_MSG_INFO ( "Xe barrel drift-time at r = 2 mm is " << m_pSimDriftTimeTool->getAverageDriftTime(2.0, 0.002*0.002, 0) << " ns." );
115  ATH_MSG_INFO ( "Kr barrel drift-time at r = 2 mm is " << m_pSimDriftTimeTool->getAverageDriftTime(2.0, 0.002*0.002, 1) << " ns." );
116  ATH_MSG_INFO ( "Ar barrel drift-time at r = 2 mm is " << m_pSimDriftTimeTool->getAverageDriftTime(2.0, 0.002*0.002, 2) << " ns." );
117 
119 
120  const double intervalBetweenCrossings(m_settings->timeInterval() / 3.);
121  m_minCrossingTime = - (intervalBetweenCrossings * 2. + 1.*CLHEP::ns);
122  m_maxCrossingTime = intervalBetweenCrossings * 3. + 1.*CLHEP::ns;
123  m_shiftOfZeroPoint = static_cast<double>( m_settings->numberOfCrossingsBeforeMain() ) * intervalBetweenCrossings;
124 
125  // Tabulate exp(-dist/m_attenuationLength) as a function of dist = time*m_signalPropagationSpeed [0.0 mm, 1500 mm)
126  // otherwise we are doing an exp() for every cluster! > 99.9% of output digits are the same, saves 13% CPU time.
127  m_expattenuation.reserve(150);
128  for (unsigned int k=0; k<150; k++) {
129  double dist = 10.0*(k+0.5); // [5mm, 1415mm] max 5 mm error (sigma = 3 mm)
130  m_expattenuation.push_back(exp(-dist/m_attenuationLength));
131  }
132 
133  //For the field effect on drifttimes in this class we will assume that the local x,y coordinates of endcap straws are such that the
134  //local y-direction is parallel to the global z-direction. As a sanity check against future code developments we will test this
135  //assumption on one straw from each endcap layer.
136 
137  if (m_solenoidFieldStrength!=0.0)
138  {
140  for (unsigned int iwheel = 0; iwheel < num->getNEndcapWheels(); ++iwheel)
141  {
142  for (unsigned int iside = 0; iside < 2; ++iside)
143  { //positive and negative endcap
144  for (unsigned int ilayer = 0; ilayer < num->getNEndcapLayers(iwheel); ++ilayer)
145  {
146  const InDetDD::TRT_EndcapElement * ec_element
147  = m_detmgr->getEndcapElement(iside,//positive or negative endcap
148  iwheel,//wheelIndex,
149  ilayer,//strawLayerIndex,
150  0);//phiIndex
151  //Local straw center and local straw point one unit along x:
152  if (!ec_element)
153  {
154  ATH_MSG_VERBOSE ( "Failed to retrieve endcap element for (iside,iwheel,ilayer)=("
155  << iside<<", "<<iwheel<<", "<<ilayer<<")." );
156  continue;
157  }
158  Amg::Vector3D strawcenter(0.0,0.0,0.0);
159  Amg::Vector3D strawx(1.0,0.0,0.0);
160  //Transform to global coordinate (use first straw in element):
161  strawcenter = ec_element->strawTransform(0) * strawcenter;
162  strawx = ec_element->strawTransform(0) * strawx;
163  const Amg::Vector3D v(strawx-strawcenter);
164  const double zcoordfrac((v.z()>0?v.z():-v.z())/v.mag());
165  if (zcoordfrac<0.98 || zcoordfrac > 1.02)
166  {
167  ATH_MSG_WARNING ( "Found endcap straw where the assumption that local x-direction"
168  <<" is parallel to global z-direction is NOT valid."
169  <<" Drift times will be somewhat off." );
170  }
171  }
172  }
173  }
174 
175  //check local barrel coordinates at four positions.
176  for (unsigned int phi_it = 0; phi_it < 32; phi_it++)
177  {
178  const InDetDD::TRT_BarrelElement * bar_element = m_detmgr->getBarrelElement(1,1,phi_it,1);
179 
180  Amg::Vector3D strawcenter(0.0,0.0,0.0);
181  Amg::Vector3D straw(cos((double)phi_it*2*M_PI/32.),sin((double)phi_it*2*M_PI/32.),0.0);
182  strawcenter = bar_element->strawTransform(0) * strawcenter;
183  straw = bar_element->strawTransform(0) * straw;
184  const Amg::Vector3D v(straw-strawcenter);
185  const double coordfrac(atan2(v.x(),v.y()));
186  if (coordfrac>0.2 || coordfrac < -0.2)
187  {
188  ATH_MSG_WARNING ( "Found barrel straw where the assumption that local y-direction"
189  <<" is along the straw is NOT valid."
190  <<" Drift times will be somewhat off." );
191  }
192  }
193  }
194 
195  m_randBinomialXe = std::make_unique<CLHEP::RandBinomialFixedP>(nullptr, 1, m_settings->smearingFactor(0), m_maxelectrons);
196  m_randBinomialKr = std::make_unique<CLHEP::RandBinomialFixedP>(nullptr, 1, m_settings->smearingFactor(1), m_maxelectrons);
197  m_randBinomialAr = std::make_unique<CLHEP::RandBinomialFixedP>(nullptr, 1, m_settings->smearingFactor(2), m_maxelectrons);
198 
199  ATH_MSG_VERBOSE ( "Initialization done" );
200 }

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40 {
42  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 164 of file AthMessaging.h.

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level  lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 179 of file AthMessaging.h.

180 { return msg() << lvl; }

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level  lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152 {
153  if (!m_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

◆ operator=()

TRTProcessingOfStraw& TRTProcessingOfStraw::operator= ( const TRTProcessingOfStraw )
private

◆ ProcessStraw()

void TRTProcessingOfStraw::ProcessStraw ( MagField::AtlasFieldCache fieldCache,
hitCollConstIter  i,
hitCollConstIter  e,
TRTDigit outdigit,
bool &  m_alreadyPrintedPDGcodeWarning,
double  m_cosmicEventPhase,
int  strawGasType,
bool  emulationArflag,
bool  emulationKrflag,
CLHEP::HepRandomEngine *  rndmEngine,
CLHEP::HepRandomEngine *  elecProcRndmEngine,
CLHEP::HepRandomEngine *  elecNoiseRndmEngine,
CLHEP::HepRandomEngine *  paiRndmEngine 
)

Process this straw all the way from Geant4 hit to output digit.


Steps:

  1. Loop over the simhits in this straw and produce a list of primary ionisation clusters.
  2. Use the cluster list along with gas and wire properties, to create a list of energy deposits (i.e. potential fluctuations) reaching the frontend electronics.
  3. Simulate how the FE turns the results into an output digit. This includes the shaping/amplification and subsequent discrimination as well as addition of noise.
Parameters
iGeant4 hit collection iterator
elast hit in collection
outdigitThe 27 bit digit (bits: 8 low + 1 high + 8 low + 1 high + 8 low + 1 high)

Definition at line 249 of file TRTProcessingOfStraw.cxx.

262 {
263 
265  // We need the straw id several times in the following //
267  const int hitID((*i)->GetHitID());
268  unsigned int region(TRTDigiHelper::getRegion(hitID));
269  const bool isBarrel(region<3 );
270  //const bool isEC (!isBarrel);
271  //const bool isShort (region==1);
272  //const bool isLong (region==2);
273  const bool isECA (region==3);
274  const bool isECB (region==4);
275 
277  //======================================================//
279  // First step is to loop over the simhits in this straw //
280  // and produce a list of primary ionisation clusters. //
281  // Each cluster needs the following information: //
282  // //
283  // * The total energy of the cluster. //
284  // * Its location in local straw (x,y,z) coordinates. //
285  // * The time the cluster was created. //
286  // //
288  //======================================================//
290  // TimeShift is the same for all the simhits in the straw.
291  const double timeShift(m_pTimeCorrection->TimeShift(hitID)); // rename hitID to strawID
292 
293  m_clusterlist.clear();
294 
295  //For magnetic field evaluation
296  Amg::Vector3D TRThitGlobalPos(0.0,0.0,0.0);
297 
298  //Now we loop over all the simhits
299  for (hitCollConstIter hit_iter= i; hit_iter != e; ++hit_iter)
300  {
301  //Get the hit:
302  const TimedHitPtr<TRTUncompressedHit> *theHit = &(*hit_iter);
303 
304  TRThitGlobalPos = getGlobalPosition(hitID, theHit);
305 
306  //Figure out the global time of the hit (all clusters from the hit
307  //will get same timing).
308 
309  double timeOfHit(0.0); // remains zero if timeCorrection is false (beamType='cosmics')
310  if (m_timeCorrection) {
311  const double globalHitTime(hitTime(*theHit));
312  const double globalTime = static_cast<double>((*theHit)->GetGlobalTime());
313  const double bunchCrossingTime(globalHitTime - globalTime);
314  if ( (bunchCrossingTime < m_minCrossingTime) || (bunchCrossingTime > m_maxCrossingTime) ) continue;
315  timeOfHit = m_shiftOfZeroPoint + globalHitTime - timeShift; //is this shiftofzeropoint correct pileup-wise?? [fixme]
316  }
317 
318  //if (timeOfHit>125.0) continue; // Will give 3% speed up (but changes seeds!). Needs careful thought though.
319 
320  //What kind of particle are we dealing with?
321  const int particleEncoding((*theHit)->GetParticleEncoding());
322 
323  //Safeguard against pdgcode 0.
324  if (particleEncoding == 0)
325  {
326  //According to Andrea this is usually nuclear fragments from
327  //hadronic interactions. They therefore ought to be allowed to
328  //contribute, but we ignore them for now - until it can be studied
329  //that it is indeed safe to stop doing so
332  ATH_MSG_WARNING ( "Ignoring sim. particle with pdgcode 0. This warning is only shown once per job" );
333  }
334  continue;
335  }
336 
337  // If it is a photon we assume it was absorbed entirely at the point of interaction.
338  // we simply deposit the entire energy into the last point of the sim. step.
339  if (particleEncoding == 22)
340  {
341 
342  const double energyDeposit = (*theHit)->GetEnergyDeposit(); // keV (see comment below)
343  // Apply radiator efficiency "fudge factor" to ignore some TR photons (assuming they are over produced in the sim. step.
344  // The fraction removed is based on tuning pHT for electrons to data, after tuning pHT for muons (which do not produce TR).
345  // The efficiency is different for Xe, Kr and Ar. Avoid fudging non-TR photons (TR is < 30 keV).
346  // Also: for |eta|<0.5 apply parabolic scale; see "Parabolic Fudge" https://indico.cern.ch/event/304066/
347 
348  if ( energyDeposit<30.0 ) {
349 
350  // Improved Argon Emulation tuning October 2018 by Hassane Hamdaoui https://cds.cern.ch/record/2643784
351  // Previously 0.15, 0.28, 0.28
352  double ArEmulationScaling_BA = 0.05;
353  double ArEmulationScaling_ECA = 0.20;
354  double ArEmulationScaling_ECB = 0.20;
355 
356  // ROUGH GUESSES RIGHT NOW
357  double KrEmulationScaling_BA = 0.20;
358  double KrEmulationScaling_ECA = 0.39;
359  double KrEmulationScaling_ECB = 0.39;
360 
361  if (isBarrel) { // Barrel
362  double trEfficiencyBarrel = m_settings->trEfficiencyBarrel(strawGasType);
363  double hitx = TRThitGlobalPos[0];
364  double hity = TRThitGlobalPos[1];
365  double hitz = TRThitGlobalPos[2];
366  double hitEta = std::abs(log(tan(0.5*atan2(sqrt(hitx*hitx+hity*hity),hitz))));
367  if ( hitEta < 0.5 ) { trEfficiencyBarrel *= ( 0.833333+0.6666667*hitEta*hitEta ); }
368  // scale down the TR efficiency if we are emulating
369  if ( strawGasType == 0 && emulationArflag ) { trEfficiencyBarrel *= ArEmulationScaling_BA; }
370  if ( strawGasType == 0 && emulationKrflag ) { trEfficiencyBarrel *= KrEmulationScaling_BA; }
371  if ( CLHEP::RandFlat::shoot(rndmEngine) > trEfficiencyBarrel ) continue; // Skip this photon
372  } // close if barrel
373  else { // Endcap - no eta dependence here.
374  if (isECA) {
375  double trEfficiencyEndCapA = m_settings->trEfficiencyEndCapA(strawGasType);
376  // scale down the TR efficiency if we are emulating
377  if ( strawGasType == 0 && emulationArflag ) { trEfficiencyEndCapA *= ArEmulationScaling_ECA; }
378  if ( strawGasType == 0 && emulationKrflag ) { trEfficiencyEndCapA *= KrEmulationScaling_ECA; }
379  if ( CLHEP::RandFlat::shoot(rndmEngine) > trEfficiencyEndCapA ) continue; // Skip this photon
380  }
381  if (isECB) {
382  double trEfficiencyEndCapB = m_settings->trEfficiencyEndCapB(strawGasType);
383  // scale down the TR efficiency if we are emulating
384  if ( strawGasType == 0 && emulationArflag ) { trEfficiencyEndCapB *= ArEmulationScaling_ECB; }
385  if ( strawGasType == 0 && emulationKrflag ) { trEfficiencyEndCapB *= KrEmulationScaling_ECB; }
386  if ( CLHEP::RandFlat::shoot(rndmEngine) > trEfficiencyEndCapB ) continue; // Skip this photon
387  }
388  } // close else (end caps)
389  } // energyDeposit < 30.0
390 
391  // Append this (usually highly energetic) cluster to the list:
392  m_clusterlist.emplace_back( energyDeposit*CLHEP::keV, timeOfHit, (*theHit)->GetPostStepX(), (*theHit)->GetPostStepY(), (*theHit)->GetPostStepZ()
393  );
394 
395  // Regarding the CLHEP::keV above: In TRT_G4_SD we converting the hits to keV,
396  // so here we convert them back to CLHEP units by multiplying by CLHEP::keV.
397  }
398  //Special treatment of magnetic monopoles && highly charged Qballs (charge > 10)
399  else if ( (MC::isMonopole(particleEncoding)) ||
400  ((static_cast<int>(abs(particleEncoding)/10000000) == 1) &&
401  (static_cast<int>(abs(particleEncoding)/100000) == 100) &&
402  (static_cast<int>((abs(particleEncoding))-10000000)/100>10)) )
403  {
404  m_clusterlist.emplace_back((*theHit)->GetEnergyDeposit()*CLHEP::keV, timeOfHit, (*theHit)->GetPostStepX(), (*theHit)->GetPostStepY(), (*theHit)->GetPostStepZ()
405  );
406  }
407  else { // It's not a photon, monopole or Qball with charge > 10, so we proceed with regular ionization using the PAI model
408 
409  // Lookup mass and charge from the PDG info in CLHEP HepPDT:
410  const HepPDT::ParticleData *particle(m_pParticleTable->particle(HepPDT::ParticleID(abs(particleEncoding))));
411  double particleCharge(0.);
412  double particleMass(0.);
413 
414  if (particle)
415  {
416  particleCharge = particle->charge();
417  particleMass = particle->mass().value();
418  if ((static_cast<int>(abs(particleEncoding)/10000000) == 1) && (static_cast<int>(abs(particleEncoding)/100000)==100))
419  {
420  particleCharge = (particleEncoding>0 ? 1. : -1.) *(((abs(particleEncoding) / 100000.0) - 100.0) * 1000.0);
421  }
422  else if ((static_cast<int>(abs(particleEncoding)/10000000) == 2) && (static_cast<int>(abs(particleEncoding)/100000)==200))
423  {
424  particleCharge = (particleEncoding>0 ? 1. : -1.) *((double)((abs(particleEncoding) / 1000) % 100) / (double)((abs(particleEncoding) / 10) % 100));
425  }
426  }
427  else
428  {
429  const int number_of_digits(static_cast<int>(log10((double)abs(particleEncoding))+1.));
430  if (number_of_digits != 10)
431  {
432  ATH_MSG_ERROR ( "Data for sim. particle with pdgcode "<<particleEncoding
433  <<" does not have 10 digits and could not be retrieved from PartPropSvc. Assuming mass and charge as pion." );
434  particleCharge = 1.;
435  particleMass = 139.57018*CLHEP::MeV;
436  }
437  else if (( number_of_digits == 10 ) && (static_cast<int>(abs(particleEncoding)/100000000)!=10) )
438  {
439  ATH_MSG_ERROR ( "Data for sim. particle with pdgcode "<<particleEncoding
440  <<" has 10 digits, could not be retrieved from PartPropSvc, and is inconsistent with ion pdg convention (+/-10LZZZAAAI)."
441  <<" Assuming mass and charge as pion." );
442  particleCharge = 1.;
443  particleMass = 139.57018*CLHEP::MeV;
444  }
445  else if ((number_of_digits==10) && (static_cast<int>(abs(particleEncoding)/100000000)==10))
446  {
447  const int A(static_cast<int>((((particleEncoding)%1000000000)%10000)/10.));
448  const int Z(static_cast<int>((((particleEncoding)%10000000)-(((particleEncoding)%1000000000)%10000))/10000.));
449 
450  const double Mp(938.272*CLHEP::MeV);
451  const double Mn(939.565*CLHEP::MeV);
452 
453  particleCharge = (particleEncoding>0 ? 1. : -1.) * static_cast<double>(Z);
454  particleMass = std::abs( Z*Mp+(A-Z)*Mn );
455 
456  if (!alreadyPrintedPDGcodeWarning)
457  {
458  ATH_MSG_WARNING ( "Data for sim. particle with pdgcode "<<particleEncoding
459  <<" could not be retrieved from PartPropSvc (unexpected ion)."
460  <<" Calculating mass and charge from pdg code. "
461  <<" The result is: Charge = "<<particleCharge<<" Mass = "<<particleMass<<"MeV" );
462  alreadyPrintedPDGcodeWarning = true;
463  }
464  }
465  }
466 
467  if (!particleCharge)//Abort if uncharged particle.
468  {
469  continue;
470  }
471  if (!particleMass)
472  { //Abort if weird massless charged particle.
473  ATH_MSG_WARNING ( "Ignoring ionization from sim. particle with pdgcode "<<particleEncoding
474  <<" since it appears to be a massless charged particle." );
475  continue;
476  }
477 
478  //We are now in the most likely case: A normal ionizing
479  //particle. Using the PAI model we are going to distribute
480  //ionization clusters along the step taken by the sim particle.
481 
482  const double scaledKineticEnergy( static_cast<double>((*theHit)->GetKineticEnergy()) * ( CLHEP::proton_mass_c2 / particleMass ));
483 
484  addClustersFromStep ( scaledKineticEnergy, particleCharge, timeOfHit,
485  (*theHit)->GetPreStepX(),(*theHit)->GetPreStepY(),(*theHit)->GetPreStepZ(),
486  (*theHit)->GetPostStepX(),(*theHit)->GetPostStepY(),(*theHit)->GetPostStepZ(),
487  m_clusterlist, strawGasType, rndmEngine, paiRndmEngine);
488 
489  }
490  }//end of hit loop
491 
493  //======================================================//
495  // Second step is, using the cluster list along with //
496  // gas and wire properties, to create a list of energy //
497  // deposits (i.e. potential fluctuations) reaching the //
498  // frontend electronics. Each deposit needs: //
499  // //
500  // * The energy of the deposit. //
501  // * The time it arrives at the FE electronics //
502  // //
504  //======================================================//
506 
507  m_depositList.clear();
508 
509  ClustersToDeposits(fieldCache, hitID, m_clusterlist, m_depositList, TRThitGlobalPos, cosmicEventPhase, strawGasType, rndmEngine );
510 
511 
513  //======================================================//
515  // The third and final step is to simulate how the FE //
516  // turns the results into an output digit. This //
517  // includes the shaping/amplification and subsequent //
518  // discrimination as well as addition of noise. //
519  // //
521  //======================================================//
523 
524  //If no deposits, and no electronics noise we might as well stop here:
525  if ( m_depositList.empty() && !m_pNoise )
526  {
527  outdigit = TRTDigit(hitID, 0);
528  return;
529  }
530 
531  //Get straw conditions data:
532  double lowthreshold, noiseamplitude;
533  if (m_settings->noiseInSimhits()) {
534  m_pDigConditions->getStrawData( hitID, lowthreshold, noiseamplitude );
535  } else {
536  lowthreshold = isBarrel ? m_settings->lowThresholdBar(strawGasType) : m_settings->lowThresholdEC(strawGasType);
537  noiseamplitude = 0.0;
538  }
539 
540  //Electronics processing:
541  m_pElectronicsProcessing->ProcessDeposits( m_depositList, hitID, outdigit, lowthreshold, noiseamplitude, strawGasType, elecProcRndmEngine, elecNoiseRndmEngine );
542 }

◆ setClusterZ()

double TRTProcessingOfStraw::setClusterZ ( double  cluster_z_in,
bool  isLong,
bool  isShort,
bool  isEC 
) const
private

Definition at line 812 of file TRTProcessingOfStraw.cxx.

812  {
813  double cluster_z(cluster_z_in);
814 
815  // The active gas volume along the straw z-axis is: Barrel long +-349.315 mm; Barrel short +-153.375 mm; End caps +-177.150 mm.
816  // Here we give a warning for clusters that are outside of the straw gas volume in in z. Since T/P version 3 cluster z values
817  // can go several mm outside these ranges; 30 mm is plenty allowance in the checks below.
818  const double longBarrelStrawHalfLength(349.315*CLHEP::mm);
819  const double shortBarrelStrawHalfLength(153.375*CLHEP::mm);
820  const double EndcapStrawHalfLength(177.150*CLHEP::mm);
821  if ( isLong && std::abs(cluster_z)>longBarrelStrawHalfLength+30 ) {
822  double d = cluster_z<0 ? cluster_z+longBarrelStrawHalfLength : cluster_z-longBarrelStrawHalfLength;
823  ATH_MSG_WARNING ("Long barrel straw cluster is outside the active gas volume z = +- 349.315 mm by " << d << " mm.");
824  ATH_MSG_WARNING ("Setting cluster_z = 0.0");
825  cluster_z = 0.0;
826  }
827  if ( isShort && std::abs(cluster_z)>shortBarrelStrawHalfLength+30 ) {
828  double d = cluster_z<0 ? cluster_z+shortBarrelStrawHalfLength : cluster_z-shortBarrelStrawHalfLength;
829  ATH_MSG_WARNING ("Short barrel straw cluster is outside the active gas volume z = +- 153.375 mm by " << d << " mm.");
830  ATH_MSG_WARNING ("Setting cluster_z = 0.0");
831  cluster_z = 0.0;
832  }
833  if ( isEC && std::abs(cluster_z)>EndcapStrawHalfLength+30 ) {
834  double d = cluster_z<0 ? cluster_z+EndcapStrawHalfLength : cluster_z-EndcapStrawHalfLength;
835  ATH_MSG_WARNING ("End cap straw cluster is outside the active gas volume z = +- 177.150 mm by " << d << " mm.");
836  ATH_MSG_WARNING ("Setting cluster_z = 0.0");
837  cluster_z = 0.0;
838  }
839  return cluster_z;
840 }

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level  lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29 {
30  m_lvl = lvl;
31 }

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_alreadywarnedagainstpdg0

bool TRTProcessingOfStraw::m_alreadywarnedagainstpdg0
private

Definition at line 229 of file TRTProcessingOfStraw.h.

◆ m_attenuationLength

double TRTProcessingOfStraw::m_attenuationLength = 0.0
private

Definition at line 129 of file TRTProcessingOfStraw.h.

◆ m_clusterlist

std::vector<cluster> TRTProcessingOfStraw::m_clusterlist
private

Definition at line 163 of file TRTProcessingOfStraw.h.

◆ m_depositList

std::vector<TRTElectronicsProcessing::Deposit> TRTProcessingOfStraw::m_depositList
private

Definition at line 164 of file TRTProcessingOfStraw.h.

◆ m_detmgr

const InDetDD::TRT_DetectorManager* TRTProcessingOfStraw::m_detmgr
private

Definition at line 119 of file TRTProcessingOfStraw.h.

◆ m_drifttimes

std::vector<double> TRTProcessingOfStraw::m_drifttimes
private

Definition at line 225 of file TRTProcessingOfStraw.h.

◆ m_expattenuation

std::vector<double> TRTProcessingOfStraw::m_expattenuation
private

Definition at line 226 of file TRTProcessingOfStraw.h.

◆ m_id_helper

const TRT_ID* TRTProcessingOfStraw::m_id_helper
protected

Definition at line 238 of file TRTProcessingOfStraw.h.

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_innerRadiusOfStraw

double TRTProcessingOfStraw::m_innerRadiusOfStraw = 0.0
private

Definition at line 138 of file TRTProcessingOfStraw.h.

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

◆ m_maxCrossingTime

double TRTProcessingOfStraw::m_maxCrossingTime = 0.0
private

Definition at line 134 of file TRTProcessingOfStraw.h.

◆ m_maxelectrons

unsigned int TRTProcessingOfStraw::m_maxelectrons = 0U
private

Definition at line 227 of file TRTProcessingOfStraw.h.

◆ m_minCrossingTime

double TRTProcessingOfStraw::m_minCrossingTime = 0.0
private

Definition at line 135 of file TRTProcessingOfStraw.h.

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_outerRadiusOfWire

double TRTProcessingOfStraw::m_outerRadiusOfWire = 0.0
private

Definition at line 139 of file TRTProcessingOfStraw.h.

◆ m_pDigConditions

TRTDigCondBase* TRTProcessingOfStraw::m_pDigConditions
private

Definition at line 147 of file TRTProcessingOfStraw.h.

◆ m_pElectronicsProcessing

TRTElectronicsProcessing* TRTProcessingOfStraw::m_pElectronicsProcessing
private

Definition at line 145 of file TRTProcessingOfStraw.h.

◆ m_pNoise

TRTNoise* TRTProcessingOfStraw::m_pNoise
private

Definition at line 146 of file TRTProcessingOfStraw.h.

◆ m_pPAItoolAr

ITRT_PAITool* TRTProcessingOfStraw::m_pPAItoolAr
private

Definition at line 121 of file TRTProcessingOfStraw.h.

◆ m_pPAItoolKr

ITRT_PAITool* TRTProcessingOfStraw::m_pPAItoolKr
private

Definition at line 122 of file TRTProcessingOfStraw.h.

◆ m_pPAItoolXe

ITRT_PAITool* TRTProcessingOfStraw::m_pPAItoolXe
private

Definition at line 120 of file TRTProcessingOfStraw.h.

◆ m_pParticleTable

const HepPDT::ParticleDataTable* TRTProcessingOfStraw::m_pParticleTable
private

Definition at line 149 of file TRTProcessingOfStraw.h.

◆ m_pSimDriftTimeTool

ITRT_SimDriftTimeTool* TRTProcessingOfStraw::m_pSimDriftTimeTool
private

Definition at line 123 of file TRTProcessingOfStraw.h.

◆ m_pTimeCorrection

TRTTimeCorrection* TRTProcessingOfStraw::m_pTimeCorrection
private

Definition at line 144 of file TRTProcessingOfStraw.h.

◆ m_randBinomialAr

std::unique_ptr<CLHEP::RandBinomialFixedP> TRTProcessingOfStraw::m_randBinomialAr {}
private

Definition at line 235 of file TRTProcessingOfStraw.h.

◆ m_randBinomialKr

std::unique_ptr<CLHEP::RandBinomialFixedP> TRTProcessingOfStraw::m_randBinomialKr {}
private

Definition at line 234 of file TRTProcessingOfStraw.h.

◆ m_randBinomialXe

std::unique_ptr<CLHEP::RandBinomialFixedP> TRTProcessingOfStraw::m_randBinomialXe {}
private

Definition at line 233 of file TRTProcessingOfStraw.h.

◆ m_settings

const TRTDigSettings* TRTProcessingOfStraw::m_settings
private

Definition at line 118 of file TRTProcessingOfStraw.h.

◆ m_shiftOfZeroPoint

double TRTProcessingOfStraw::m_shiftOfZeroPoint = 0.0
private

Definition at line 136 of file TRTProcessingOfStraw.h.

◆ m_signalPropagationSpeed

double TRTProcessingOfStraw::m_signalPropagationSpeed = 0.0
private

Definition at line 128 of file TRTProcessingOfStraw.h.

◆ m_solenoidFieldStrength

double TRTProcessingOfStraw::m_solenoidFieldStrength = 0.0
private

Definition at line 141 of file TRTProcessingOfStraw.h.

◆ m_timeCorrection

bool TRTProcessingOfStraw::m_timeCorrection = false
private

Time to be corrected for flight and wire propagation delays false when beamType='cosmics'.

Definition at line 126 of file TRTProcessingOfStraw.h.

◆ m_useAttenuation

bool TRTProcessingOfStraw::m_useAttenuation = false
private

Definition at line 131 of file TRTProcessingOfStraw.h.

◆ m_useMagneticFieldMap

bool TRTProcessingOfStraw::m_useMagneticFieldMap = false
private

Definition at line 132 of file TRTProcessingOfStraw.h.


The documentation for this class was generated from the following files:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
ITRT_PAITool::GetMeanFreePath
virtual double GetMeanFreePath(double scaledKineticEnergy, double squaredCharge) const =0
GetMeanFreePath.
TRTProcessingOfStraw::m_pElectronicsProcessing
TRTElectronicsProcessing * m_pElectronicsProcessing
Definition: TRTProcessingOfStraw.h:145
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
Trk::ParticleSwitcher::particle
constexpr ParticleHypothesis particle[PARTICLEHYPOTHESES]
the array of masses
Definition: ParticleHypothesis.h:76
TRTDigSettings::doCosmicTimingPit
bool doCosmicTimingPit() const
Cosmics timing corresponding to pit setup?
TRTProcessingOfStraw::m_pDigConditions
TRTDigCondBase * m_pDigConditions
Definition: TRTProcessingOfStraw.h:147
InDetDD::TRT_BarrelElement
Definition: TRT_BarrelElement.h:44
TRT::Hit::straw
@ straw
Definition: HitInfo.h:82
TRTDigSettings::lowThresholdEC
double lowThresholdEC(int strawGasType) const
TRTProcessingOfStraw::m_innerRadiusOfStraw
double m_innerRadiusOfStraw
Definition: TRTProcessingOfStraw.h:138
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
TRTDigSettings::timeCorrection
bool timeCorrection() const
Query whether time is corrected for flight and wire propagation delays.
makeComparison.deltaY
int deltaY
Definition: makeComparison.py:44
TRTDigSettings::useMagneticFieldMap
bool useMagneticFieldMap() const
TRTDigiHelper::getRegion
unsigned int getRegion(int hitID)
Definition: TRTDigiHelper.cxx:48
ITRT_PAITool
Definition: ITRT_PAITool.h:20
TRTProcessingOfStraw::m_detmgr
const InDetDD::TRT_DetectorManager * m_detmgr
Definition: TRTProcessingOfStraw.h:119
Monitored::Z
@ Z
Definition: HistogramFillerUtils.h:24
hist_file_dump.d
d
Definition: hist_file_dump.py:137
InDetDD::TRT_DetectorManager::getBarrelElement
const TRT_BarrelElement * getBarrelElement(unsigned int positive, unsigned int moduleIndex, unsigned int phiIndex, unsigned int strawLayerIndex) const
Access Barrel Elements:---------------—(Fast)-------------------------—.
Definition: TRT_DetectorManager.cxx:103
ITRT_PAITool::GetEnergyTransfer
virtual double GetEnergyTransfer(double scaledKineticEnergy, CLHEP::HepRandomEngine *rndmEngine) const =0
GetEnergyTransfer.
TRTProcessingOfStraw::m_signalPropagationSpeed
double m_signalPropagationSpeed
Definition: TRTProcessingOfStraw.h:128
TRTDigSettings::solenoidFieldStrength
double solenoidFieldStrength() const
Get solenoid field strength.
TRTDigCondBase::getStrawData
void getStrawData(const int &hitID, double &lowthreshold, double &noiseamplitude) const
Get straw data mixed condition is implemented function will return both Argon and Xenon straws (with ...
Definition: TRTDigCondBase.h:191
python.SystemOfUnits.MeV
int MeV
Definition: SystemOfUnits.py:154
TRTProcessingOfStraw::m_pPAItoolKr
ITRT_PAITool * m_pPAItoolKr
Definition: TRTProcessingOfStraw.h:122
TRTProcessingOfStraw::Initialize
void Initialize(const ITRT_CalDbTool *)
Initialize.
Definition: TRTProcessingOfStraw.cxx:88
M_PI
#define M_PI
Definition: ActiveFraction.h:11
InDetDD::TRT_EndcapElement
Definition: TRT_EndcapElement.h:44
TRTTimeCorrection::PropagationTime
void PropagationTime(const int &strawID, const double &meanZ, double &propagationTime1, double &propagationTime2)
Calculates the time between the signal reaching the wire and when it reaches the electronics.
Definition: TRTTimeCorrection.cxx:287
TimedHitPtr< TRTUncompressedHit >
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
TRTProcessingOfStraw::m_id_helper
const TRT_ID * m_id_helper
Definition: TRTProcessingOfStraw.h:238
drawFromPickle.exp
exp
Definition: drawFromPickle.py:36
TRTProcessingOfStraw::m_randBinomialXe
std::unique_ptr< CLHEP::RandBinomialFixedP > m_randBinomialXe
Definition: TRTProcessingOfStraw.h:233
TRTProcessingOfStraw::m_maxCrossingTime
double m_maxCrossingTime
Definition: TRTProcessingOfStraw.h:134
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
TRTDigSettings::jitterTimeOffset
double jitterTimeOffset() const
In cosmics, events not correlated with LHC clock.
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
TRTProcessingOfStraw::m_randBinomialAr
std::unique_ptr< CLHEP::RandBinomialFixedP > m_randBinomialAr
Definition: TRTProcessingOfStraw.h:235
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
TRTProcessingOfStraw::m_pSimDriftTimeTool
ITRT_SimDriftTimeTool * m_pSimDriftTimeTool
Definition: TRTProcessingOfStraw.h:123
TRTProcessingOfStraw::m_outerRadiusOfWire
double m_outerRadiusOfWire
Definition: TRTProcessingOfStraw.h:139
python.utils.AtlRunQueryLookup.mask
string mask
Definition: AtlRunQueryLookup.py:460
TRTDigSettings::smearingFactor
double smearingFactor(int strawGasType) const
Get smearing factor.
Trk::energyDeposit
@ energyDeposit
Definition: MeasurementType.h:32
TRTTimeCorrection::TimeShift
double TimeShift(const int &strawID)
Returns the time it would take to travel at light-speed from (0,0,0) to the farthest end of the wire ...
Definition: TRTTimeCorrection.cxx:96
dqt_zlumi_alleff_HIST.A
A
Definition: dqt_zlumi_alleff_HIST.py:110
python.SystemOfUnits.keV
int keV
Definition: SystemOfUnits.py:156
TRTProcessingOfStraw::addClustersFromStep
void addClustersFromStep(const double &scaledKineticEnergy, const double &particleCharge, const double &timeOfHit, const double &prex, const double &prey, const double &prez, const double &postx, const double &posty, const double &postz, std::vector< cluster > &clusterlist, int strawGasType, CLHEP::HepRandomEngine *rndmEngine, CLHEP::HepRandomEngine *paiRndmEngine)
This is the main function for re-simulation of the ionisation in the active gas via the PAI model.
Definition: TRTProcessingOfStraw.cxx:203
TRTProcessingOfStraw::m_useAttenuation
bool m_useAttenuation
Definition: TRTProcessingOfStraw.h:131
TRTDigSettings::trEfficiencyEndCapA
double trEfficiencyEndCapA(int strawGasType) const
Get assumed Transition Radiation efficiency in end caps.
AthMessaging::AthMessaging
AthMessaging()
Default constructor:
TRTProcessingOfStraw::m_settings
const TRTDigSettings * m_settings
Definition: TRTProcessingOfStraw.h:118
InDetDD::TRT_DetectorManager::getNumerology
TRT_Numerology * getNumerology()
Access Numerological information:---------------------------------------—.
Definition: TRT_DetectorManager.cxx:46
A
TRTProcessingOfStraw::m_maxelectrons
unsigned int m_maxelectrons
Definition: TRTProcessingOfStraw.h:227
InDetDD::TRT_Numerology
Definition: TRT_Numerology.h:22
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
TRTProcessingOfStraw::m_shiftOfZeroPoint
double m_shiftOfZeroPoint
Definition: TRTProcessingOfStraw.h:136
lumiFormat.i
int i
Definition: lumiFormat.py:85
TRTProcessingOfStraw::m_depositList
std::vector< TRTElectronicsProcessing::Deposit > m_depositList
Definition: TRTProcessingOfStraw.h:164
TRTProcessingOfStraw::m_pNoise
TRTNoise * m_pNoise
Definition: TRTProcessingOfStraw.h:146
isMonopole
bool isMonopole(const T &p)
PDG rule 11i Magnetic monopoles and dyons are assumed to have one unit of Dirac monopole charge and a...
Definition: AtlasPID.h:539
CaloNoise_fillDB.dt
dt
Definition: CaloNoise_fillDB.py:58
TRTDigSettings::attenuationLength
double attenuationLength() const
TRTDigSettings::lowThresholdBar
double lowThresholdBar(int strawGasType) const
Get discriminator setting for low threshold.
TRTProcessingOfStraw::m_timeCorrection
bool m_timeCorrection
Time to be corrected for flight and wire propagation delays false when beamType='cosmics'.
Definition: TRTProcessingOfStraw.h:126
TRTProcessingOfStraw::setClusterZ
double setClusterZ(double cluster_z_in, bool isLong, bool isShort, bool isEC) const
Definition: TRTProcessingOfStraw.cxx:812
jobOptions.ParticleID
ParticleID
Definition: jobOptions.decayer.py:85
TRTProcessingOfStraw::m_pParticleTable
const HepPDT::ParticleDataTable * m_pParticleTable
Definition: TRTProcessingOfStraw.h:149
drawFromPickle.tan
tan
Definition: drawFromPickle.py:36
TRTProcessingOfStraw::m_clusterlist
std::vector< cluster > m_clusterlist
Definition: TRTProcessingOfStraw.h:163
xAOD::double
double
Definition: CompositeParticle_v1.cxx:159
TRTProcessingOfStraw::m_useMagneticFieldMap
bool m_useMagneticFieldMap
Definition: TRTProcessingOfStraw.h:132
TRTDigit
Class for TRT digits.
Definition: TRTDigit.h:11
CLHEP::RandBinomialFixedP
Definition: RandBinomialFixedP.h:18
TRTProcessingOfStraw::m_pTimeCorrection
TRTTimeCorrection * m_pTimeCorrection
Definition: TRTProcessingOfStraw.h:144
compareGeometries.deltaX
float deltaX
Definition: compareGeometries.py:32
TRTDigSettings::innerRadiusOfStraw
double innerRadiusOfStraw() const
Get inner radius of straw.
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
TRTProcessingOfStraw::getGlobalPosition
Amg::Vector3D getGlobalPosition(int hitID, const TimedHitPtr< TRTUncompressedHit > *theHit)
Definition: TRTProcessingOfStraw.cxx:754
TRTDigSettings::noiseInSimhits
bool noiseInSimhits() const
Query whether simulation of noise in hit straws.
TRTProcessingOfStraw::m_solenoidFieldStrength
double m_solenoidFieldStrength
Definition: TRTProcessingOfStraw.h:141
trigbs_pickEvents.num
num
Definition: trigbs_pickEvents.py:76
InDetDD::TRT_DetectorManager::getEndcapElement
const TRT_EndcapElement * getEndcapElement(unsigned int positive, unsigned int wheelIndex, unsigned int strawLayerIndex, unsigned int phiIndex) const
Access Endcap Elements:---------------—(Fast)--------------------------—.
Definition: TRT_DetectorManager.cxx:119
TRTProcessingOfStraw::hitCollConstIter
TimedHitCollection< TRTUncompressedHit >::const_iterator hitCollConstIter
Definition: TRTProcessingOfStraw.h:74
python.PhysicalConstants.proton_mass_c2
float proton_mass_c2
Definition: PhysicalConstants.py:87
TRTDigSettings::trEfficiencyEndCapB
double trEfficiencyEndCapB(int strawGasType) const
TRTProcessingOfStraw::m_minCrossingTime
double m_minCrossingTime
Definition: TRTProcessingOfStraw.h:135
TRTDigSettings::numberOfCrossingsBeforeMain
unsigned int numberOfCrossingsBeforeMain() const
Get number of simulated bunch crossings before main event (pile up)
TRTProcessingOfStraw::m_randBinomialKr
std::unique_ptr< CLHEP::RandBinomialFixedP > m_randBinomialKr
Definition: TRTProcessingOfStraw.h:234
Amg::Vector3D
Eigen::Matrix< double, 3, 1 > Vector3D
Definition: GeoPrimitives.h:47
TRTProcessingOfStraw::m_attenuationLength
double m_attenuationLength
Definition: TRTProcessingOfStraw.h:129
TRTDigSettings::trEfficiencyBarrel
double trEfficiencyBarrel(int strawGasType) const
Get assumed Transition Radiation efficiency in barrel.
python.SystemOfUnits.mm
int mm
Definition: SystemOfUnits.py:83
python.PyAthena.v
v
Definition: PyAthena.py:154
TRTProcessingOfStraw::m_pPAItoolAr
ITRT_PAITool * m_pPAItoolAr
Definition: TRTProcessingOfStraw.h:121
InDetDD::TRT_BaseElement::strawTransform
const Amg::Transform3D & strawTransform(unsigned int straw) const
Straw transform - fast access in array, in Tracking frame: Amg.
Definition: TRT_BaseElement.cxx:89
TRTElectronicsProcessing::ProcessDeposits
void ProcessDeposits(const std::vector< Deposit > &, const int &hitID, TRTDigit &outdigit, double lowthreshold, const double &noiseamplitude, int strawGasType, CLHEP::HepRandomEngine *rndmEngine, CLHEP::HepRandomEngine *elecNoiseRndmEngine, double highthreshold=-1.0)
Process deposits in a straw.
Definition: TRTElectronicsProcessing.cxx:203
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
TRTDigSettings::timeInterval
double timeInterval() const
Get time interval covered by each digit.
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
ITRT_SimDriftTimeTool::getAverageDriftTime
virtual double getAverageDriftTime(const double &dist, const double &effectivefield_squared, int strawGasType=0) const =0
TRTTimeCorrection
Time correction.
Definition: TRTTimeCorrection.h:26
python.CaloCondTools.log
log
Definition: CaloCondTools.py:20
RunTileMonitoring.clusters
clusters
Definition: RunTileMonitoring.py:133
python.LArCondContChannels.isBarrel
isBarrel
Definition: LArCondContChannels.py:659
MagField::AtlasFieldCache::getField
void getField(const double *ATH_RESTRICT xyz, double *ATH_RESTRICT bxyz, double *ATH_RESTRICT deriv=nullptr)
get B field value at given position xyz[3] is in mm, bxyz[3] is in kT if deriv[9] is given,...
Definition: AtlasFieldCache.cxx:42
python.SystemOfUnits.ns
int ns
Definition: SystemOfUnits.py:130
TRTDigSettings::useAttenuation
bool useAttenuation() const
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
hitTime
float hitTime(const AFP_SIDSimHit &hit)
Definition: AFP_SIDSimHit.h:39
makeComparison.deltaZ
int deltaZ
Definition: makeComparison.py:46
TRTDigSettings::outerRadiusOfWire
double outerRadiusOfWire() const
Get radius of signal wire.
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
TRTDigSettings::signalPropagationSpeed
double signalPropagationSpeed() const
Get wire signal propagation speed.
TRTProcessingOfStraw::m_expattenuation
std::vector< double > m_expattenuation
Definition: TRTProcessingOfStraw.h:226
WriteCellNoiseToCool.noise
noise
Definition: WriteCellNoiseToCool.py:380
TRTDigSettings::ionisationPotential
double ionisationPotential(int strawGasType) const
Get ionisation potential.
TRTProcessingOfStraw::ClustersToDeposits
void ClustersToDeposits(MagField::AtlasFieldCache &fieldCache, const int &hitID, const std::vector< cluster > &clusters, std::vector< TRTElectronicsProcessing::Deposit > &deposits, Amg::Vector3D TRThitGlobalPos, double m_cosmicEventPhase, int strawGasType, CLHEP::HepRandomEngine *rndmEngine)
Transform the ioniation clusters along the particle trajectory inside a straw to energy deposits (i....
Definition: TRTProcessingOfStraw.cxx:545
fitman.k
k
Definition: fitman.py:528
TRTProcessingOfStraw::m_pPAItoolXe
ITRT_PAITool * m_pPAItoolXe
Definition: TRTProcessingOfStraw.h:120
TRTProcessingOfStraw::m_alreadywarnedagainstpdg0
bool m_alreadywarnedagainstpdg0
Definition: TRTProcessingOfStraw.h:229