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)
G4double DistChord() const
void Stepper(const G4double P[], const G4double dPdS[], G4double step, G4double Po[], G4double Err[])