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 hadronic/Hadr01/include/HistoManager << 26 // $Id: HistoManager.hh,v 1.3 2006/06/29 17:23:42 gunter Exp $ 27 /// \brief Definition of the HistoManager clas << 27 // GEANT4 tag $Name: geant4-08-01-patch-01 $ 28 // 28 // 29 //-------------------------------------------- 29 //--------------------------------------------------------------------------- 30 // 30 // 31 // ClassName: HistoManager 31 // ClassName: HistoManager 32 // 32 // 33 // Description: Singleton class to hold parame 33 // Description: Singleton class to hold parameters and build histograms. 34 // User cannot access to the cons 34 // User cannot access to the constructor. 35 // The pointer of the only existi 35 // The pointer of the only existing object can be got via 36 // HistoManager::GetPointer() sta 36 // HistoManager::GetPointer() static method. 37 // The first invokation of this s 37 // The first invokation of this static method makes 38 // the singleton object. 38 // the singleton object. 39 // 39 // 40 // Author: V.Ivanchenko 27/09/00 40 // Author: V.Ivanchenko 27/09/00 41 // 41 // 42 // Modified: 42 // Modified: 43 // 04.06.2006 Adoptation of Hadr01 (V.Ivanchen << 43 // 04.06.2006 Adoptation of hadr01 (V.Ivanchenko) 44 // 03.10.2006 Add csFlag (V.Ivanchenko) << 45 // 16.11.2006 Add beamFlag (V.Ivanchenko) << 46 // 44 // 47 //-------------------------------------------- 45 //---------------------------------------------------------------------------- 48 // 46 // 49 47 50 #ifndef HistoManager_h 48 #ifndef HistoManager_h 51 #define HistoManager_h 1 49 #define HistoManager_h 1 52 50 53 #include "G4Element.hh" << 54 #include "G4Material.hh" << 55 #include "globals.hh" 51 #include "globals.hh" 56 52 57 //....oooOO0OOooo........oooOO0OOooo........oo 53 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo.... 58 54 59 class Histo; 55 class Histo; 60 class G4Track; 56 class G4Track; 61 class G4Step; 57 class G4Step; 62 class G4ParticleDefinition; 58 class G4ParticleDefinition; 63 59 64 class HistoManager 60 class HistoManager 65 { 61 { 66 public: << 62 public: 67 static HistoManager* GetPointer(); << 68 63 69 private: << 64 static HistoManager* GetPointer(); 70 HistoManager(); << 71 65 72 public: << 66 private: 73 ~HistoManager(); << 74 67 75 void BookHisto(); << 68 HistoManager(); 76 << 77 void BeginOfRun(); << 78 void EndOfRun(); << 79 void BeginOfEvent(); << 80 void EndOfEvent(); << 81 void Fill(G4int id, G4double x, G4double w << 82 << 83 void ScoreNewTrack(const G4Track*); << 84 void AddTargetStep(const G4Step*); << 85 void AddLeakingParticle(const G4Track*); << 86 << 87 void SetVerbose(G4int val); << 88 << 89 inline void SetTargetRadius(G4double val) << 90 { << 91 fRadius = val; << 92 fR2 = val * val; << 93 }; << 94 inline void SetTargetLength(G4double val) << 95 inline void SetNumberOfSlices(G4int val) { << 96 inline void SetNumberOfBinsE(G4int val) { << 97 inline void SetDefaultBeamPositionFlag(G4b << 98 inline void SetMaxEnergyDeposit(G4double v << 99 << 100 inline G4double Radius() const { return fR << 101 inline G4double Length() const { return fL << 102 inline G4bool DefaultBeamPosition() const << 103 inline G4int NumberOfSlices() const { retu << 104 inline G4int GetVerbose() const { return f << 105 << 106 inline G4int PrintBertiniXS() const { retu << 107 inline void SetPrintBertiniXS(G4int key) { << 108 << 109 private: << 110 static HistoManager* fManager; << 111 << 112 const G4ParticleDefinition* fPrimaryDef; << 113 const G4ParticleDefinition* fNeutron; << 114 << 115 G4double fR2 = 0.0; << 116 G4double fRadius; << 117 G4double fLength; << 118 G4double fEdepMax; << 119 G4double fEdepEvt = 0.0; << 120 G4double fEdepEM = 0.0; << 121 G4double fEdepPI = 0.0; << 122 G4double fEdepP = 0.0; << 123 G4double fEdepSum = 0.0; << 124 G4double fEdepSum2 = 0.0; << 125 G4double fAbsZ0 = 0.0; << 126 G4double fPrimaryKineticEnergy = 0.0; << 127 << 128 G4int fVerbose = 0; << 129 G4int fNBinsE = 100; << 130 G4int fNSlices = 300; << 131 << 132 G4int fNevt = 0; << 133 G4int fNelec = 0; << 134 G4int fNposit = 0; << 135 G4int fNgam = 0; << 136 G4int fNprot_leak = 0; << 137 G4int fNpiofNleak = 0; << 138 G4int fNcpions = 0; << 139 G4int fNpi0 = 0; << 140 G4int fNkaons = 0; << 141 G4int fNmuons = 0; << 142 G4int fNions = 0; << 143 G4int fNdeut = 0; << 144 G4int fNalpha = 0; << 145 G4int fNneutron = 0; << 146 G4int fNproton = 0; << 147 G4int fNaproton = 0; << 148 G4int fNneu_forw = 0; << 149 G4int fNneu_leak = 0; << 150 G4int fNneu_back = 0; << 151 G4int fNstep = 0; << 152 G4int fNHisto = 28; << 153 G4int fPrintBertiniXS = -1; // 0 - all << 154 69 155 G4bool fBeamFlag = true; << 70 public: 156 G4bool fHistoBooked = false; << 71 >> 72 ~HistoManager(); >> 73 >> 74 void bookHisto(); >> 75 >> 76 void BeginOfRun(); >> 77 void EndOfRun(); >> 78 >> 79 void ScoreNewTrack(const G4Track*); >> 80 void AddTargetStep(const G4Step*); >> 81 void AddLeakingParticle(const G4Track*); >> 82 >> 83 void SetTargetLength(G4double val) {length = val;}; >> 84 void SetNumberOfSlices(G4int val) {nSlices = val;}; >> 85 void SetNumberOfBinsE(G4int val) {nBinsE = val;}; >> 86 >> 87 G4double Length() const {return length;}; >> 88 G4int NumberOfSlices() const {return nSlices;}; >> 89 >> 90 void SetVerbose(G4int val); >> 91 G4int GetVerbose() const {return verbose;}; >> 92 >> 93 G4double CurrentKinEnergy() {return currentKinEnergy;}; >> 94 const G4ParticleDefinition* CurrentDefinition() >> 95 {return currentDef;}; >> 96 >> 97 private: >> 98 >> 99 static HistoManager* fManager; >> 100 >> 101 const G4ParticleDefinition* primaryDef; >> 102 const G4ParticleDefinition* currentDef; >> 103 const G4ParticleDefinition* neutron; >> 104 G4double currentKinEnergy; >> 105 >> 106 G4int verbose; >> 107 G4int nBinsE; >> 108 G4int nSlices; >> 109 >> 110 G4double beamEnergy; >> 111 G4double length; >> 112 G4double absZ0; >> 113 G4double primaryKineticEnergy; >> 114 >> 115 G4int n_evt; >> 116 G4int n_elec; >> 117 G4int n_posit; >> 118 G4int n_gam; >> 119 G4int n_prot_leak; >> 120 G4int n_pion_leak; >> 121 G4int n_cpions; >> 122 G4int n_pi0; >> 123 G4int n_kaons; >> 124 G4int n_muons; >> 125 G4int n_ions; >> 126 G4int n_deut; >> 127 G4int n_alpha; >> 128 G4int n_neutron; >> 129 G4int n_proton; >> 130 G4int n_aproton; >> 131 G4int n_neu_forw; >> 132 G4int n_neu_leak; >> 133 G4int n_neu_back; >> 134 G4int n_step; >> 135 G4int nHisto; 157 136 158 Histo* fHisto; << 137 Histo* histo; 159 }; 138 }; 160 139 161 #endif 140 #endif 162 141