74 const G4double sqrtS = theParticle->getMass();
76 theParticle->setType(
Lambda);
78 sampleAngles(&c_tet, &s_tet, &phi);
82 G4double beta = incidentDirection.mag();
87 sal = incidentDirection.perp()/beta;
89 G4double b1 = incidentDirection.getX();
90 G4double b2 = incidentDirection.getY();
91 G4double b3 = incidentDirection.getZ();
93 G4double t1 = c_tet+cal*s_tet*s_phi/sal;
95 q1=(b1*t1+b2*t2*c_phi)/beta;
96 q2=(b2*t1-b1*t2*c_phi)/beta;
97 q3=(b3*t1/beta-t2*s_phi);
105 theParticle->getMass(),
112 ThreeVector createdPosition(theParticle->getPosition());
113 Particle *createdParticle =
new Particle(createdType, createdMomentum, createdPosition);
114 theParticle->setMomentum(-createdMomentum);
115 theParticle->adjustEnergyFromMomentum();
const G4INCL::ThreeVector & getMomentum() 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)
G4double getWidth(const ParticleType t)
Get particle width (in s)