75 fParticleChange =
nullptr;
80 if (
nullptr == fCrossSection) {
95 delete f3GProbability;
96 fCrossSection =
nullptr;
97 f3GProbability =
nullptr;
107 if (
nullptr == fParticleChange) {
111 f3GModel->Initialise(p, cuts);
116 std::size_t num = fCrossSection->GetVectorLength();
117 for (std::size_t i=0; i<num; ++i) {
118 G4double e = fCrossSection->Energy(i);
120 G4double cs3 = f3GModel->ComputeCrossSectionPerElectron(e);
122 fCrossSection->PutValue(i, cs2);
123 G4double y = (cs2 > 0.0) ? cs3/cs2 : 0.0;
124 f3GProbability->PutValue(i, y);
126 fCrossSection->FillSecondDerivatives();
127 f3GProbability->FillSecondDerivatives();
140 G4double ekin = std::max(CLHEP::eV, kinEnergy);
141 G4double tau = ekin/CLHEP::electron_mass_c2;
147 - (gam+3.)/(std::sqrt(gam*gam - 1.));
148 G4double eGammaCMS = CLHEP::electron_mass_c2 * std::sqrt(0.5*(tau + 2.0));
149 fDelta = std::max(fDeltaMin, fGammaTh/eGammaCMS);
150 f3GModel->SetDelta(fDelta);
153 CLHEP::pi*CLHEP::classic_electr_radius*CLHEP::classic_electr_radius;
154 G4double cross = (pir2*rho + alpha_rcl2*2.*
G4Log(fDelta)*rho*rho)/(gam+1.);
167 G4double cross = Z*fCrossSection->Value(kineticEnergy);
181 G4double cross = eDensity*fCrossSection->Value(kineticEnergy);
191 std::vector<G4DynamicParticle*>* vdp,
197 fParticleChange->SetProposedKineticEnergy(0.0);
203 posiKinEnergy + 2*CLHEP::electron_mass_c2);
206 if (
G4UniformRand() < f3GProbability->Value(posiKinEnergy)) {
207 fDelta = std::max(fDeltaMin, fGammaTh/eGammaCMS);
208 f3GModel->SetDelta(fDelta);
209 f3GModel->SampleSecondaries(vdp, couple, dp);
232 aGamma1->SetPolarization(pol1);
234 aGamma2->SetPolarization(pol2);
236 vdp->push_back(aGamma1);
237 vdp->push_back(aGamma2);
G4double G4Log(G4double x)
CLHEP::HepLorentzVector G4LorentzVector
G4ThreeVector G4RandomDirection()
CLHEP::Hep3Vector G4ThreeVector
Hep3Vector & rotateUz(const Hep3Vector &)
Hep3Vector boostVector() const
HepLorentzVector & boost(double, double, double)
G4double GetKineticEnergy() const
G4ThreeVector GetMomentum() const
static G4EmParameters * Instance()
G4double LowestTripletEnergy() const
G4double GetElectronDensity() const
G4ParticleChangeForGamma * GetParticleChangeForGamma()
void SetTripletModel(G4VEmModel *)
G4VEmModel(const G4String &nam)
~G4eplusTo2or3GammaModel() override
G4double CrossSectionPerVolume(const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) override
G4double ComputeCrossSectionPerAtom(const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0., G4double cutEnergy=0., G4double maxEnergy=DBL_MAX) override
G4eplusTo2or3GammaModel()
void Initialise(const G4ParticleDefinition *, const G4DataVector &) override
void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin=0.0, G4double maxEnergy=DBL_MAX) override
G4double ComputeCrossSectionPerElectron(G4double kinEnergy)