93 const G4double sqrtS = theParticle->getMass();
96 switch (theParticle->getType()) {
101 theParticle->setType(
Photon);
104 else if (drnd < 0.7265) {
106 theParticle->setType(
PiZero);
110 else if (drnd < 0.9575) {
112 theParticle->setType(
PiZero);
118 theParticle->setType(
Photon);
126 theParticle->setType(
PiZero);
130 else if (drnd < 0.9845) {
133 theParticle->setType(
PiZero);
139 theParticle->setType(
PiPlus);
144 INCL_FATAL(
"Unrecognized pion resonance type; type=" << theParticle->getType() <<
'\n');
150 sampleAngles(&ctet, &stet, &fi);
154 G4double beta = incidentDirection.mag();
159 sal = incidentDirection.perp()/beta;
161 G4double b1 = incidentDirection.getX();
162 G4double b2 = incidentDirection.getY();
163 G4double b3 = incidentDirection.getZ();
165 G4double t1 = ctet+cal*stet*sfi/sal;
167 q1=(b1*t1+b2*t2*cfi)/beta;
168 q2=(b2*t1-b1*t2*cfi)/beta;
169 q3=(b3*t1/beta-t2*sfi);
177 theParticle->getMass(),
184 ThreeVector createdPosition(theParticle->getPosition());
185 Particle *createdParticle =
new Particle(createdType, createdMomentum, createdPosition);
186 theParticle->setMomentum(-createdMomentum);
187 theParticle->adjustEnergyFromMomentum();
193 else if (nbpart == 3) {
196 list.push_back(theParticle);
197 const ThreeVector &rposdecay = theParticle->getPosition();
201 list.push_back(Pion1);
202 list.push_back(Pion2);
G4double getEnergy() const
G4INCL::ParticleType getType() const
G4double getMass() const
Get the cached particle mass.
G4double getINCLMass(const G4int A, const G4int Z, const G4int S)
Get INCL nuclear mass (in MeV/c^2)