43 #ifndef G4MicroElecInelasticModel_h
44 #define G4MicroElecInelasticModel_h 1
70 const G4String& nam =
"MicroElecInelasticModel");
116 typedef std::map<G4String,G4String,std::less<G4String> >
MapFile;
119 typedef std::map<G4String,G4MicroElecCrossSectionDataSet*,std::less<G4String> >
MapData;
156 typedef std::map<double, std::vector<double> >
VecMap;
TriDimensionMap pNrjTransfData[7]
void SelectFasterComputation(G4bool input)
G4int RandomSelect(G4double energy, const G4String &particle)
G4double RandomizeEjectedElectronEnergyFromCumulatedDcs(G4ParticleDefinition *aParticleDefinition, G4double incomingParticleEnergy, G4int shell)
double DifferentialCrossSection(G4ParticleDefinition *aParticleDefinition, G4double k, G4double energyTransfer, G4int shell)
std::map< double, std::vector< double > > VecMap
G4MicroElecSiStructure SiStructure
static const G4double emax
G4double Interpolate(G4double e1, G4double e2, G4double e, G4double xs1, G4double xs2)
G4VAtomDeexcitation * fAtomDeexcitation
std::map< G4String, G4String, std::less< G4String > > MapFile
virtual ~G4MicroElecInelasticModel()
std::map< G4String, G4MicroElecCrossSectionDataSet *, std::less< G4String > > MapData
G4ParticleChangeForGamma * fParticleChangeForGamma
virtual void SampleSecondaries(std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy)
G4MicroElecInelasticModel & operator=(const G4MicroElecInelasticModel &right)
std::map< double, std::map< double, double > > TriDimensionMap
G4double QuadInterpolator(G4double e11, G4double e12, G4double e21, G4double e22, G4double x11, G4double x12, G4double x21, G4double x22, G4double t1, G4double t2, G4double t, G4double e)
virtual G4double CrossSectionPerVolume(const G4Material *material, const G4ParticleDefinition *p, G4double ekin, G4double emin, G4double emax)
std::vector< double > pTdummyVec
G4MicroElecInelasticModel(const G4ParticleDefinition *p=0, const G4String &nam="MicroElecInelasticModel")
TriDimensionMap eDiffCrossSectionData[7]
std::map< G4String, G4double, std::less< G4String > > lowEnergyLimit
G4double RandomizeEjectedElectronEnergy(G4ParticleDefinition *aParticleDefinition, G4double incomingParticleEnergy, G4int shell)
TriDimensionMap pDiffCrossSectionData[7]
TriDimensionMap eNrjTransfData[7]
virtual void Initialise(const G4ParticleDefinition *, const G4DataVector &)
std::vector< double > eTdummyVec
G4double TransferedEnergy(G4ParticleDefinition *aParticleDefinition, G4double incomingParticleEnergy, G4int shell, G4double random)
std::map< G4String, G4double, std::less< G4String > > highEnergyLimit