31#ifndef G4CoherentPairProduction_h
32#define G4CoherentPairProduction_h 1
68 {
Input(crystal,lattice,
"");}
122 {fChargeParticleAngleFactor = chargeParticleAngleFactor;}
126 {fNTrajectorySteps = nTrajectorySteps;}
137 G4int FindVectorIndex(std::vector<G4double> &myvector,
G4double value);
142 std::vector <CLHEP::Hep2Vector> fullVectorEtotal;
145 std::vector <CLHEP::Hep2Vector> fullVectorX;
148 std::vector <CLHEP::Hep2Vector> fullVectorY;
151 std::vector <CLHEP::Hep2Vector> fullVectorTX;
154 std::vector <CLHEP::Hep2Vector> fullVectorTY;
158 std::vector <G4double> fPairProductionCDFdz;
160 G4double fLowEnergyLimit = 1*CLHEP::GeV;
161 G4double fHighAngleLimit = 50*CLHEP::mrad;
164 G4double fPPKineticEnergyCut = 1*CLHEP::MeV;
167 G4int fNMCPairs = 150;
169 G4double fChargeParticleAngleFactor = 4;
173 G4int fNTrajectorySteps=250;
179 G4String fG4RegionName =
"Crystal";
182 const G4double fMass = CLHEP::electron_mass_c2;
185 G4bool fIncoherentScattering =
false;
Definition of the G4ChannelingFastSimCrystalData class The class inherits G4VChannelingFastSimCrystal...
G4double condition(const G4ErrorSymMatrix &m)
G4CoherentPairProduction(const G4String &processName="cpp", G4ProcessType aType=fElectromagnetic)
G4double GetNTrajectorySteps()
get number of trajectory steps of a single particle (e- or e+)
G4String GetG4RegionName()
get the name of G4Region in which the model is applicable
G4double ModelMinPrimaryEnergy()
get cuts
void SetHighAngleLimit(G4double angle)
void SetPPKineticEnergyCut(G4double kineticEnergyCut)
G4double GetPPKineticEnergyCut()
G4double GetEffectiveLrad()
void SetLowEnergyLimit(G4double energy)
set cuts
void SetG4RegionName(const G4String &nameG4Region)
set the name of G4Region in which the model is applicable
G4double GetChargeParticleAngleFactor()
G4bool IsApplicable(const G4ParticleDefinition &aPD) override
void SetSamplingPairsNumber(G4int nPairs)
void Input(const G4Material *crystal, const G4String &lattice)
special functions
~G4CoherentPairProduction()=default
G4double GetHighAngleLimit()
void SetNTrajectorySteps(G4int nTrajectorySteps)
set number of trajectory steps of a single particle (e- or e+)
G4ChannelingFastSimCrystalData * GetCrystalData()
void SetChargeParticleAngleFactor(G4double chargeParticleAngleFactor)
G4double GetMeanFreePath(const G4Track &aTrack, G4double, G4ForceCondition *condition) override
G4int GetSamplingPairsNumber()
G4VParticleChange * PostStepDoIt(const G4Track &, const G4Step &) override
void ProcessDescription(std::ostream &) const override
void ActivateIncoherentScattering()
const G4String & GetParticleName() const
G4VDiscreteProcess(const G4String &aName, G4ProcessType aType=fNotDefined)