48 #ifndef G4HadronicProcess_h
49 #define G4HadronicProcess_h 1
112 { theCrossSectionDataStore->
AddDataSet(aDataSet);}
124 {
return &targetNucleus; }
141 aMaterial,anElement);
146 {
return &targetNucleus; }
154 { useIntegralXS = val; }
161 { epCheckLevels.first = relativeLevel;
162 epCheckLevels.second = absoluteLevel;
163 levelsSetByProcess =
true;
167 {
return epCheckLevels; }
171 {
return theCrossSectionDataStore;}
174 { aScaleFactor = factor; }
182 {
return theInteraction; }
186 {
return theLastCrossSection; }
200 G4double XBiasSurvivalProbability();
208 void GetEnergyMomentumCheckEnvvars();
230 bool G4HadronicProcess_debug_flag;
237 std::pair<G4double, G4double> epCheckLevels;
238 G4bool levelsSetByProcess;
240 std::vector<G4VLeadingParticleBiasing *> theBias;
242 G4double theInitialNumberOfInteractionLength;
G4double G4ParticleHPJENDLHEData::G4double result
void AddDataSet(G4VCrossSectionDataSet *)
std::ostringstream G4ExceptionDescription
void BiasCrossSectionByFactor(G4double aScale)
G4double GetMicroscopicCrossSection(const G4DynamicParticle *part, const G4Element *elm, const G4Material *mat=nullptr)
std::vector< ExP01TrackerHit * > a
G4HadronicInteraction * GetHadronicInteraction(const G4HadProjectile &aHadProjectile, G4Nucleus &aTargetNucleus, const G4Material *aMaterial, const G4Element *anElement) const
G4double GetElementCrossSection(const G4DynamicParticle *part, const G4Element *elm, const G4Material *mat=nullptr)
void SetIntegral(G4bool val)
virtual void PreparePhysicsTable(const G4ParticleDefinition &)
void CheckEnergyMomentumConservation(const G4Track &, const G4Nucleus &)
const G4Isotope * GetTargetIsotope()
std::vector< G4HadronicInteraction * > & GetHadronicInteractionList()
void RegisterMe(G4HadronicInteraction *a)
virtual void BuildPhysicsTable(const G4ParticleDefinition &)
void DumpState(const G4Track &, const G4String &, G4ExceptionDescription &)
void AddDataSet(G4VCrossSectionDataSet *aDataSet)
void FillResult(G4HadFinalState *aR, const G4Track &aT)
G4ParticleChange * theTotalResult
const G4Nucleus * GetTargetNucleus() const
G4double GetMeanFreePath(const G4Track &aTrack, G4double, G4ForceCondition *)
G4CrossSectionDataStore * GetCrossSectionDataStore()
virtual void ProcessDescription(std::ostream &outFile) const
void SetEnergyMomentumCheckLevels(G4double relativeLevel, G4double absoluteLevel)
void SetEpReportLevel(G4int level)
void DumpPhysicsTable(const G4ParticleDefinition &)
G4HadronicInteraction * GetHadronicInteraction() const
G4Nucleus * GetTargetNucleusPointer()
const G4Isotope * GetIsotope()
virtual ~G4HadronicProcess()
void DumpPhysicsTable(const G4ParticleDefinition &p)
void MultiplyCrossSectionBy(G4double factor)
G4HadronicInteraction * ChooseHadronicInteraction(const G4HadProjectile &aHadProjectile, G4Nucleus &aTargetNucleus, G4Material *aMaterial, G4Element *anElement)
G4HadronicProcess(const G4String &processName="Hadronic", G4ProcessType procType=fHadronic)
virtual G4VParticleChange * PostStepDoIt(const G4Track &aTrack, const G4Step &aStep)
std::pair< G4double, G4double > GetEnergyMomentumCheckLevels() const
G4double GetLastCrossSection()
G4HadFinalState * CheckResult(const G4HadProjectile &thePro, const G4Nucleus &targetNucleus, G4HadFinalState *result)
std::vector< G4HadronicInteraction * > & GetHadronicInteractionList()