25 template <
typename FieldFunction,
typename ... Arguments>
26 class RK4 :
public Stepper<FieldFunction, Arguments...> {
30 RK4(
const FieldFunction& fieldfunc) :
Stepper<FieldFunction, Arguments ...>(fieldfunc) { }
37 Arguments& ... args)
const;
54 Arguments& ... args)
const;
constexpr double q_e
The elementary charge in As.
constexpr double c
The velocity of light in m/s.
4-th order Runnge-Kutta stepper
bool derivate_m(PartBunchBase< double, 3 > *bunch, double *y, const double &t, double *yp, const size_t &i, Arguments &... args) const
RK4(const FieldFunction &fieldfunc)
bool doAdvance_m(PartBunchBase< double, 3 > *bunch, const size_t &i, const double &t, const double dt, Arguments &... args) const
void copyFrom(Vector_t &R, Vector_t &P, double *x) const
void copyTo(const Vector_t &R, const Vector_t &P, double *x) const