|
OPALX (Object Oriented Parallel Accelerator Library for Exascal) master (dc2a29eed580)
OPALX
|
#include <Tracker.h>
Public Types | |
| enum | { X , PX , Y , PY , T , PT } |
Public Member Functions | |
| Tracker (const Beamline &, bool backBeam, bool backTrack) | |
| Constructor. | |
| Tracker (const Beamline &, PartBunch_t &bunch, bool backBeam, bool backTrack) | |
| Construct a tracker that borrows an existing particle bunch. | |
| virtual | ~Tracker () |
| PartBunch_t & | getBunch () const |
| Return the currently attached borrowed bunch. | |
| void | addToBunch (const OpalParticle &) |
| Add particle to bunch. | |
| virtual void | visitComponent (const Component &) |
| Store the bunch. | |
| virtual void | setNumBunch (short) |
| set total number of tracked bunches | |
| virtual short | getNumBunch () |
| get total number of tracked bunches | |
| void | execute () override |
| Apply the algorithm to the top-level beamline. | |
| void | visitBeamline (const Beamline &) override |
| Apply the algorithm to a beam line. | |
| void | visitConstantEFieldCavity (const ConstantEFieldCavity &) override |
| Apply the algorithm to a constant E-field cavity element. | |
| void | visitDrift (const Drift &) override |
| Apply the algorithm to a drift space. | |
| void | visitLaser (const Laser &) override |
| Apply the algorithm to a laser. | |
| void | visitFlaggedElmPtr (const FlaggedElmPtr &) override |
| Apply the algorithm to a FlaggedElmPtr. | |
| void | visitMarker (const Marker &) override |
| Apply the algorithm to a marker. | |
| void | visitMonitor (const Monitor &) override |
| Apply the algorithm to a beam position monitor. | |
| void | visitMultipole (const Multipole &) override |
| Apply the algorithm to a multipole. | |
| void | visitMultipoleT (const MultipoleT &) override |
| Apply the algorithm to an arbitrary multipole. | |
| void | visitRBend (const RBend &) override |
| Apply the algorithm to a rectangular bend. | |
| void | visitRing (const Ring &) override |
| Apply the algorithm to a Ring. | |
| void | visitSBend (const SBend &) override |
| Apply the algorithm to a sector bend. | |
| void | visitRFCavity (const RFCavity &) override |
| Apply the algorithm to a RF cavity. | |
| void | visitSolenoid (const Solenoid &) override |
| Apply the algorithm to a Solenoid. | |
| void | visitTravelingWave (const TravelingWave &) override |
| Apply the algorithm to a traveling wave. | |
| void | visitScalingFFAMagnet (const ScalingFFAMagnet &spiral) override |
| Apply the algorithm to a scaling FFA magnet. | |
| void | visitVerticalFFAMagnet (const VerticalFFAMagnet &) override |
| Apply the algorithm to a vertical FFA magnet. | |
| void | visitVariableRFCavity (const VariableRFCavity &) override |
| Apply the algorithm to a variable RF cavity. | |
| void | visitProbe (const Probe &prob) override |
| Apply the algorithm to a Probe. | |
Public Attributes | |
| FieldList | cavities_m |
| const Beamline & | itsBeamline_m |
Protected Attributes | |
| PartBunch_t * | itsBunch_m |
| The bunch of particles to be tracked. Borrowed; lifetime is managed by TrackRun. | |
| const Beamline & | itsLine |
| bool | back_beam |
| bool | back_track |
| bool | back_path |
| double | flip_B |
| double | flip_s |
Private Member Functions | |
| Tracker () | |
| Tracker (const Tracker &) | |
| void | operator= (const Tracker &) |
| virtual void | applyDefault (const ElementBase &) |
Private Attributes | |
| bool | local_flip |
|
inherited |
| Enumerator | |
|---|---|
| X | |
| PX | |
| Y | |
| PY | |
| T | |
| PT | |
Definition at line 36 of file AbstractTracker.h.
| Tracker::Tracker | ( | const Beamline & | beamline, |
| bool | backBeam, | ||
| bool | backTrack | ||
| ) |
Constructor.
Definition at line 76 of file Tracker.cpp.
| Tracker::Tracker | ( | const Beamline & | beamline, |
| PartBunch_t & | bunch, | ||
| bool | backBeam, | ||
| bool | backTrack | ||
| ) |
Construct a tracker that borrows an existing particle bunch.
| bunch | Particle bunch to track. Ownership remains with the caller. |
Definition at line 81 of file Tracker.cpp.
|
virtual |
Definition at line 84 of file Tracker.cpp.
|
private |
|
private |
| void Tracker::addToBunch | ( | const OpalParticle & | ) |
|
privatevirtualinherited |
Definition at line 113 of file DefaultVisitor.cpp.
Referenced by DefaultVisitor::visitComponent(), DefaultVisitor::visitConstantEFieldCavity(), DefaultVisitor::visitDrift(), DefaultVisitor::visitLaser(), DefaultVisitor::visitMarker(), DefaultVisitor::visitMonitor(), DefaultVisitor::visitMultipole(), DefaultVisitor::visitMultipoleT(), DefaultVisitor::visitProbe(), DefaultVisitor::visitRBend(), DefaultVisitor::visitRFCavity(), DefaultVisitor::visitRing(), DefaultVisitor::visitSBend(), DefaultVisitor::visitScalingFFAMagnet(), DefaultVisitor::visitSolenoid(), DefaultVisitor::visitTravelingWave(), DefaultVisitor::visitVariableRFCavity(), and DefaultVisitor::visitVerticalFFAMagnet().
|
overridevirtualinherited |
Apply the algorithm to the top-level beamline.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker, RangeSelector, and Selector.
Definition at line 54 of file DefaultVisitor.cpp.
References ElementBase::accept(), DefaultVisitor::back_beam, DefaultVisitor::back_track, DefaultVisitor::itsLine, and DefaultVisitor::local_flip.
Referenced by RangeSelector::execute(), Line::replace(), Sequence::replace(), and Select::select().

| PartBunch_t & Tracker::getBunch | ( | ) | const |
Return the currently attached borrowed bunch.
Definition at line 86 of file Tracker.cpp.
References itsBunch_m.
|
inlinevirtual |
|
private |
|
inlinevirtual |
|
overridevirtualinherited |
Apply the algorithm to a beam line.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 97 of file DefaultVisitor.cpp.
References Beamline::iterate(), and DefaultVisitor::local_flip.

|
virtual |
Store the bunch.
Apply the algorithm to an arbitrary component.
Reimplemented from DefaultVisitor.
Reimplemented in ParallelTracker.
Definition at line 101 of file Tracker.cpp.
References DefaultVisitor::back_beam, DefaultVisitor::back_track, PartBunch< T, Dim >::getReference(), itsBunch_m, and Component::trackBunch().
Referenced by ParallelTracker::visitComponent().
|
overridevirtualinherited |
Apply the algorithm to a constant E-field cavity element.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 61 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a drift space.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 65 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a FlaggedElmPtr.
Implements BeamlineVisitor.
Reimplemented in Flagger, Replacer, and RangeSelector.
Definition at line 103 of file DefaultVisitor.cpp.
References ElementBase::accept(), ElmPtr::getElement(), FlaggedElmPtr::getReflectionFlag(), and DefaultVisitor::local_flip.
Referenced by RangeSelector::handleBeamline(), RangeSelector::handleElement(), Flagger::visitFlaggedElmPtr(), and Replacer::visitFlaggedElmPtr().

|
overridevirtualinherited |
Apply the algorithm to a laser.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 67 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a marker.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 69 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a beam position monitor.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 71 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a multipole.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 73 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to an arbitrary multipole.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 75 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a Probe.
Implements BeamlineVisitor.
Definition at line 95 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a rectangular bend.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 77 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a RF cavity.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 81 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a Ring.
Implements BeamlineVisitor.
Definition at line 79 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a sector bend.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 83 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a scaling FFA magnet.
Implements BeamlineVisitor.
Definition at line 89 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a Solenoid.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 85 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a traveling wave.
Implements BeamlineVisitor.
Reimplemented in ParallelTracker.
Definition at line 87 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a variable RF cavity.
Implements BeamlineVisitor.
Definition at line 93 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
overridevirtualinherited |
Apply the algorithm to a vertical FFA magnet.
Implements BeamlineVisitor.
Definition at line 91 of file DefaultVisitor.cpp.
References DefaultVisitor::applyDefault().

|
protectedinherited |
Definition at line 110 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor(), DefaultVisitor::execute(), and visitComponent().
|
protectedinherited |
Definition at line 112 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor().
|
protectedinherited |
Definition at line 111 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor(), DefaultVisitor::execute(), and visitComponent().
|
protectedinherited |
Definition at line 115 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor().
|
protectedinherited |
Definition at line 116 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor().
| const Beamline& Tracker::itsBeamline_m |
Definition at line 115 of file Tracker.h.
Referenced by ParallelTracker::prepareSections().
|
protected |
The bunch of particles to be tracked. Borrowed; lifetime is managed by TrackRun.
Definition at line 119 of file Tracker.h.
Referenced by ParallelTracker::activateEmittingContainers(), ParallelTracker::applyGlobalProcesses(), ParallelTracker::autophaseCavities(), ParallelTracker::changeDT(), ParallelTracker::computeExternalFields(), ParallelTracker::computeInitialBounds(), ParallelTracker::computeSpaceChargeFields(), ParallelTracker::deleteInvalidParticles(), ParallelTracker::dumpStats(), ParallelTracker::emitFromEmissionSources(), ParallelTracker::evolveSpinTBMT(), ParallelTracker::execute(), ParallelTracker::findStartPositions(), getBunch(), ParallelTracker::hasEndOfLineReached(), ParallelTracker::markBackwardParticlesAtSourcePlane(), ParallelTracker::printInitialContainerRefs(), ParallelTracker::resetFields(), ParallelTracker::selectDT(), ParallelTracker::setTime(), ParallelTracker::timeIntegration1(), ParallelTracker::timeIntegration2(), ParallelTracker::updateReferenceParticles(), ParallelTracker::updateRefToLabCSTrafo(), visitComponent(), ParallelTracker::visitConstantEFieldCavity(), ParallelTracker::visitDrift(), ParallelTracker::visitMarker(), ParallelTracker::visitMonitor(), ParallelTracker::visitMultipole(), ParallelTracker::visitMultipoleT(), ParallelTracker::visitRBend(), ParallelTracker::visitRFCavity(), ParallelTracker::visitSBend(), ParallelTracker::visitSolenoid(), ParallelTracker::visitTravelingWave(), and ParallelTracker::writePhaseSpace().
|
protectedinherited |
Definition at line 107 of file DefaultVisitor.h.
Referenced by DefaultVisitor::execute().
|
privateinherited |
Definition at line 130 of file DefaultVisitor.h.
Referenced by DefaultVisitor::DefaultVisitor(), DefaultVisitor::execute(), DefaultVisitor::visitBeamline(), and DefaultVisitor::visitFlaggedElmPtr().