OPAL (Object Oriented Parallel Accelerator Library)
2.2.0
OPAL
|
#include <BorisPusher.h>
Public Member Functions | |
BorisPusher (const PartData &ref) | |
BorisPusher () | |
void | initialise (const PartData *ref) |
void | kick (const Vector_t &R, Vector_t &P, const Vector_t &Ef, const Vector_t &Bf, const double &dt) const |
void | kick (const Vector_t &R, Vector_t &P, const Vector_t &Ef, const Vector_t &Bf, const double &dt, const double &mass, const double &charge) const |
void | push (Vector_t &R, const Vector_t &P, const double &dt) const |
Private Attributes | |
const PartData * | itsReference |
Definition at line 13 of file BorisPusher.h.
|
inline |
Definition at line 35 of file BorisPusher.h.
|
inline |
Definition at line 39 of file BorisPusher.h.
|
inline |
Definition at line 43 of file BorisPusher.h.
References itsReference, and Hypervolume::ref.
Referenced by Bend2D::setupPusher().
|
inline |
Definition at line 48 of file BorisPusher.h.
References PartData::getM(), PartData::getQ(), and itsReference.
Referenced by Bend2D::calculateBendAngle(), Bend2D::calculateRefTrajectory(), OrbitThreader::integrate(), ParallelCyclotronTracker::kick(), LF2< FieldFunction, Arguments >::kick_m(), ParallelTTracker::kickParticles(), ParallelSliceTracker::updateReferenceParticle(), and ParallelTTracker::updateReferenceParticle().
|
inline |
Definition at line 56 of file BorisPusher.h.
References Physics::c, cross(), dot(), and sqrt().
\[ \vec{x}_{n+1/2} = \vec{x}_{n} + \frac{1}{2}\vec{v}_{n-1/2}\quad (= \vec{x}_{n} + \frac{\Delta t}{2} \frac{\vec{\beta}_{n-1/2}\gamma_{n-1/2}}{\gamma_{n-1/2}}) \]
Definition at line 116 of file BorisPusher.h.
Referenced by ParallelTTracker::applyFractionalStep(), ParallelSliceTracker::autophaseCavities(), ParallelTTracker::autophaseCavities(), Bend2D::calculateBendAngle(), Bend2D::calculateRefTrajectory(), OrbitThreader::execute(), ParallelSliceTracker::findStartPosition(), OrbitThreader::integrate(), ParallelTTracker::pushParticles(), OrbitThreader::trackBack(), ParallelSliceTracker::updateReferenceParticle(), and ParallelTTracker::updateReferenceParticle().
|
private |
Definition at line 32 of file BorisPusher.h.
Referenced by initialise(), and kick().