46 :
G4Mag_EqRhs( MagField ), charge(0.), mass(0.), magMoment(0.),
47 spin(0.), omegac(0.), anomaly(0.0011659208), beta(0.), gamma(0.)
63 spin = particleCharge.
GetSpin();
70 if ( spin != 0. ) g_BMT = (magMoment/muB)/spin;
73 anomaly = (g_BMT - 2.)/2.;
86 G4double inv_momentum_magnitude = 1.0 / std::sqrt( momentum_mag_square );
89 dydx[0] = y[3] * inv_momentum_magnitude;
90 dydx[1] = y[4] * inv_momentum_magnitude;
91 dydx[2] = y[5] * inv_momentum_magnitude;
98 dydx[3] = cof*(y[4]*B[2] - y[5]*B[1]) ;
99 dydx[4] = cof*(y[5]*B[0] - y[3]*B[2]) ;
100 dydx[5] = cof*(y[3]*B[1] - y[4]*B[0]) ;
104 u *= inv_momentum_magnitude;
108 G4double udb = anomaly*beta*gamma/(1.+gamma) * (BField * u);
109 G4double ucb = (anomaly+1./gamma)/beta;
112 dydx[6] = dydx[7] = dydx[8] = 0.0;
117 if (charge == 0.) pcharge = 1.;
118 else pcharge = charge;
121 if (Spin.
mag2() != 0.) {
122 dSpin = pcharge*omegac*(ucb*(Spin.
cross(BField))-udb*(Spin.
cross(u)));
125 dydx[ 9] = dSpin.
x();
126 dydx[10] = dSpin.
y();
127 dydx[11] = dSpin.
z();
void SetChargeMomentumMass(G4ChargeState particleCharge, G4double MomentumXc, G4double mass)
G4double GetCharge() const
G4double GetMagneticDipoleMoment() const
Hep3Vector cross(const Hep3Vector &) const
G4Mag_SpinEqRhs(G4MagneticField *MagField)
void EvaluateRhsGivenB(const G4double y[], const G4double B[3], G4double dydx[]) const