61 G4cout <<
"###=== The class G4ChargeExchangeProcess is obsolete!!!" <<
G4endl;
62 G4cout <<
"###=== It will be removed at the next public release" <<
G4endl;
100 if (factors)
delete factors;
108 theParticle = &aParticleType;
114 if(theParticle == thePiPlus || theParticle == thePiMinus ||
115 theParticle == theKPlus || theParticle == theKMinus ||
116 theParticle == theK0S || theParticle == theK0L) {
118 G4double F[n] = {0.33,0.27,0.29,0.31,0.27,0.18,0.13,0.1,0.09,0.07};
120 for(
size_t i=0; i<n; i++) {factors->PutValue(i,F[i]);}
124 G4double F[n] = {0.50,0.45,0.40,0.35,0.30,0.25,0.06,0.04,0.005,0.0};
126 for(
size_t i=0; i<n; i++) {factors->PutValue(i,F[i]);}
130 G4cout <<
"G4ChargeExchangeProcess for "
131 << theParticle->GetParticleName()
151 G4cout <<
"G4ChargeExchangeProcess compute GHAD CS for element "
154 x = store->GetCrossSection(dp, elm, mat);
157 G4cout <<
"G4ChargeExchangeProcess cross(mb)= " << x/millibarn
159 <<
" " << theParticle->GetParticleName()
166 if(theParticle == thePiPlus || theParticle == theProton ||
167 theParticle == theKPlus || theParticle == theANeutron)
168 { x *= (1.0 - Z/
A); }
170 else if(theParticle == thePiMinus || theParticle == theNeutron ||
171 theParticle == theKMinus || theParticle == theAProton)
174 if(theParticle->GetPDGMass() < GeV) {
175 if(ptot > 2.*GeV) x *= 4.0*GeV*GeV/(ptot*ptot);
179 G4cout <<
"Corrected cross(mb)= " << x/millibarn <<
G4endl;
188 return (p == thePiPlus || p == thePiMinus ||
189 p == theProton || p == theNeutron ||
190 p == theAProton|| p == theANeutron||
191 p == theKPlus || p == theKMinus ||
192 p == theK0S || p == theK0L ||
199 store->DumpPhysicsTable(aParticleType);
G4GLOB_DLL std::ostream G4cout
static G4AntiLambda * AntiLambda()
static G4AntiNeutron * AntiNeutron()
static G4AntiOmegaMinus * AntiOmegaMinus()
static G4AntiProton * AntiProton()
static G4AntiSigmaMinus * AntiSigmaMinus()
static G4AntiSigmaPlus * AntiSigmaPlus()
static G4AntiSigmaZero * AntiSigmaZero()
static G4AntiXiMinus * AntiXiMinus()
static G4AntiXiZero * AntiXiZero()
virtual G4double GetElementCrossSection(const G4DynamicParticle *aParticle, const G4Element *anElement, const G4Material *mat=0)
virtual void DumpPhysicsTable(const G4ParticleDefinition &aParticleType)
virtual G4bool IsApplicable(const G4ParticleDefinition &aParticleType)
virtual void BuildPhysicsTable(const G4ParticleDefinition &aParticleType)
virtual ~G4ChargeExchangeProcess()
G4ChargeExchangeProcess(const G4String &procName="chargeExchange")
static G4Deuteron * Deuteron()
G4double GetKineticEnergy() const
G4double GetTotalMomentum() const
const G4String & GetName() const
void AddDataSet(G4VCrossSectionDataSet *aDataSet)
G4HadronicProcess(const G4String &processName="Hadronic", G4ProcessType procType=fHadronic)
void BuildPhysicsTable(const G4ParticleDefinition &) override
G4CrossSectionDataStore * GetCrossSectionDataStore()
static G4KaonMinus * KaonMinus()
static G4KaonPlus * KaonPlus()
static G4KaonZeroLong * KaonZeroLong()
static G4KaonZeroShort * KaonZeroShort()
static G4Lambda * Lambda()
static G4Neutron * Neutron()
static G4OmegaMinus * OmegaMinus()
G4int GetPDGEncoding() const
static G4PionMinus * PionMinus()
static G4PionPlus * PionPlus()
static G4PionZero * PionZero()
static G4Pow * GetInstance()
G4double powA(G4double A, G4double y) const
static G4Proton * Proton()
static G4SigmaMinus * SigmaMinus()
static G4SigmaPlus * SigmaPlus()
static G4SigmaZero * SigmaZero()
static G4Triton * Triton()
static G4XiMinus * XiMinus()
static G4XiZero * XiZero()