Geant4 Cross Reference

Cross-Referencing   Geant4
Geant4/examples/advanced/lAr_calorimeter/src/FCALSteppingAction.cc

Version: [ ReleaseNotes ] [ 1.0 ] [ 1.1 ] [ 2.0 ] [ 3.0 ] [ 3.1 ] [ 3.2 ] [ 4.0 ] [ 4.0.p1 ] [ 4.0.p2 ] [ 4.1 ] [ 4.1.p1 ] [ 5.0 ] [ 5.0.p1 ] [ 5.1 ] [ 5.1.p1 ] [ 5.2 ] [ 5.2.p1 ] [ 5.2.p2 ] [ 6.0 ] [ 6.0.p1 ] [ 6.1 ] [ 6.2 ] [ 6.2.p1 ] [ 6.2.p2 ] [ 7.0 ] [ 7.0.p1 ] [ 7.1 ] [ 7.1.p1 ] [ 8.0 ] [ 8.0.p1 ] [ 8.1 ] [ 8.1.p1 ] [ 8.1.p2 ] [ 8.2 ] [ 8.2.p1 ] [ 8.3 ] [ 8.3.p1 ] [ 8.3.p2 ] [ 9.0 ] [ 9.0.p1 ] [ 9.0.p2 ] [ 9.1 ] [ 9.1.p1 ] [ 9.1.p2 ] [ 9.1.p3 ] [ 9.2 ] [ 9.2.p1 ] [ 9.2.p2 ] [ 9.2.p3 ] [ 9.2.p4 ] [ 9.3 ] [ 9.3.p1 ] [ 9.3.p2 ] [ 9.4 ] [ 9.4.p1 ] [ 9.4.p2 ] [ 9.4.p3 ] [ 9.4.p4 ] [ 9.5 ] [ 9.5.p1 ] [ 9.5.p2 ] [ 9.6 ] [ 9.6.p1 ] [ 9.6.p2 ] [ 9.6.p3 ] [ 9.6.p4 ] [ 10.0 ] [ 10.0.p1 ] [ 10.0.p2 ] [ 10.0.p3 ] [ 10.0.p4 ] [ 10.1 ] [ 10.1.p1 ] [ 10.1.p2 ] [ 10.1.p3 ] [ 10.2 ] [ 10.2.p1 ] [ 10.2.p2 ] [ 10.2.p3 ] [ 10.3 ] [ 10.3.p1 ] [ 10.3.p2 ] [ 10.3.p3 ] [ 10.4 ] [ 10.4.p1 ] [ 10.4.p2 ] [ 10.4.p3 ] [ 10.5 ] [ 10.5.p1 ] [ 10.6 ] [ 10.6.p1 ] [ 10.6.p2 ] [ 10.6.p3 ] [ 10.7 ] [ 10.7.p1 ] [ 10.7.p2 ] [ 10.7.p3 ] [ 10.7.p4 ] [ 11.0 ] [ 11.0.p1 ] [ 11.0.p2 ] [ 11.0.p3, ] [ 11.0.p4 ] [ 11.1 ] [ 11.1.1 ] [ 11.1.2 ] [ 11.1.3 ] [ 11.2 ] [ 11.2.1 ] [ 11.2.2 ] [ 11.3.0 ]

Diff markup

Differences between /examples/advanced/lAr_calorimeter/src/FCALSteppingAction.cc (Version 11.3.0) and /examples/advanced/lAr_calorimeter/src/FCALSteppingAction.cc (Version 10.4)


  1 //                                                  1 //
  2 // *******************************************      2 // ********************************************************************
  3 // * License and Disclaimer                         3 // * License and Disclaimer                                           *
  4 // *                                                4 // *                                                                  *
  5 // * The  Geant4 software  is  copyright of th      5 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
  6 // * the Geant4 Collaboration.  It is provided      6 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
  7 // * conditions of the Geant4 Software License      7 // * conditions of the Geant4 Software License,  included in the file *
  8 // * LICENSE and available at  http://cern.ch/      8 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
  9 // * include a list of copyright holders.           9 // * include a list of copyright holders.                             *
 10 // *                                               10 // *                                                                  *
 11 // * Neither the authors of this software syst     11 // * Neither the authors of this software system, nor their employing *
 12 // * institutes,nor the agencies providing fin     12 // * institutes,nor the agencies providing financial support for this *
 13 // * work  make  any representation or  warran     13 // * work  make  any representation or  warranty, express or implied, *
 14 // * regarding  this  software system or assum     14 // * regarding  this  software system or assume any liability for its *
 15 // * use.  Please see the license in the file      15 // * use.  Please see the license in the file  LICENSE  and URL above *
 16 // * for the full disclaimer and the limitatio     16 // * for the full disclaimer and the limitation of liability.         *
 17 // *                                               17 // *                                                                  *
 18 // * This  code  implementation is the result      18 // * This  code  implementation is the result of  the  scientific and *
 19 // * technical work of the GEANT4 collaboratio     19 // * technical work of the GEANT4 collaboration.                      *
 20 // * By using,  copying,  modifying or  distri     20 // * By using,  copying,  modifying or  distributing the software (or *
 21 // * any work based  on the software)  you  ag     21 // * any work based  on the software)  you  agree  to acknowledge its *
 22 // * use  in  resulting  scientific  publicati     22 // * use  in  resulting  scientific  publications,  and indicate your *
 23 // * acceptance of all terms of the Geant4 Sof     23 // * acceptance of all terms of the Geant4 Software license.          *
 24 // *******************************************     24 // ********************************************************************
 25 //                                                 25 //
                                                   >>  26 // $Id: FCALSteppingAction.cc 67976 2013-03-13 10:23:17Z gcosmo $
 26 //                                                 27 //
 27 //                                                 28 // 
 28                                                    29 
 29 //....oooOO0OOooo........oooOO0OOooo........oo     30 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
 30 //....oooOO0OOooo........oooOO0OOooo........oo     31 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
 31                                                    32 
 32 #include <iostream>                                33 #include <iostream>
 33                                                    34 
 34 #include "FCALSteppingAction.hh"                   35 #include "FCALSteppingAction.hh"
 35 #include "G4SteppingManager.hh"                    36 #include "G4SteppingManager.hh"
 36                                                    37 
 37 #include "globals.hh"                              38 #include "globals.hh"
 38 #include "G4SystemOfUnits.hh"                      39 #include "G4SystemOfUnits.hh"
 39 #include "G4Track.hh"                              40 #include "G4Track.hh"
 40 #include "G4DynamicParticle.hh"                    41 #include "G4DynamicParticle.hh"
 41 #include "G4Material.hh"                           42 #include "G4Material.hh"
 42                                                    43 
 43 #include "G4LogicalVolume.hh"                      44 #include "G4LogicalVolume.hh"
 44 #include "G4VPhysicalVolume.hh"                    45 #include "G4VPhysicalVolume.hh"
 45 #include "G4VTouchable.hh"                         46 #include "G4VTouchable.hh"
 46 #include "G4TouchableHistory.hh"                   47 #include "G4TouchableHistory.hh"
 47                                                    48 
 48 #include "G4Event.hh"                              49 #include "G4Event.hh"
 49                                                    50 
 50 #include "G4ThreeVector.hh"                        51 #include "G4ThreeVector.hh"
 51                                                    52 
 52 #include "G4ios.hh"                                53 #include "G4ios.hh"
 53                                                    54 
 54 //....oooOO0OOooo........oooOO0OOooo........oo     55 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
 55                                                    56 
 56 FCALSteppingAction::FCALSteppingAction():IDold     57 FCALSteppingAction::FCALSteppingAction():IDold(-1),IDout(-1)
 57 {;}                                                58 {;}
 58                                                    59 
 59 //....oooOO0OOooo........oooOO0OOooo........oo     60 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
 60                                                    61 
 61 FCALSteppingAction::~FCALSteppingAction()          62 FCALSteppingAction::~FCALSteppingAction()
 62 {;}                                                63 {;}
 63                                                    64 
 64 //....oooOO0OOooo........oooOO0OOooo........oo     65 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
 65                                                    66 
 66 void FCALSteppingAction::UserSteppingAction(co     67 void FCALSteppingAction::UserSteppingAction(const G4Step* astep)
 67 {                                                  68 { 
 68   // Get Edep                                      69   // Get Edep
 69    G4double Edep = astep->GetTotalEnergyDeposi     70    G4double Edep = astep->GetTotalEnergyDeposit();
 70                                                    71 
 71    // Get Track                                    72    // Get Track
 72      G4Track* aTrack = astep->GetTrack();          73      G4Track* aTrack = astep->GetTrack();
 73                                                    74 
 74    // Get Touchable History                        75    // Get Touchable History
 75   G4TouchableHistory* theTouchable =  (G4Touch     76   G4TouchableHistory* theTouchable =  (G4TouchableHistory*)(aTrack->GetTouchable());
 76                                                    77 
 77   // Energy deposit in FCAL1 and FCAL2             78   // Energy deposit in FCAL1 and FCAL2
 78   if(Edep != 0.)                                   79   if(Edep != 0.) 
 79     {                                              80     {
 80       G4VPhysicalVolume* physVol = theTouchabl     81       G4VPhysicalVolume* physVol = theTouchable->GetVolume();
 81                                                    82       
 82       if(strcmp(physVol->GetName(),"FCALEmModu     83       if(strcmp(physVol->GetName(),"FCALEmModulePhysical")== 0 ||
 83    strcmp(physVol->GetName(),"F1LArGapPhysical     84    strcmp(physVol->GetName(),"F1LArGapPhysical") == 0) 
 84   {                                                85   {
 85     EdepFCALEm = EdepFCALEm + Edep;                86     EdepFCALEm = EdepFCALEm + Edep;
 86   };                                               87   };
 87                                                    88       
 88       if( (strcmp(physVol->GetName(), "FCALHad     89       if( (strcmp(physVol->GetName(), "FCALHadModulePhysical") == 0) ||
 89     (strcmp(physVol->GetName(), "CuPlateAPhysi     90     (strcmp(physVol->GetName(), "CuPlateAPhysical") == 0) ||
 90     (strcmp(physVol->GetName(), "CuPlateBPhysi     91     (strcmp(physVol->GetName(), "CuPlateBPhysical") == 0) ||
 91     (strcmp(physVol->GetName(), "WAbsorberPhys     92     (strcmp(physVol->GetName(), "WAbsorberPhysical") == 0) ||
 92     (strcmp(physVol->GetName(), "F2RodPhysical     93     (strcmp(physVol->GetName(), "F2RodPhysical") == 0) ||
 93     (strcmp(physVol->GetName(), "F2LArGapPhysi     94     (strcmp(physVol->GetName(), "F2LArGapPhysical") == 0) ) 
 94   {                                                95   {
 95     EdepFCALHad = EdepFCALHad + Edep;              96     EdepFCALHad = EdepFCALHad + Edep;
 96   };                                               97   };
 97     };                                             98     };
 98                                                    99 
 99   // Get Tracks properties                        100   // Get Tracks properties
100   G4int TrackID = aTrack->GetTrackID();           101   G4int TrackID = aTrack->GetTrackID();
101   G4int ParentID = aTrack->GetParentID();         102   G4int ParentID = aTrack->GetParentID();
102   // Get Associated particle                      103   // Get Associated particle
103   const G4DynamicParticle * aDynamicParticle =    104   const G4DynamicParticle * aDynamicParticle = aTrack->GetDynamicParticle();
104   G4ParticleDefinition * aParticle = aTrack->G    105   G4ParticleDefinition * aParticle = aTrack->GetDefinition();
105   G4String ParticleName = aParticle->GetPartic    106   G4String ParticleName = aParticle->GetParticleName();
106                                                   107   
107   IDnow = EventNo + 10000*TrackID+ 100000000*P    108   IDnow = EventNo + 10000*TrackID+ 100000000*ParentID;
108                                                   109   
109   if(IDnow != IDold)                              110   if(IDnow != IDold)
110     {                                             111     {
111       IDold = IDnow;                              112       IDold = IDnow;
112                                                   113       
113       // Get the primary particle                 114       // Get the primary particle
114       if(TrackID==1 && ParentID==0 && (aTrack-    115       if(TrackID==1 && ParentID==0 && (aTrack->GetCurrentStepNumber()) == 1)
115   {                                               116   {
116     PrimaryVertex    = aTrack->GetVertexPositi    117     PrimaryVertex    = aTrack->GetVertexPosition(); 
117     PrimaryDirection = aTrack->GetVertexMoment    118     PrimaryDirection = aTrack->GetVertexMomentumDirection();
118                                                   119     
119     NSecondaries = 1;                             120     NSecondaries = 1;   
120     Secondaries[NSecondaries][1] = aParticle->    121     Secondaries[NSecondaries][1] = aParticle->GetPDGEncoding();
121     Secondaries[NSecondaries][2] = PrimaryVert    122     Secondaries[NSecondaries][2] = PrimaryVertex.x();
122     Secondaries[NSecondaries][3] = PrimaryVert    123     Secondaries[NSecondaries][3] = PrimaryVertex.y();
123     Secondaries[NSecondaries][4] = PrimaryVert    124     Secondaries[NSecondaries][4] = PrimaryVertex.z();
124     Secondaries[NSecondaries][5] = (aDynamicPa    125     Secondaries[NSecondaries][5] = (aDynamicParticle->GetMomentum()).x(); 
125     Secondaries[NSecondaries][6] = (aDynamicPa    126     Secondaries[NSecondaries][6] = (aDynamicParticle->GetMomentum()).y();
126     Secondaries[NSecondaries][7] = (aDynamicPa    127     Secondaries[NSecondaries][7] = (aDynamicParticle->GetMomentum()).z();
127     Secondaries[NSecondaries][8] = aDynamicPar    128     Secondaries[NSecondaries][8] = aDynamicParticle->GetTotalMomentum();
128     Secondaries[NSecondaries][9] = aDynamicPar    129     Secondaries[NSecondaries][9] = aDynamicParticle->GetTotalEnergy();
129     Secondaries[NSecondaries][10] = aDynamicPa    130     Secondaries[NSecondaries][10] = aDynamicParticle->GetKineticEnergy();
130                                                   131     
131     G4cout << " ****  Primary : " << EventNo <    132     G4cout << " ****  Primary : " << EventNo << G4endl;
132     G4cout << " Vertex : " << PrimaryVertex <<    133     G4cout << " Vertex : " << PrimaryVertex << G4endl;
133   }                                               134   }
134                                                   135       
135                                                   136       
136       // Get secondaries in air close to the p    137       // Get secondaries in air close to the primary tracks (DCA < 2.mm) 
137       G4double DCACut = 2.*mm;                    138       G4double DCACut = 2.*mm;
138       G4String Material = aTrack->GetMaterial(    139       G4String Material = aTrack->GetMaterial()->GetName();
139       G4ThreeVector TrackPos = aTrack->GetVert    140       G4ThreeVector TrackPos = aTrack->GetVertexPosition();
140                                                   141       
141       if(TrackID != 1 && ParentID == 1 && (str    142       if(TrackID != 1 && ParentID == 1 && (strcmp(Material,"Air")==0) && (TrackPos.z() > 135.*cm)) 
142   {                                               143   {
143     SecondaryVertex = aTrack->GetVertexPositio    144     SecondaryVertex = aTrack->GetVertexPosition();
144     SecondaryDirection = aTrack->GetVertexMome    145     SecondaryDirection = aTrack->GetVertexMomentumDirection();
145                                                   146     
146     // calculate DCA of secondries to primary     147     // calculate DCA of secondries to primary particle
147     Distance = PrimaryVertex - SecondaryVertex    148     Distance = PrimaryVertex - SecondaryVertex ;
148     VectorProduct = PrimaryDirection.cross(Sec    149     VectorProduct = PrimaryDirection.cross(SecondaryDirection);
149     if(VectorProduct == G4ThreeVector() &&        150     if(VectorProduct == G4ThreeVector() &&  
150        PrimaryDirection != G4ThreeVector() &&     151        PrimaryDirection != G4ThreeVector() && SecondaryDirection != G4ThreeVector()) 
151       {                                           152       {
152         G4ThreeVector Temp = Distance.cross(Pr    153         G4ThreeVector Temp = Distance.cross(PrimaryDirection);
153         VectorProduct = Temp.cross(PrimaryDire    154         VectorProduct = Temp.cross(PrimaryDirection);
154       };                                          155       };    
155                                                   156         
156 VectorProductMagnitude = VectorProduct.mag();     157 VectorProductMagnitude = VectorProduct.mag();
157     if(VectorProductMagnitude == 0.)              158     if(VectorProductMagnitude == 0.) 
158       {                                           159       {
159         VectorProductNorm = G4ThreeVector();      160         VectorProductNorm = G4ThreeVector();
160       } else {                                    161       } else {
161         VectorProductNorm = (1./VectorProduct.    162         VectorProductNorm = (1./VectorProduct.mag()) * VectorProduct ;
162       };                                          163       };    
163     DistOfClosestApproach = Distance * VectorP    164     DistOfClosestApproach = Distance * VectorProductNorm ;
164                                                   165     
165     if(std::abs(DistOfClosestApproach) < DCACu    166     if(std::abs(DistOfClosestApproach) < DCACut) 
166       {                                           167       {
167         NSecondaries++;                           168         NSecondaries++;       
168         Secondaries[0][0] = NSecondaries;         169         Secondaries[0][0] = NSecondaries;
169         Secondaries[NSecondaries][1] = aPartic    170         Secondaries[NSecondaries][1] = aParticle->GetPDGEncoding();
170         Secondaries[NSecondaries][2] = (aTrack    171         Secondaries[NSecondaries][2] = (aTrack->GetVertexPosition()).x();
171         Secondaries[NSecondaries][3] = (aTrack    172         Secondaries[NSecondaries][3] = (aTrack->GetVertexPosition()).y();
172         Secondaries[NSecondaries][4] = (aTrack    173         Secondaries[NSecondaries][4] = (aTrack->GetVertexPosition()).z();
173         Secondaries[NSecondaries][5] =(aDynami    174         Secondaries[NSecondaries][5] =(aDynamicParticle->GetMomentum()).x(); 
174         Secondaries[NSecondaries][6] = (aDynam    175         Secondaries[NSecondaries][6] = (aDynamicParticle->GetMomentum()).y();
175         Secondaries[NSecondaries][7] = (aDynam    176         Secondaries[NSecondaries][7] = (aDynamicParticle->GetMomentum()).z();
176         Secondaries[NSecondaries][8] = aDynami    177         Secondaries[NSecondaries][8] = aDynamicParticle->GetTotalMomentum();
177         Secondaries[NSecondaries][9] = aDynami    178         Secondaries[NSecondaries][9] = aDynamicParticle->GetTotalEnergy();
178         Secondaries[NSecondaries][10] =aDynami    179         Secondaries[NSecondaries][10] =aDynamicParticle->GetKineticEnergy();
179       };                                          180       };  
180   };                                              181   };
181     };                                            182     };
182                                                   183 
183                                                   184 
184   // Get the World leaving particle               185   // Get the World leaving particle
185   if(aTrack->GetNextVolume() == 0) {              186   if(aTrack->GetNextVolume() == 0) {
186     if(IDnow != IDout) {                          187     if(IDnow != IDout) {
187       IDout = IDnow;                              188       IDout = IDnow;
188                                                   189 
189       NTracks++;                                  190       NTracks++;
190                                                   191 
191       OutOfWorldTracksData[0][0] = NTracks;       192       OutOfWorldTracksData[0][0] = NTracks;
192                                                   193 
193       OutOfWorldTracksData[NTracks][1] = aPart    194       OutOfWorldTracksData[NTracks][1] = aParticle->GetPDGEncoding();
194                                                   195 
195       OutOfWorldTracksData[NTracks][2] = (aTra    196       OutOfWorldTracksData[NTracks][2] = (aTrack->GetVertexPosition()).x();
196       OutOfWorldTracksData[NTracks][3] = (aTra    197       OutOfWorldTracksData[NTracks][3] = (aTrack->GetVertexPosition()).y();
197       OutOfWorldTracksData[NTracks][4] = (aTra    198       OutOfWorldTracksData[NTracks][4] = (aTrack->GetVertexPosition()).z();
198                                                   199 
199       OutOfWorldTracksData[NTracks][5] = (aDyn    200       OutOfWorldTracksData[NTracks][5] = (aDynamicParticle->GetMomentum()).x();
200       OutOfWorldTracksData[NTracks][6] = (aDyn    201       OutOfWorldTracksData[NTracks][6] = (aDynamicParticle->GetMomentum()).y();
201       OutOfWorldTracksData[NTracks][7] = (aDyn    202       OutOfWorldTracksData[NTracks][7] = (aDynamicParticle->GetMomentum()).z();
202                                                   203       
203       OutOfWorldTracksData[NTracks][8] = aDyna    204       OutOfWorldTracksData[NTracks][8] = aDynamicParticle->GetTotalMomentum();
204                                                   205 
205       OutOfWorldTracksData[NTracks][9] = aDyna    206       OutOfWorldTracksData[NTracks][9] = aDynamicParticle->GetTotalEnergy();
206                                                   207 
207       OutOfWorldTracksData[NTracks][10] = aDyn    208       OutOfWorldTracksData[NTracks][10] = aDynamicParticle->GetKineticEnergy();      
208     };                                            209     };
209   };                                              210   };
210                                                   211   
211                                                   212  
212 }                                                 213 }
213                                                   214 
214 void FCALSteppingAction::initialize(G4int Nev)    215 void FCALSteppingAction::initialize(G4int Nev) {
215   EventNo = Nev;                                  216   EventNo = Nev;
216   NTracks = 0;                                    217   NTracks = 0;
217   NSecondaries = 0;                               218   NSecondaries = 0;
218   EdepFCALEm = EdepFCALHad = 0.;                  219   EdepFCALEm = EdepFCALHad = 0.;
219                                                   220 
220   for(G4int i=0; i<6000; i++)                     221   for(G4int i=0; i<6000; i++)
221     {                                             222     {
222       for(G4int j=0; j<11; j++)                   223       for(G4int j=0; j<11; j++) 
223   {                                               224   { 
224     OutOfWorldTracksData[i][j] = 0.;              225     OutOfWorldTracksData[i][j] = 0.;
225     Secondaries[i][j] = 0.;                       226     Secondaries[i][j] = 0.; 
226   }                                               227   }
227     };                                            228     };
228 }                                                 229 }
229                                                   230 
230 G4double FCALSteppingAction::GetOutOfWorldTrac    231 G4double FCALSteppingAction::GetOutOfWorldTracks(G4int i, G4int j){
231   return OutOfWorldTracksData[i][j];              232   return OutOfWorldTracksData[i][j];
232 }                                                 233 }
233                                                   234 
234 G4double FCALSteppingAction::GetSecondaries(G4    235 G4double FCALSteppingAction::GetSecondaries(G4int i, G4int j){
235   return Secondaries[i][j];                       236   return Secondaries[i][j];
236 }                                                 237 }
237                                                   238 
238 G4double FCALSteppingAction::GetEdepFCAL(G4Str    239 G4double FCALSteppingAction::GetEdepFCAL(G4String FCAL) {
239   if(strcmp(FCAL,"FCALEm") == 0) {                240   if(strcmp(FCAL,"FCALEm") == 0) {
240     return EdepFCALEm;                            241     return EdepFCALEm;
241   } else {                                        242   } else {
242     if(strcmp(FCAL,"FCALHad") == 0) {             243     if(strcmp(FCAL,"FCALHad") == 0) {
243       return EdepFCALHad;}                        244       return EdepFCALHad;}
244   }                                               245   }
245   return 0.0;                                     246   return 0.0; 
246 }                                                 247 } 
247                                                   248 
248                                                   249 
249 //....oooOO0OOooo........oooOO0OOooo........oo    250 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo....
250                                                   251 
251                                                   252 
252                                                   253 
253                                                   254