56 aDataFile >> theTargetCode >> theAngularRep >> theInterpolation >> nEnergy;
57 const std::size_t esize = nEnergy > 0 ? nEnergy : 1;
59 theManager.
Init(aDataFile);
60 for (
G4int i = 0; i < nEnergy; ++i) {
61 theAngular[i].Init(aDataFile, theProjectile);
62 theAngular[i].SetInterpolation(theInterpolation);
64 theAngular[i].PrepareTableInterpolation();
75 for (i = 0; i < nEnergy; ++i) {
78 if (theAngular[i].GetEnergy() > anEnergy)
break;
80 if (theAngular[i].GetEnergy() >= anEnergy)
break;
90 theAngular[0].SetTargetCode(theTargetCode);
92 result = theAngular[0].Sample(anEnergy, massCode, targetMass, theAngularRep, theInterpolation);
108 theAngular[it].SetTargetCode(theTargetCode);
110 result = theAngular[it].Sample(anEnergy, massCode, targetMass, theAngularRep, theInterpolation);
114 if (fCacheAngular.Get() ==
nullptr) {
116 fCacheAngular.Put(angpar);
118 fCacheAngular.Get()->SetInterpolation(theInterpolation);
119 fCacheAngular.Get()->BuildByInterpolation(anEnergy, theManager.GetScheme(0),
120 (theAngular[it - 1]), (theAngular[it]));
121 fCacheAngular.Get()->SetTarget(
GetTarget());
122 fCacheAngular.Get()->SetTargetCode(theTargetCode);
126 fCacheAngular.Get()->Sample(anEnergy, massCode, targetMass, theAngularRep, theInterpolation);
127 currentMeanEnergy.Put(fCacheAngular.Get()->MeanEnergyOfThisInteraction());
void Init(std::istream &aDataFile, const G4ParticleDefinition *projectile)
G4ParticleHPContEnergyAngular(const G4ParticleDefinition *proj)
G4double MeanEnergyOfThisInteraction() override
void Init(std::istream &aDataFile) override
G4ReactionProduct * Sample(G4double anEnergy, G4double massCode, G4double mass) override
~G4ParticleHPContEnergyAngular() override
void ClearHistories() override
G4ReactionProduct * GetTarget() const
G4ReactionProduct * GetProjectileRP() const