|  | 
|  | G4MuElecElasticModel (const G4ParticleDefinition *p=0, const G4String &nam="MuElecElasticModel") | 
|  | 
| virtual | ~G4MuElecElasticModel () | 
|  | 
| virtual void | Initialise (const G4ParticleDefinition *, const G4DataVector &) | 
|  | 
| virtual G4double | CrossSectionPerVolume (const G4Material *material, const G4ParticleDefinition *p, G4double ekin, G4double emin, G4double emax) | 
|  | 
| virtual void | SampleSecondaries (std::vector< G4DynamicParticle * > *, const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double tmin, G4double maxEnergy) | 
|  | 
| void | SetKillBelowThreshold (G4double threshold) | 
|  | 
| G4double | GetKillBelowThreshold () | 
|  | 
|  | G4VEmModel (const G4String &nam) | 
|  | 
| virtual | ~G4VEmModel () | 
|  | 
| virtual void | InitialiseLocal (const G4ParticleDefinition *, G4VEmModel *masterModel) | 
|  | 
| virtual void | InitialiseForMaterial (const G4ParticleDefinition *, const G4Material *) | 
|  | 
| virtual void | InitialiseForElement (const G4ParticleDefinition *, G4int Z) | 
|  | 
| virtual G4double | ComputeDEDXPerVolume (const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=DBL_MAX) | 
|  | 
| virtual G4double | ComputeCrossSectionPerAtom (const G4ParticleDefinition *, G4double kinEnergy, G4double Z, G4double A=0., G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| virtual G4double | ChargeSquareRatio (const G4Track &) | 
|  | 
| virtual G4double | GetChargeSquareRatio (const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy) | 
|  | 
| virtual G4double | GetParticleCharge (const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy) | 
|  | 
| virtual void | StartTracking (G4Track *) | 
|  | 
| virtual void | CorrectionsAlongStep (const G4MaterialCutsCouple *, const G4DynamicParticle *, G4double &eloss, G4double &niel, G4double length) | 
|  | 
| virtual G4double | Value (const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy) | 
|  | 
| virtual G4double | MinPrimaryEnergy (const G4Material *, const G4ParticleDefinition *, G4double cut=0.0) | 
|  | 
| virtual G4double | MinEnergyCut (const G4ParticleDefinition *, const G4MaterialCutsCouple *) | 
|  | 
| virtual void | SetupForMaterial (const G4ParticleDefinition *, const G4Material *, G4double kineticEnergy) | 
|  | 
| virtual void | DefineForRegion (const G4Region *) | 
|  | 
| void | InitialiseElementSelectors (const G4ParticleDefinition *, const G4DataVector &) | 
|  | 
| std::vector < G4EmElementSelector * > *
 | GetElementSelectors () | 
|  | 
| void | SetElementSelectors (std::vector< G4EmElementSelector * > *) | 
|  | 
| G4double | ComputeDEDX (const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=DBL_MAX) | 
|  | 
| G4double | CrossSection (const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| G4double | ComputeMeanFreePath (const G4ParticleDefinition *, G4double kineticEnergy, const G4Material *, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| G4double | ComputeCrossSectionPerAtom (const G4ParticleDefinition *, const G4Element *, G4double kinEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| G4int | SelectIsotopeNumber (const G4Element *) | 
|  | 
| const G4Element * | SelectRandomAtom (const G4MaterialCutsCouple *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| const G4Element * | SelectRandomAtom (const G4Material *, const G4ParticleDefinition *, G4double kineticEnergy, G4double cutEnergy=0.0, G4double maxEnergy=DBL_MAX) | 
|  | 
| G4int | SelectRandomAtomNumber (const G4Material *) | 
|  | 
| void | SetParticleChange (G4VParticleChange *, G4VEmFluctuationModel *f=0) | 
|  | 
| void | SetCrossSectionTable (G4PhysicsTable *, G4bool isLocal) | 
|  | 
| G4ElementData * | GetElementData () | 
|  | 
| G4PhysicsTable * | GetCrossSectionTable () | 
|  | 
| G4VEmFluctuationModel * | GetModelOfFluctuations () | 
|  | 
| G4VEmAngularDistribution * | GetAngularDistribution () | 
|  | 
| void | SetAngularDistribution (G4VEmAngularDistribution *) | 
|  | 
| G4double | HighEnergyLimit () const | 
|  | 
| G4double | LowEnergyLimit () const | 
|  | 
| G4double | HighEnergyActivationLimit () const | 
|  | 
| G4double | LowEnergyActivationLimit () const | 
|  | 
| G4double | PolarAngleLimit () const | 
|  | 
| G4double | SecondaryThreshold () const | 
|  | 
| G4bool | LPMFlag () const | 
|  | 
| G4bool | DeexcitationFlag () const | 
|  | 
| G4bool | ForceBuildTableFlag () const | 
|  | 
| G4bool | UseAngularGeneratorFlag () const | 
|  | 
| void | SetAngularGeneratorFlag (G4bool) | 
|  | 
| void | SetHighEnergyLimit (G4double) | 
|  | 
| void | SetLowEnergyLimit (G4double) | 
|  | 
| void | SetActivationHighEnergyLimit (G4double) | 
|  | 
| void | SetActivationLowEnergyLimit (G4double) | 
|  | 
| G4bool | IsActive (G4double kinEnergy) | 
|  | 
| void | SetPolarAngleLimit (G4double) | 
|  | 
| void | SetSecondaryThreshold (G4double) | 
|  | 
| void | SetLPMFlag (G4bool val) | 
|  | 
| void | SetDeexcitationFlag (G4bool val) | 
|  | 
| void | SetForceBuildTable (G4bool val) | 
|  | 
| void | SetMasterThread (G4bool val) | 
|  | 
| G4bool | IsMaster () const | 
|  | 
| G4double | MaxSecondaryKinEnergy (const G4DynamicParticle *dynParticle) | 
|  | 
| const G4String & | GetName () const | 
|  | 
| void | SetCurrentCouple (const G4MaterialCutsCouple *) | 
|  | 
| const G4Element * | GetCurrentElement () const | 
|  | 
Definition at line 51 of file G4MuElecElasticModel.hh.
 
Implements G4VEmModel.
Definition at line 111 of file G4MuElecElasticModel.cc.
References python.hepunit::cm, G4InuclParticleNames::electron, G4Electron::ElectronDefinition(), python.hepunit::eV, FatalException, fParticleChangeForGamma, G4cout, G4endl, G4Exception(), G4VEmModel::GetParticleChangeForGamma(), G4ParticleDefinition::GetParticleName(), G4VEmModel::HighEnergyLimit(), python.hepunit::keV, G4MuElecCrossSectionDataSet::LoadData(), G4VEmModel::LowEnergyLimit(), python.hepunit::MeV, G4VEmModel::SetHighEnergyLimit(), and G4VEmModel::SetLowEnergyLimit().
  115   if (verboseLevel > 3)
 
  116     G4cout << 
"Calling G4MuElecElasticModel::Initialise()" << 
G4endl;
 
  122     G4cout << 
"G4MuElecElasticModel: low energy limit increased from " << 
 
  129     G4cout << 
"G4MuElecElasticModel: high energy limit decreased from " << 
 
  138   G4String fileElectron(
"microelec/sigma_elastic_e_Si");
 
  155     char *path = getenv(
"G4LEDATA");
 
  163     std::ostringstream eFullFileName;
 
  164     eFullFileName << path << 
"/microelec/sigmadiff_elastic_e_Si.dat";
 
  165     std::ifstream eDiffCrossSection(eFullFileName.str().c_str());
 
  167     if (!eDiffCrossSection) 
 
  168     G4Exception(
"G4MuElecElasticModel::Initialise",
"em0003",
FatalException,
"Missing data file: /microelec/sigmadiff_elastic_e_Si.dat");
 
  170     eTdummyVec.push_back(0.);
 
  172     while(!eDiffCrossSection.eof())
 
  176     eDiffCrossSection>>tDummy>>eDummy;
 
  179         if (tDummy != eTdummyVec.back()) 
 
  181           eTdummyVec.push_back(tDummy); 
 
  182           eVecm[tDummy].push_back(0.);
 
  185         eDiffCrossSection>>eDiffCrossSectionData[tDummy][eDummy];
 
  188         if (!eDiffCrossSection.eof()) eDiffCrossSectionData[tDummy][eDummy]*=scaleFactor;
 
  190         if (eDummy != eVecm[tDummy].back()) eVecm[tDummy].push_back(eDummy);
 
  196   if (verboseLevel > 2) 
 
  197     G4cout << 
"Loaded cross section files for MuElec Elastic model" << 
G4endl;
 
  201     G4cout << 
"MuElec Elastic model is initialized " << G4endl
 
  208   if (isInitialised) { 
return; }
 
  210   isInitialised = 
true;
 
static G4Electron * ElectronDefinition()
G4double LowEnergyLimit() const 
G4double HighEnergyLimit() const 
virtual G4bool LoadData(const G4String &argFileName)
const G4String & GetParticleName() const 
void SetHighEnergyLimit(G4double)
G4GLOB_DLL std::ostream G4cout
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
G4ParticleChangeForGamma * fParticleChangeForGamma
void SetLowEnergyLimit(G4double)
G4ParticleChangeForGamma * GetParticleChangeForGamma()