7#ifndef WARPX_ACCELERATORLATTICE_ACCELERATORLATTICE_H_
8#define WARPX_ACCELERATORLATTICE_ACCELERATORLATTICE_H_
33 ReadLattice (std::string
const & root_name, amrex::ParticleReal & z_location);
52 amrex::Real gamma_boost,
std::unique_ptr< amrex::LayoutData< LatticeElementFinder > > m_element_finder
Definition AcceleratorLattice.H:68
LatticeElementFinderDevice GetFinderDeviceInstance(WarpXParIter const &a_pti, int a_offset, const amrex::Vector< amrex::Real > &dts) const
Return an instance of a lattice finder associated with the grid and that can be used on the device (s...
Definition AcceleratorLattice.cpp:111
void ReadLattice(std::string const &root_name, amrex::ParticleReal &z_location)
Read in the MAD like lattice description.
Definition AcceleratorLattice.cpp:39
HardEdgedPlasmaLens h_plasmalens
Definition AcceleratorLattice.H:84
void InitElementFinder(int lev, amrex::Real gamma_boost, const amrex::Vector< amrex::Real > &time, amrex::BoxArray const &ba, amrex::DistributionMapping const &dm)
Initialize the element finder instance at the given level of refinement.
Definition AcceleratorLattice.cpp:84
Drift h_drift
Definition AcceleratorLattice.H:82
bool m_lattice_defined
Definition AcceleratorLattice.H:39
HardEdgedQuadrupole h_quad
Definition AcceleratorLattice.H:83
AcceleratorLattice()
Definition AcceleratorLattice.cpp:20
int m_level
Definition AcceleratorLattice.H:36
void UpdateElementFinder(int lev, const amrex::Vector< amrex::Real > &time)
Update the element finder, needed when the simulation frame has moved relative to the lab frame.
Definition AcceleratorLattice.cpp:99
Definition WarpXParticleContainer.H:117
Definition HardEdgedPlasmaLens.H:26
Definition HardEdgedQuadrupole.H:26
The lattice element finder class that can be trivially copied to the device. This only has simple dat...
Definition LatticeElementFinder.H:108