#include "PWO25PhysicsList.hh" #include "G4ParticleDefinition.hh" #include "G4ProcessManager.hh" #include "G4ProcessVector.hh" #include "G4ParticleTypes.hh" #include "G4ParticleTable.hh" #include "G4Material.hh" #include "G4LossTableManager.hh" #include "G4ios.hh" #include #include "PhysListEmStandard.hh" PWO25PhysicsList::PWO25PhysicsList() : G4VModularPhysicsList() { G4LossTableManager::Instance(); currentDefaultCut = 1.0*mm; cutForGamma = currentDefaultCut; cutForElectron = currentDefaultCut; cutForPositron = currentDefaultCut; SetVerboseLevel(1); // EM physics emName = G4String("standard"); emPhysicsList = new PhysListEmStandard(emName); } PWO25PhysicsList::~PWO25PhysicsList() {;} // Bosons #include "G4ChargedGeantino.hh" #include "G4Geantino.hh" #include "G4Gamma.hh" #include "G4OpticalPhoton.hh" // leptons #include "G4MuonPlus.hh" #include "G4MuonMinus.hh" #include "G4NeutrinoMu.hh" #include "G4AntiNeutrinoMu.hh" #include "G4Electron.hh" #include "G4Positron.hh" #include "G4NeutrinoE.hh" #include "G4AntiNeutrinoE.hh" // Mesons #include "G4PionPlus.hh" #include "G4PionMinus.hh" #include "G4PionZero.hh" #include "G4Eta.hh" #include "G4EtaPrime.hh" #include "G4KaonPlus.hh" #include "G4KaonMinus.hh" #include "G4KaonZero.hh" #include "G4AntiKaonZero.hh" #include "G4KaonZeroLong.hh" #include "G4KaonZeroShort.hh" // Baryons #include "G4Proton.hh" #include "G4AntiProton.hh" #include "G4Neutron.hh" #include "G4AntiNeutron.hh" // Nuclei #include "G4Deuteron.hh" #include "G4Triton.hh" #include "G4Alpha.hh" #include "G4GenericIon.hh" void PWO25PhysicsList::ConstructParticle() { // pseudo-particles G4Geantino::GeantinoDefinition(); G4ChargedGeantino::ChargedGeantinoDefinition(); // gamma G4Gamma::GammaDefinition(); // optical photon G4OpticalPhoton::OpticalPhotonDefinition(); // leptons G4Electron::ElectronDefinition(); G4Positron::PositronDefinition(); G4MuonPlus::MuonPlusDefinition(); G4MuonMinus::MuonMinusDefinition(); G4NeutrinoE::NeutrinoEDefinition(); G4AntiNeutrinoE::AntiNeutrinoEDefinition(); G4NeutrinoMu::NeutrinoMuDefinition(); G4AntiNeutrinoMu::AntiNeutrinoMuDefinition(); // mesons G4PionPlus::PionPlusDefinition(); G4PionMinus::PionMinusDefinition(); G4PionZero::PionZeroDefinition(); G4Eta::EtaDefinition(); G4EtaPrime::EtaPrimeDefinition(); G4KaonPlus::KaonPlusDefinition(); G4KaonMinus::KaonMinusDefinition(); G4KaonZero::KaonZeroDefinition(); G4AntiKaonZero::AntiKaonZeroDefinition(); G4KaonZeroLong::KaonZeroLongDefinition(); G4KaonZeroShort::KaonZeroShortDefinition(); // barions G4Proton::ProtonDefinition(); G4AntiProton::AntiProtonDefinition(); G4Neutron::NeutronDefinition(); G4AntiNeutron::AntiNeutronDefinition(); // ions G4Deuteron::DeuteronDefinition(); G4Triton::TritonDefinition(); G4Alpha::AlphaDefinition(); G4GenericIon::GenericIonDefinition(); } #include "G4EmProcessOptions.hh" void PWO25PhysicsList::ConstructProcess() { // Transportation // AddTransportation(); // Electromagnetic physics list // emPhysicsList->ConstructProcess(); // Em options // G4EmProcessOptions emOptions; emOptions.SetBuildCSDARange(true); emOptions.SetMaxEnergyForCSDARange(100*TeV); emOptions.SetDEDXBinningForCSDARange(120); emOptions.SetVerbose(0); } void PWO25PhysicsList::AddPhysicsList(const G4String& name) { if (verboseLevel>0) { G4cout << "PhysicsList::AddPhysicsList: <" << name << ">" << G4endl; } if (name == emName) return; if (name == "standard") { emName = name; delete emPhysicsList; emPhysicsList = new PhysListEmStandard(name); } else { G4cout << "PhysicsList::AddPhysicsList: <" << name << ">" << " is not defined" << G4endl; } } #include "G4Gamma.hh" #include "G4Electron.hh" #include "G4Positron.hh" void PWO25PhysicsList::SetCuts() { // set cut values for gamma at first and for e- second and next for e+, // because some processes for e+/e- need cut values for gamma SetCutValue(cutForGamma, "gamma"); SetCutValue(cutForElectron, "e-"); SetCutValue(cutForPositron, "e+"); DumpCutValuesTable(); } void PWO25PhysicsList::SetCutForGamma(G4double cut) { cutForGamma = cut; SetParticleCuts(cutForGamma, G4Gamma::Gamma()); } //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... void PWO25PhysicsList::SetCutForElectron(G4double cut) { cutForElectron = cut; SetParticleCuts(cutForElectron, G4Electron::Electron()); } //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo...... void PWO25PhysicsList::SetCutForPositron(G4double cut) { cutForPositron = cut; SetParticleCuts(cutForPositron, G4Positron::Positron()); }