105 const G4double deltaMass = theParticle->getMass();
108 sampleAngles(&ctet, &stet, &fi);
112 G4double beta = incidentDirection.mag();
117 sal = incidentDirection.perp()/beta;
119 G4double b1 = incidentDirection.getX();
120 G4double b2 = incidentDirection.getY();
121 G4double b3 = incidentDirection.getZ();
123 G4double t1 = ctet+cal*stet*sfi/sal;
125 q1=(b1*t1+b2*t2*cfi)/beta;
126 q2=(b2*t1-b1*t2*cfi)/beta;
127 q3=(b3*t1/beta-t2*sfi);
133 theParticle->setHelicity(0.0);
136#ifdef INCLXX_IN_GEANT4_MODE
137 G4int deltaPDGCode = 0;
139 switch(theParticle->getType()) {
141 theParticle->setType(
Proton);
143#ifdef INCLXX_IN_GEANT4_MODE
152 theParticle->setType(
Proton);
155#ifdef INCLXX_IN_GEANT4_MODE
161 theParticle->setType(
Proton);
167#ifdef INCLXX_IN_GEANT4_MODE
174#ifdef INCLXX_IN_GEANT4_MODE
179 INCL_FATAL(
"Unrecognized delta type; type=" << theParticle->getType() <<
'\n');
185 theParticle->getMass(),
193 ThreeVector pionPosition(theParticle->getPosition());
195 theParticle->setMomentum(-pionMomentum);
196 theParticle->adjustEnergyFromMomentum();
198#ifdef INCLXX_IN_GEANT4_MODE
201 G4int parentResonanceID =
static_cast<G4int>(round(deltaMass/CLHEP::keV));
202 pion->setParentResonancePDGCode(deltaPDGCode);
203 pion->setParentResonanceID(parentResonanceID);
204 theParticle->setParentResonancePDGCode(deltaPDGCode);
205 theParticle->setParentResonanceID(parentResonanceID);
G4double getEnergy() 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)
const G4double effectiveNucleonMass
const G4double effectivePionMass