Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2025-02-23 09:22:10

0001 //
0002 // ********************************************************************
0003 // * License and Disclaimer                                           *
0004 // *                                                                  *
0005 // * The  Geant4 software  is  copyright of the Copyright Holders  of *
0006 // * the Geant4 Collaboration.  It is provided  under  the terms  and *
0007 // * conditions of the Geant4 Software License,  included in the file *
0008 // * LICENSE and available at  http://cern.ch/geant4/license .  These *
0009 // * include a list of copyright holders.                             *
0010 // *                                                                  *
0011 // * Neither the authors of this software system, nor their employing *
0012 // * institutes,nor the agencies providing financial support for this *
0013 // * work  make  any representation or  warranty, express or implied, *
0014 // * regarding  this  software system or assume any liability for its *
0015 // * use.  Please see the license in the file  LICENSE  and URL above *
0016 // * for the full disclaimer and the limitation of liability.         *
0017 // *                                                                  *
0018 // * This  code  implementation is the result of  the  scientific and *
0019 // * technical work of the GEANT4 collaboration.                      *
0020 // * By using,  copying,  modifying or  distributing the software (or *
0021 // * any work based  on the software)  you  agree  to acknowledge its *
0022 // * use  in  resulting  scientific  publications,  and indicate your *
0023 // * acceptance of all terms of the Geant4 Software license.          *
0024 // ********************************************************************
0025 //
0026 // This example is provided by the Geant4-DNA collaboration
0027 // Any report or published results obtained using the Geant4-DNA software
0028 // shall cite the following Geant4-DNA collaboration publications:
0029 // Med. Phys. 45 (2018) e722-e739
0030 // Phys. Med. 31 (2015) 861-874
0031 // Med. Phys. 37 (2010) 4692-4708
0032 // Int. J. Model. Simul. Sci. Comput. 1 (2010) 157–178
0033 //
0034 // The Geant4-DNA web site is available at http://geant4-dna.org
0035 //
0036 /// \file medical/dna/svalue/src/PhysicsList.cc
0037 /// \brief Implementation of the PhysicsList class
0038 
0039 #include "PhysicsList.hh"
0040 
0041 #include "PhysicsListMessenger.hh"
0042 
0043 #include "G4EmDNAPhysics.hh"
0044 #include "G4EmDNAPhysics_option1.hh"
0045 #include "G4EmDNAPhysics_option2.hh"
0046 #include "G4EmDNAPhysics_option3.hh"
0047 #include "G4EmDNAPhysics_option4.hh"
0048 #include "G4EmDNAPhysics_option5.hh"
0049 #include "G4EmDNAPhysics_option6.hh"
0050 #include "G4EmDNAPhysics_option7.hh"
0051 #include "G4EmDNAPhysics_option8.hh"
0052 #include "G4EmStandardPhysics_option3.hh"
0053 #include "G4EmStandardPhysics_option4.hh"
0054 #include "G4UserSpecialCuts.hh"
0055 
0056 // Particles
0057 
0058 #include "G4BaryonConstructor.hh"
0059 #include "G4BosonConstructor.hh"
0060 #include "G4DNAGenericIonsManager.hh"
0061 #include "G4IonConstructor.hh"
0062 #include "G4LeptonConstructor.hh"
0063 #include "G4MesonConstructor.hh"
0064 
0065 // Decay
0066 
0067 #include "G4Electron.hh"
0068 #include "G4NuclideTable.hh"
0069 #include "G4RadioactiveDecayPhysics.hh"
0070 #include "G4SystemOfUnits.hh"
0071 
0072 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0073 
0074 PhysicsList::PhysicsList() : G4VModularPhysicsList(), fEmPhysicsList(0), fMessenger(0)
0075 {
0076   fMessenger = new PhysicsListMessenger(this);
0077 
0078   SetVerboseLevel(1);
0079 
0080   // Physics
0081 
0082   fEmPhysicsList = new G4EmDNAPhysics();
0083   defaultCutValue = 1. * CLHEP::nm;
0084 
0085   G4double lowLimit = 10. * CLHEP::eV;
0086   G4double highLimit = 100. * CLHEP::GeV;
0087 
0088   G4ProductionCutsTable::GetProductionCutsTable()->SetEnergyRange(lowLimit, highLimit);
0089   // Change time and other limits in G4NuclideTable
0090 
0091   G4NuclideTable::GetInstance()->SetThresholdOfHalfLife(0.1 * picosecond);
0092   G4NuclideTable::GetInstance()->SetLevelTolerance(1.0 * eV);
0093 
0094   fRadDecay = new G4RadioactiveDecayPhysics();
0095 }
0096 
0097 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0098 
0099 PhysicsList::~PhysicsList()
0100 {
0101   delete fMessenger;
0102   delete fEmPhysicsList;
0103   delete fRadDecay;
0104 }
0105 
0106 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0107 
0108 void PhysicsList::ConstructParticle()
0109 {
0110   G4BosonConstructor pBosonConstructor;
0111   pBosonConstructor.ConstructParticle();
0112 
0113   G4LeptonConstructor pLeptonConstructor;
0114   pLeptonConstructor.ConstructParticle();
0115 
0116   G4MesonConstructor pMesonConstructor;
0117   pMesonConstructor.ConstructParticle();
0118 
0119   G4BaryonConstructor pBaryonConstructor;
0120   pBaryonConstructor.ConstructParticle();
0121 
0122   G4IonConstructor pIonConstructor;
0123   pIonConstructor.ConstructParticle();
0124 
0125   G4DNAGenericIonsManager* genericIonsManager;
0126   genericIonsManager = G4DNAGenericIonsManager::Instance();
0127   genericIonsManager->GetIon("alpha++");
0128   genericIonsManager->GetIon("alpha+");
0129   genericIonsManager->GetIon("helium");
0130   genericIonsManager->GetIon("hydrogen");
0131 }
0132 
0133 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0134 
0135 void PhysicsList::ConstructProcess()
0136 {
0137   // Transportation
0138 
0139   AddTransportation();
0140 
0141   // Electromagnetic physics list
0142 
0143   fEmPhysicsList->ConstructProcess();
0144 
0145   // Tracking cut
0146 
0147   AddTrackingCut();
0148 
0149   // Radioactive decay
0150 
0151   fRadDecay->ConstructProcess();
0152 }
0153 
0154 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0155 
0156 void PhysicsList::AddPhysicsList(const G4String& name)
0157 {
0158   if (verboseLevel > 0) {
0159     G4cout << "PhysicsList::AddPhysicsList: <" << name << ">" << G4endl;
0160   }
0161 
0162   if (name == fEmName) return;
0163 
0164   if (name == "dna") {
0165     fEmName = name;
0166     delete fEmPhysicsList;
0167     fEmPhysicsList = new G4EmDNAPhysics();
0168   }
0169   else if (name == "dna_opt1") {
0170     fEmName = name;
0171     delete fEmPhysicsList;
0172     fEmPhysicsList = new G4EmDNAPhysics_option1();
0173   }
0174   else if (name == "dna_opt2") {
0175     fEmName = name;
0176     delete fEmPhysicsList;
0177     fEmPhysicsList = new G4EmDNAPhysics_option2();
0178   }
0179   else if (name == "dna_opt3") {
0180     fEmName = name;
0181     delete fEmPhysicsList;
0182     fEmPhysicsList = new G4EmDNAPhysics_option3();
0183   }
0184   else if (name == "dna_opt4") {
0185     fEmName = name;
0186     delete fEmPhysicsList;
0187     fEmPhysicsList = new G4EmDNAPhysics_option4();
0188   }
0189   else if (name == "dna_opt5") {
0190     fEmName = name;
0191     delete fEmPhysicsList;
0192     fEmPhysicsList = new G4EmDNAPhysics_option5();
0193   }
0194   else if (name == "dna_opt6") {
0195     fEmName = name;
0196     delete fEmPhysicsList;
0197     fEmPhysicsList = new G4EmDNAPhysics_option6();
0198   }
0199   else if (name == "dna_opt7") {
0200     fEmName = name;
0201     delete fEmPhysicsList;
0202     fEmPhysicsList = new G4EmDNAPhysics_option7();
0203   }
0204   else if (name == "dna_opt8") {
0205     fEmName = name;
0206     delete fEmPhysicsList;
0207     fEmPhysicsList = new G4EmDNAPhysics_option8();
0208   }
0209   else if (name == "std_opt3") {
0210     fEmName = name;
0211     delete fEmPhysicsList;
0212     fEmPhysicsList = new G4EmStandardPhysics_option3();
0213   }
0214   else if (name == "std_opt4") {
0215     fEmName = name;
0216     delete fEmPhysicsList;
0217     fEmPhysicsList = new G4EmStandardPhysics_option4();
0218   }
0219   else {
0220     G4cout << "PhysicsList::AddPhysicsList: <" << name << ">"
0221            << " is not defined" << G4endl;
0222   }
0223 }
0224 
0225 //....oooOO0OOooo........oooOO0OOooo........oooOO0OOooo........oooOO0OOooo......
0226 
0227 void PhysicsList::AddTrackingCut()
0228 {
0229   G4PhysicsListHelper* ph = G4PhysicsListHelper::GetPhysicsListHelper();
0230   ph->RegisterProcess(new G4UserSpecialCuts(), G4Electron::Electron());
0231 }