73 aDataFile >> theMassCode >> theMass >> theIsomerFlag >> theDistLaw >> theGroundStateQValue
74 >> theActualStateQValue;
75 theGroundStateQValue *= CLHEP::eV;
76 theActualStateQValue *= CLHEP::eV;
77 theYield.Init(aDataFile, CLHEP::eV);
79 if (theDistLaw == 0) {
84 else if (theDistLaw == 1) {
88 else if (theDistLaw == 2) {
92 else if (theDistLaw == 3) {
96 else if (theDistLaw == 4) {
106 else if (theDistLaw == 6) {
110 else if (theDistLaw == 7) {
116 "distribution law unknown to G4ParticleHPProduct");
118 if (theDist !=
nullptr) {
119 theDist->SetQValue(theActualStateQValue);
120 theDist->Init(aDataFile);
151 if (theDist ==
nullptr) {
156 theDist->SetTarget(fCache.Get().theTarget);
157 theDist->SetProjectileRP(fCache.Get().theProjectileRP);
159 theDist->ClearHistories();
161 for (
G4int i = 0; i < multi; ++i) {
162 tmp = theDist->Sample(anEnergy, theMassCode, theMass);
163 if (tmp !=
nullptr) {
164 result->push_back(tmp);
167 G4cout <<
"multi=" << multi <<
" i=" << i <<
" G4ParticleHPProduct::Sample "
174 tmp = theDist->Sample(anEnergy, theMassCode, theMass);
const G4String & GetParticleName() const
static G4ParticleHPManager * GetInstance()
G4ReactionProductVector * Sample(G4double anEnergy, G4int nParticles)
void Init(std::istream &aDataFile, const G4ParticleDefinition *projectile)
G4int GetMultiplicity(G4double anEnergy)