106 void clearCurrentFSData();
111 std::pair<G4double, G4double> find_LH(
G4double, std::vector<G4double>*);
113 std::pair<G4double, G4double>);
119 std::pair<G4double, G4double> sample_inelastic_E_mu(
G4double pE,
120 std::vector<E_P_E_isoAng*>* vNEP_EPM);
121 std::pair<G4double, G4int> sample_inelastic_E(
G4double rndm1,
G4double rndm2,
124 std::pair<G4double, E_isoAng>
125 create_sE_and_EPM_from_pE_and_vE_P_E_isoAng(
G4double,
G4double, std::vector<E_P_E_isoAng*>*);
127 void buildPhysicsTable();
138 std::map<G4int, std::map<G4double, std::vector<std::pair<G4double, G4double>*>*>*>* coherentFSs{
nullptr};
139 std::map<G4double, std::vector<std::pair<G4double, G4double>*>*>* readACoherentFSDATA(
const G4String&);
143 std::map<G4int, std::map<G4double, std::vector<E_isoAng*>*>*>* incoherentFSs{
nullptr};
144 std::map<G4double, std::vector<E_isoAng*>*>* readAnIncoherentFSDATA(
const G4String&);
145 E_isoAng* readAnE_isoAng(std::istream*);
149 std::map<G4int, std::map<G4double, std::vector<E_P_E_isoAng*>*>*>* inelasticFSs{
nullptr};
150 std::map<G4double, std::vector<E_P_E_isoAng*>*>* readAnInelasticFSDATA(
const G4String&);
157 std::map<std::pair<const G4Material*, const G4Element*>,
G4int> dic;
160 std::size_t nMaterial;
161 std::size_t nElement;
void ModelDescription(std::ostream &outFile) const override
const std::pair< G4double, G4double > GetFatalEnergyCheckLevels() const override
~G4ParticleHPThermalScattering() override
G4HadFinalState * ApplyYourself(const G4HadProjectile &aTrack, G4Nucleus &aTargetNucleus) override
void BuildPhysicsTable(const G4ParticleDefinition &) override
void AddUserThermalScatteringFile(const G4String &, const G4String &)