44     m_magdistance( distanceConstField ),
 
   50   m_fldPosition[0]  = m_iPoint[0] = m_fPoint[0] = m_mPoint[0] = 9.9999999e+99 ;
 
   51   m_fldPosition[1]  = m_iPoint[1] = m_fPoint[1] = m_mPoint[1] = 9.9999999e+99 ;
 
   52   m_fldPosition[2]  = m_iPoint[2] = m_fPoint[2] = m_mPoint[2] = 9.9999999e+99 ;
 
   53   m_fldPosition[3]  = -9.9999999e+99;
 
   54   m_lastField[0] = m_lastField[1] = m_lastField[2] = 0.0;
 
   56   m_magdistance2 = distanceConstField*distanceConstField;
 
   75   G4double R[3] = {   P[0],   P[1] ,    P[2]};
 
   76   G4double A[3] = {dPdS[0], dPdS[1], dPdS[2]};
 
   78   m_iPoint[0]=R[0]; m_iPoint[1]=R[1]; m_iPoint[2]=R[2];
 
   94   G4double K1[3] = { m_imom*dPdS[3], m_imom*dPdS[4], m_imom*dPdS[5] };
 
   99            R[1]+S5*(A[1]+S4*K1[1]),
 
  100            R[2]+S5*(A[2]+S4*K1[2]),
 
  104   G4double A2[3] = {A[0]+S5*K1[0],A[1]+S5*K1[1],A[2]+S5*K1[2]};
 
  105   G4double K2[3] = {(A2[1]*m_lastField[2]-A2[2]*m_lastField[1])*m_cof,
 
  106             (A2[2]*m_lastField[0]-A2[0]*m_lastField[2])*m_cof,
 
  107             (A2[0]*m_lastField[1]-A2[1]*m_lastField[0])*m_cof};
 
  109   m_mPoint[0]=p[0]; m_mPoint[1]=p[1]; m_mPoint[2]=p[2];
 
  113   G4double A3[3] = {A[0]+S5*K2[0],A[1]+S5*K2[1],A[2]+S5*K2[2]};
 
  114   G4double K3[3] = {(A3[1]*m_lastField[2]-A3[2]*m_lastField[1])*m_cof,
 
  115             (A3[2]*m_lastField[0]-A3[0]*m_lastField[2])*m_cof,
 
  116             (A3[0]*m_lastField[1]-A3[1]*m_lastField[0])*m_cof};
 
  120   p[0] = R[0]+S*(A[0]+S5*K3[0]);
 
  121   p[1] = R[1]+S*(A[1]+S5*K3[1]);
 
  122   p[2] = R[2]+S*(A[2]+S5*K3[2]);             
 
  126   G4double A4[3] = {A[0]+S*K3[0],A[1]+S*K3[1],A[2]+S*K3[2]};
 
  127   G4double K4[3] = {(A4[1]*m_lastField[2]-A4[2]*m_lastField[1])*m_cof,
 
  128             (A4[2]*m_lastField[0]-A4[0]*m_lastField[2])*m_cof,
 
  129             (A4[0]*m_lastField[1]-A4[1]*m_lastField[0])*m_cof};
 
  133   Po[0] = P[0]+S*(A[0]+S6*(K1[0]+K2[0]+K3[0]));
 
  134   Po[1] = P[1]+S*(A[1]+S6*(K1[1]+K2[1]+K3[1]));
 
  135   Po[2] = P[2]+S*(A[2]+S6*(K1[2]+K2[2]+K3[2]));
 
  137   m_fPoint[0]=Po[0]; m_fPoint[1]=Po[1]; m_fPoint[2]=Po[2];
 
  141   Po[3] = A[0]+S6*(K1[0]+K4[0]+2.*(K2[0]+K3[0]));
 
  142   Po[4] = A[1]+S6*(K1[1]+K4[1]+2.*(K2[1]+K3[1]));
 
  143   Po[5] = A[2]+S6*(K1[2]+K4[2]+2.*(K2[2]+K3[2]));
 
  147   Err[3] = S*std::fabs(K1[0]-K2[0]-K3[0]+K4[0]);
 
  148   Err[4] = S*std::fabs(K1[1]-K2[1]-K3[1]+K4[1]);
 
  149   Err[5] = S*std::fabs(K1[2]-K2[2]-K3[2]+K4[2]);
 
  159   G4double normF = m_mom/std::sqrt(Po[3]*Po[3]+Po[4]*Po[4]+Po[5]*Po[5]);
 
  160   Po [3]*=normF; Po[4]*=normF; Po[5]*=normF; 
 
  163   Po[6]=P[6]; Po[7]=P[7];
 
  174   G4double ax = m_fPoint[0]-m_iPoint[0];  
 
  175   G4double ay = m_fPoint[1]-m_iPoint[1];  
 
  176   G4double az = m_fPoint[2]-m_iPoint[2];
 
  177   G4double dx = m_mPoint[0]-m_iPoint[0]; 
 
  178   G4double dy = m_mPoint[1]-m_iPoint[1]; 
 
  179   G4double dz = m_mPoint[2]-m_iPoint[2];
 
  183     G4double ds = (ax*dx+ay*dy+az*dz)/d2;
 
  188   return std::sqrt(dx*dx+dy*dy+dz*dz);
 
  198   G4double P4vec[4]= { P[0], P[1], P[2], P[7] }; 
 
  200   m_mom   = std::sqrt(P[3]*P[3]+P[4]*P[4]+P[5]*P[5])     ; 
 
  202   m_cof   = m_fEq->
FCof()*m_imom                    ;
 
  204   dPdS[0] = P[3]*m_imom                             ; 
 
  205   dPdS[1] = P[4]*m_imom                             ; 
 
  206   dPdS[2] = P[5]*m_imom                             ; 
 
  207   dPdS[3] = m_cof*(P[4]*m_lastField[2]-P[5]*m_lastField[1]) ; 
 
  208   dPdS[4] = m_cof*(P[5]*m_lastField[0]-P[3]*m_lastField[2]) ; 
 
  209   dPdS[5] = m_cof*(P[3]*m_lastField[1]-P[4]*m_lastField[0]) ; 
 
virtual void ComputeRightHandSide(const double P[], double dPdS[])
 
G4NystromRK4(G4Mag_EqRhs *EquationMotion, G4double distanceConstField=0.0)
 
double A(double temperature)
 
G4double DistChord() const 
 
void Stepper(const G4double P[], const G4double dPdS[], G4double step, G4double Po[], G4double Err[])