Geant4 Cross Reference |
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 /// \file Run.cc 26 /// \file Run.cc 27 /// \brief Implementation of the Run class 27 /// \brief Implementation of the Run class 28 // 28 // 29 // << 29 // 30 //....oooOO0OOooo........oooOO0OOooo........oo 30 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 31 //....oooOO0OOooo........oooOO0OOooo........oo 31 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 32 32 33 #include "Run.hh" 33 #include "Run.hh" 34 << 35 #include "DetectorConstruction.hh" 34 #include "DetectorConstruction.hh" 36 #include "HistoManager.hh" << 37 #include "PrimaryGeneratorAction.hh" 35 #include "PrimaryGeneratorAction.hh" >> 36 #include "HistoManager.hh" 38 37 39 #include "G4SystemOfUnits.hh" << 40 #include "G4UnitsTable.hh" 38 #include "G4UnitsTable.hh" >> 39 #include "G4SystemOfUnits.hh" 41 40 42 //....oooOO0OOooo........oooOO0OOooo........oo 41 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 43 42 44 Run::Run(DetectorConstruction* det) : fDetecto << 43 Run::Run(DetectorConstruction* det) >> 44 : G4Run(), >> 45 fDetector(det), fParticle(0), fEkin(0.), >> 46 fNbStep1(0), fNbStep2(0), >> 47 fTrackLen1(0.), fTrackLen2(0.), >> 48 fTime1(0.),fTime2(0.) >> 49 { } >> 50 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... >> 51 >> 52 Run::~Run() >> 53 { } 45 54 46 //....oooOO0OOooo........oooOO0OOooo........oo 55 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 47 56 48 void Run::SetPrimary(G4ParticleDefinition* par 57 void Run::SetPrimary(G4ParticleDefinition* particle, G4double energy) 49 { << 58 { 50 fParticle = particle; 59 fParticle = particle; 51 fEkin = energy; 60 fEkin = energy; 52 } << 61 } 53 62 54 //....oooOO0OOooo........oooOO0OOooo........oo 63 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 55 64 56 void Run::CountProcesses(const G4VProcess* pro << 65 void Run::CountProcesses(const G4VProcess* process) 57 { 66 { 58 if (process == nullptr) return; 67 if (process == nullptr) return; 59 G4String procName = process->GetProcessName( 68 G4String procName = process->GetProcessName(); 60 std::map<G4String, G4int>::iterator it = fPr << 69 std::map<G4String,G4int>::iterator it = fProcCounter.find(procName); 61 if (it == fProcCounter.end()) { << 70 if ( it == fProcCounter.end()) { 62 fProcCounter[procName] = 1; 71 fProcCounter[procName] = 1; 63 } 72 } 64 else { 73 else { 65 fProcCounter[procName]++; << 74 fProcCounter[procName]++; 66 } 75 } 67 } << 76 } 68 << 77 69 //....oooOO0OOooo........oooOO0OOooo........oo 78 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 70 79 71 void Run::ParticleCount(G4String name, G4doubl 80 void Run::ParticleCount(G4String name, G4double Ekin) 72 { 81 { 73 std::map<G4String, ParticleData>::iterator i 82 std::map<G4String, ParticleData>::iterator it = fParticleDataMap.find(name); 74 if (it == fParticleDataMap.end()) { << 83 if ( it == fParticleDataMap.end()) { 75 fParticleDataMap[name] = ParticleData(1, E 84 fParticleDataMap[name] = ParticleData(1, Ekin, Ekin, Ekin); 76 } 85 } 77 else { 86 else { 78 ParticleData& data = it->second; 87 ParticleData& data = it->second; 79 data.fCount++; 88 data.fCount++; 80 data.fEmean += Ekin; 89 data.fEmean += Ekin; 81 // update min max << 90 //update min max 82 G4double emin = data.fEmin; 91 G4double emin = data.fEmin; 83 if (Ekin < emin) data.fEmin = Ekin; 92 if (Ekin < emin) data.fEmin = Ekin; 84 G4double emax = data.fEmax; 93 G4double emax = data.fEmax; 85 if (Ekin > emax) data.fEmax = Ekin; << 94 if (Ekin > emax) data.fEmax = Ekin; 86 } << 95 } 87 } 96 } 88 97 89 //....oooOO0OOooo........oooOO0OOooo........oo 98 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 90 99 91 void Run::SumTrackLength(G4int nstep1, G4int n << 100 void Run::SumTrackLength(G4int nstep1, G4int nstep2, >> 101 G4double trackl1, G4double trackl2, 92 G4double time1, G4dou 102 G4double time1, G4double time2) 93 { 103 { 94 fNbStep1 += nstep1; << 104 fNbStep1 += nstep1; fNbStep2 += nstep2; 95 fNbStep2 += nstep2; << 105 fTrackLen1 += trackl1; fTrackLen2 += trackl2; 96 fTrackLen1 += trackl1; << 106 fTime1 += time1; fTime2 += time2; 97 fTrackLen2 += trackl2; << 98 fTime1 += time1; << 99 fTime2 += time2; << 100 } 107 } 101 108 102 //....oooOO0OOooo........oooOO0OOooo........oo 109 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 103 110 104 void Run::Merge(const G4Run* run) 111 void Run::Merge(const G4Run* run) 105 { 112 { 106 const Run* localRun = static_cast<const Run* 113 const Run* localRun = static_cast<const Run*>(run); 107 << 114 108 // primary particle info << 115 //primary particle info 109 // 116 // 110 fParticle = localRun->fParticle; 117 fParticle = localRun->fParticle; 111 fEkin = localRun->fEkin; << 118 fEkin = localRun->fEkin; 112 << 119 113 // accumulate sums 120 // accumulate sums 114 // 121 // 115 fNbStep1 += localRun->fNbStep1; << 122 fNbStep1 += localRun->fNbStep1; 116 fNbStep2 += localRun->fNbStep2; << 123 fNbStep2 += localRun->fNbStep2; 117 fTrackLen1 += localRun->fTrackLen1; << 124 fTrackLen1 += localRun->fTrackLen1; 118 fTrackLen2 += localRun->fTrackLen2; 125 fTrackLen2 += localRun->fTrackLen2; 119 fTime1 += localRun->fTime1; << 126 fTime1 += localRun->fTime1; 120 fTime2 += localRun->fTime2; << 127 fTime2 += localRun->fTime2; >> 128 >> 129 //map: processes count >> 130 std::map<G4String,G4int>::const_iterator itp; >> 131 for ( itp = localRun->fProcCounter.begin(); >> 132 itp != localRun->fProcCounter.end(); ++itp ) { 121 133 122 // map: processes count << 123 std::map<G4String, G4int>::const_iterator it << 124 for (itp = localRun->fProcCounter.begin(); i << 125 G4String procName = itp->first; 134 G4String procName = itp->first; 126 G4int localCount = itp->second; 135 G4int localCount = itp->second; 127 if (fProcCounter.find(procName) == fProcCo << 136 if ( fProcCounter.find(procName) == fProcCounter.end()) { 128 fProcCounter[procName] = localCount; 137 fProcCounter[procName] = localCount; 129 } 138 } 130 else { 139 else { 131 fProcCounter[procName] += localCount; 140 fProcCounter[procName] += localCount; 132 } << 141 } 133 } 142 } 134 << 143 135 // map: created particles count << 144 //map: created particles count 136 std::map<G4String, ParticleData>::const_iter << 145 std::map<G4String,ParticleData>::const_iterator itn; 137 for (itn = localRun->fParticleDataMap.begin( << 146 for (itn = localRun->fParticleDataMap.begin(); >> 147 itn != localRun->fParticleDataMap.end(); ++itn) { >> 148 138 G4String name = itn->first; 149 G4String name = itn->first; 139 const ParticleData& localData = itn->secon << 150 const ParticleData& localData = itn->second; 140 if (fParticleDataMap.find(name) == fPartic << 151 if ( fParticleDataMap.find(name) == fParticleDataMap.end()) { 141 fParticleDataMap[name] = << 152 fParticleDataMap[name] 142 ParticleData(localData.fCount, localDa << 153 = ParticleData(localData.fCount, >> 154 localData.fEmean, >> 155 localData.fEmin, >> 156 localData.fEmax); 143 } 157 } 144 else { 158 else { 145 ParticleData& data = fParticleDataMap[na << 159 ParticleData& data = fParticleDataMap[name]; 146 data.fCount += localData.fCount; 160 data.fCount += localData.fCount; 147 data.fEmean += localData.fEmean; 161 data.fEmean += localData.fEmean; 148 G4double emin = localData.fEmin; 162 G4double emin = localData.fEmin; 149 if (emin < data.fEmin) data.fEmin = emin 163 if (emin < data.fEmin) data.fEmin = emin; 150 G4double emax = localData.fEmax; 164 G4double emax = localData.fEmax; 151 if (emax > data.fEmax) data.fEmax = emax << 165 if (emax > data.fEmax) data.fEmax = emax; 152 } << 166 } 153 } 167 } 154 168 155 G4Run::Merge(run); << 169 G4Run::Merge(run); 156 } << 170 } 157 171 158 //....oooOO0OOooo........oooOO0OOooo........oo 172 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 159 173 160 void Run::EndOfRun() << 174 void Run::EndOfRun() 161 { 175 { 162 G4int prec = 5, wid = prec + 2; << 176 G4int prec = 5, wid = prec + 2; 163 G4int dfprec = G4cout.precision(prec); 177 G4int dfprec = G4cout.precision(prec); 164 << 178 165 // run condition << 179 //run condition 166 // 180 // 167 G4Material* material = fDetector->GetMateria 181 G4Material* material = fDetector->GetMaterial(); 168 G4double density = material->GetDensity(); 182 G4double density = material->GetDensity(); 169 << 183 170 G4String Particle = fParticle->GetParticleNa << 184 G4String Particle = fParticle->GetParticleName(); 171 G4cout << "\n The run is " << numberOfEvent << 185 G4cout << "\n The run is " << numberOfEvent << " "<< Particle << " of " 172 << G4BestUnit(fEkin, "Energy") << " t << 186 << G4BestUnit(fEkin,"Energy") << " through " 173 << G4BestUnit(0.5 * (fDetector->GetSi << 187 << G4BestUnit(0.5*(fDetector->GetSize()),"Length") << " of " 174 << " (density: " << G4BestUnit(densit << 188 << material->GetName() << " (density: " 175 << 189 << G4BestUnit(density,"Volumic Mass") << ")" << G4endl; 176 if (numberOfEvent == 0) { << 190 177 G4cout.precision(dfprec); << 191 if (numberOfEvent == 0) { G4cout.precision(dfprec); return;} 178 return; << 192 179 } << 193 //frequency of processes 180 << 181 // frequency of processes << 182 // 194 // 183 G4cout << "\n Process calls frequency :" << << 195 G4cout << "\n Process calls frequency :" << G4endl; 184 G4int survive = 0; 196 G4int survive = 0; 185 std::map<G4String, G4int>::iterator it; << 197 std::map<G4String,G4int>::iterator it; 186 for (it = fProcCounter.begin(); it != fProcC 198 for (it = fProcCounter.begin(); it != fProcCounter.end(); it++) { 187 G4String procName = it->first; << 199 G4String procName = it->first; 188 G4int count = it->second; << 200 G4int count = it->second; 189 G4cout << "\t" << procName << "= " << coun << 201 G4cout << "\t" << procName << "= " << count; 190 if (procName == "Transportation") survive << 202 if (procName == "Transportation") survive = count; 191 } 203 } 192 G4cout << G4endl; 204 G4cout << G4endl; 193 << 205 194 if (survive > 0) { 206 if (survive > 0) { 195 G4cout << "\n Nb of incident particles sur 207 G4cout << "\n Nb of incident particles surviving after " 196 << G4BestUnit(0.5 * (fDetector->Get << 208 << G4BestUnit(0.5*(fDetector->GetSize()),"Length") << " of " 197 << fDetector->GetMaterial()->GetNam 209 << fDetector->GetMaterial()->GetName() << " : " << survive << G4endl; 198 } 210 } 199 211 200 // total track length of incident neutron << 212 // total track length of incident neutron 201 // << 213 // 202 G4cout << "\n Parcours of incident neutron:" << 214 G4cout << "\n Parcours of incident neutron:"; 203 << 215 204 G4double meanCollision1 = (G4double)fNbStep1 << 216 G4double meanCollision1 = (G4double)fNbStep1/numberOfEvent; 205 G4double meanCollision2 = (G4double)fNbStep2 << 217 G4double meanCollision2 = (G4double)fNbStep2/numberOfEvent; 206 G4double meanCollisTota = meanCollision1 + m << 218 G4double meanCollisTota = meanCollision1 + meanCollision2; 207 << 219 208 G4cout << "\n nb of collisions E>1*eV= << 220 G4cout << "\n nb of collisions E>1*eV= " << meanCollision1 209 << " E<1*eV= " << meanCollision2 << 221 << " E<1*eV= " << meanCollision2 210 << 222 << " total= " << meanCollisTota; 211 G4double meanTrackLen1 = fTrackLen1 / number << 223 212 G4double meanTrackLen2 = fTrackLen2 / number << 224 G4double meanTrackLen1 = fTrackLen1/numberOfEvent; 213 G4double meanTrackLtot = meanTrackLen1 + mea << 225 G4double meanTrackLen2 = fTrackLen2/numberOfEvent; 214 << 226 G4double meanTrackLtot = meanTrackLen1 + meanTrackLen2; 215 G4cout << "\n track length E>1*eV= << 227 216 << " E<1*eV= " << G4BestUnit(meanTra << 228 G4cout 217 << " total= " << G4BestUnit(meanTra << 229 << "\n track length E>1*eV= " << G4BestUnit(meanTrackLen1,"Length") 218 << 230 << " E<1*eV= " << G4BestUnit(meanTrackLen2, "Length") 219 G4double meanTime1 = fTime1 / numberOfEvent; << 231 << " total= " << G4BestUnit(meanTrackLtot, "Length"); 220 G4double meanTime2 = fTime2 / numberOfEvent; << 232 221 G4double meanTimeTo = meanTime1 + meanTime2; << 233 G4double meanTime1 = fTime1/numberOfEvent; 222 << 234 G4double meanTime2 = fTime2/numberOfEvent; 223 G4cout << "\n time of flight E>1*eV= << 235 G4double meanTimeTo = meanTime1 + meanTime2; 224 << " E<1*eV= " << G4BestUnit(meanTim << 236 225 << " total= " << G4BestUnit(meanTim << 237 G4cout 226 << 238 << "\n time of flight E>1*eV= " << G4BestUnit(meanTime1,"Time") 227 // particles count << 239 << " E<1*eV= " << G4BestUnit(meanTime2, "Time") 228 // << 240 << " total= " << G4BestUnit(meanTimeTo, "Time") << G4endl; 229 G4cout << "\n List of generated particles:" << 241 230 << 242 //particles count 231 std::map<G4String, ParticleData>::iterator i << 243 // 232 for (itn = fParticleDataMap.begin(); itn != << 244 G4cout << "\n List of generated particles:" << G4endl; >> 245 >> 246 std::map<G4String,ParticleData>::iterator itn; >> 247 for (itn = fParticleDataMap.begin(); itn != fParticleDataMap.end(); itn++) { 233 G4String name = itn->first; 248 G4String name = itn->first; 234 ParticleData data = itn->second; 249 ParticleData data = itn->second; 235 G4int count = data.fCount; 250 G4int count = data.fCount; 236 G4double eMean = data.fEmean / count; << 251 G4double eMean = data.fEmean/count; 237 G4double eMin = data.fEmin; 252 G4double eMin = data.fEmin; 238 G4double eMax = data.fEmax; << 253 G4double eMax = data.fEmax; 239 << 254 240 G4cout << " " << std::setw(13) << name << 255 G4cout << " " << std::setw(13) << name << ": " << std::setw(7) << count 241 << " Emean = " << std::setw(wid) < << 256 << " Emean = " << std::setw(wid) << G4BestUnit(eMean, "Energy") 242 << G4BestUnit(eMin, "Energy") << " << 257 << "\t( " << G4BestUnit(eMin, "Energy") 243 } << 258 << " --> " << G4BestUnit(eMax, "Energy") 244 << 259 << ")" << G4endl; 245 // normalize histograms << 260 } >> 261 >> 262 //normalize histograms 246 ////G4AnalysisManager* analysisManager = G4A 263 ////G4AnalysisManager* analysisManager = G4AnalysisManager::Instance(); 247 ////G4double factor = 1./numberOfEvent; 264 ////G4double factor = 1./numberOfEvent; 248 ////analysisManager->ScaleH1(3,factor); 265 ////analysisManager->ScaleH1(3,factor); 249 << 266 250 // remove all contents in fProcCounter, fCou << 267 //remove all contents in fProcCounter, fCount 251 fProcCounter.clear(); 268 fProcCounter.clear(); 252 fParticleDataMap.clear(); 269 fParticleDataMap.clear(); 253 << 270 254 // restore default format << 271 //restore default format 255 G4cout.precision(dfprec); << 272 G4cout.precision(dfprec); 256 } 273 } 257 274 258 //....oooOO0OOooo........oooOO0OOooo........oo 275 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... 259 276