71 G4double psq = particle1->getMomentum().mag2();
77 G4double y = 1.0 - ranres * (1.0 - z);
83 if((particle1->getType() ==
Proton && particle2->getType() ==
Neutron) ||
84 (particle1->getType() ==
Neutron && particle2->getType() ==
Proton)) {
87 apt = (800.0/pl)*(800.0/pl);
88 G4double cpt = std::max(6.23 * std::exp(-1.79*x), 0.3);
90 G4double aaa = (1 + apt) * (1 - std::exp(-btmax))/b;
96 argu = std::exp(-4.0 * argu);
99 G4double aac = cpt * (1.0 - argu)/alphac;
102 z = std::exp(-4.0 * psq *alphac);
104 y = 1.0 - ranres*(1.0 - z);
105 T = std::log(y)/alphac;
111 if(std::abs(ctet) > 1.0) ctet =
Math::sign(ctet);
112 G4double stet = std::sqrt(1.0 - ctet*ctet);
119 G4double xx = particle1->getMomentum().perp2();
120 G4double zz = std::pow(particle1->getMomentum().getZ(), 2);
122 if(xx >= (zz * 1.0e-8)) {
127 ez[0] = p.
getX() / pnorm;
128 ez[1] = p.
getY() / pnorm;
129 ez[2] = p.
getZ() / pnorm;
132 ex[0] = p.
getY() / yn;
133 ex[1] = -p.
getX() / yn;
140 G4double pX = (ex[0]*cfi*stet + ey[0]*sfi*stet + ez[0]*ctet) * pnorm;
141 G4double pY = (ex[1]*cfi*stet + ey[1]*sfi*stet + ez[1]*ctet) * pnorm;
142 G4double pZ = (ex[2]*cfi*stet + ey[2]*sfi*stet + ez[2]*ctet) * pnorm;
145 particle1->setMomentum(p1momentum);
146 particle2->setMomentum(-p1momentum);
148 G4double momZ = particle1->getMomentum().getZ();
154 particle1->setMomentum(p1momentum);
155 particle2->setMomentum(-p1momentum);
160 if((particle1->getType() ==
Proton && particle2->getType() ==
Neutron) ||
161 (particle1->getType() ==
Neutron && particle2->getType() ==
Proton)) {
165 apt = std::pow(800.0/pl, 2);
167 if(iexpi == 1 || rndm > 1.0/(1.0 + apt)) {
168 particle1->setType(p2TypeOld);
169 particle2->setType(p1TypeOld);
G4int getIsospin(const ParticleType t)
Get the isospin of a particle.
const G4double effectiveNucleonMass