100 delete thePhotonSpectrum;
129 if(1 >= Z) {
return 0.0; }
133 if ( theDynamicParticle->
GetKineticEnergy() < 2.0*CLHEP::MeV ) {
return 0.0; }
143 if (b <= 0.0 && b >= 1.0) {
return 0.0; }
147 G4double bmin = thePhotonSpectrum->GetClosestApproach(AP, ZP, AT, ZT, b);
158 (*theProjectileCrossSections)[0]+(*theProjectileCrossSections)[1];
159 delete theProjectileCrossSections;
163 (*theTargetCrossSections)[0]+(*theTargetCrossSections)[1];
164 delete theTargetCrossSections;
184 G4double u = 3.0 * J / Qprime / AProot3;
186 G4double E_GDR = hbarc / std::sqrt(0.7*amu_c2*R0*R0/8.0/J*
187 (1.0 + u - (1.0 + epsilon + 3.0*u)/(1.0 + epsilon + u)*epsilon));
188 G4double E_GQR = 63.0 * MeV / AProot3;
195 thePhotonSpectrum->GetGeneralE1Spectrum(E_GDR, b, bmin);
197 thePhotonSpectrum->GetGeneralE2Spectrum(E_GQR, b, bmin);
203 G4double sE1 = 60.0 * millibarn * MeV * (AP-ZP)*ZP/AP;
204 G4double sE2 = 0.22 * microbarn / MeV * ZP * AProot3 * AProot3;
205 if (AP > 100.0) sE2 *= 0.9;
206 else if (AP > 40.0) sE2 *= 0.6;
214 theCrossSectionVector->
PutValue(0, E_GDR, sE1*nE1);
215 theCrossSectionVector->
PutValue(1, E_GQR, sE2*nE2*E_GQR*E_GQR);
217 return theCrossSectionVector;
G4double G4Exp(G4double initial_x)
Exponential Function double precision.
G4ParticleDefinition * GetDefinition() const
G4double GetKineticEnergy() const
G4double GetElementCrossSection(const G4DynamicParticle *, G4int Z, const G4Material *) override
G4PhysicsFreeVector * GetCrossSectionForProjectile(G4double, G4double, G4double, G4double, G4double, G4double)
~G4EMDissociationCrossSection() override
G4double GetWilsonProbabilityForProtonDissociation(G4double, G4double)
G4PhysicsFreeVector * GetCrossSectionForTarget(G4double, G4double, G4double, G4double, G4double, G4double)
G4EMDissociationCrossSection()
G4bool IsElementApplicable(const G4DynamicParticle *, G4int Z, const G4Material *) override
static G4NistManager * Instance()
G4double GetAtomicMassAmu(const G4String &symb) const
G4double GetPDGCharge() const
G4int GetBaryonNumber() const
static G4ParticleTable * GetParticleTable()
void PutValue(const std::size_t index, const G4double e, const G4double value)
static G4Pow * GetInstance()
G4double A13(G4double A) const
G4VCrossSectionDataSet(const G4String &nam="")