10#ifndef IMPACTX_SOFTQUAD_H
11#define IMPACTX_SOFTQUAD_H
64 -9.056149864743113E-002,
65 1.803476331179615E-002,
66 4.464887700797893E-002,
67 7.364410636252136E-003,
68 -1.697541023436736E-002,
69 -9.012679515542771E-003,
70 4.367667630047725E-003,
71 5.444030542119803E-003,
72 -5.889959910931886E-005,
73 -2.409098101409192E-003,
74 -7.962712154165590E-004,
75 7.855814707106538E-004,
76 6.174930463182168E-004,
77 -1.340154094301854E-004,
78 -3.167213724698439E-004,
79 -4.925292460592617E-005,
80 1.221580597451921E-004,
81 6.331025910961789E-005,
82 -3.202416719002774E-005,
83 -3.872103053895529E-005,
84 8.212882937116278E-007
88 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
89 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
106 inline std::map<int, std::vector<amrex::ParticleReal>>
h_cos_coef = {};
108 inline std::map<int, std::vector<amrex::ParticleReal>>
h_sin_coef = {};
111 inline std::map<int, amrex::Gpu::DeviceVector<amrex::ParticleReal>>
d_cos_coef = {};
113 inline std::map<int, amrex::Gpu::DeviceVector<amrex::ParticleReal>>
d_sin_coef = {};
126 static constexpr auto type =
"SoftQuadrupole";
146 amrex::ParticleReal
ds,
147 amrex::ParticleReal gscale,
148 std::vector<amrex::ParticleReal> cos_coef,
149 std::vector<amrex::ParticleReal> sin_coef,
150 amrex::ParticleReal
dx = 0,
151 amrex::ParticleReal
dy = 0,
152 amrex::ParticleReal rotation_degree = 0,
157 std::optional<std::string>
name = std::nullopt
169 m_ncoef = int(cos_coef.size());
170 if (
m_ncoef !=
int(sin_coef.size()))
171 throw std::runtime_error(
"SoftQuadrupole: cos and sin coefficients must have same length!");
183 cos_coef.begin(), cos_coef.end(),
186 sin_coef.begin(), sin_coef.end(),
196 using BeamOptic::operator();
207 using namespace amrex::literals;
209 Alignment::compute_constants(refpart);
226 template<
typename T_Real=amrex::ParticleReal,
typename T_IdCpu=u
int64_t>
239 using namespace amrex::literals;
255 auto const out = R *
v;
279 using namespace amrex::literals;
283 amrex::ParticleReal
const x = refpart.x;
284 amrex::ParticleReal
const px = refpart.px;
285 amrex::ParticleReal
const y = refpart.y;
286 amrex::ParticleReal
const py = refpart.py;
287 amrex::ParticleReal
const z = refpart.z;
288 amrex::ParticleReal
const pz = refpart.pz;
289 amrex::ParticleReal
const pt = refpart.pt;
290 amrex::ParticleReal
const s = refpart.s;
291 amrex::ParticleReal
const sedge = refpart.sedge;
294 refpart.map =
decltype(refpart.map)::Identity();
297 amrex::ParticleReal
const slice_ds =
m_ds /
nslice();
300 amrex::ParticleReal
const bgi = std::sqrt(powi<2>(pt) - 1.0_prt);
303 amrex::ParticleReal
const zin =
s - sedge;
304 amrex::ParticleReal
const zout = zin + slice_ds;
308 amrex::ParticleReal
const ptf = refpart.pt;
322 refpart.x = x + slice_ds*px/bgi;
323 refpart.y = y + slice_ds*py/bgi;
324 refpart.z = z + slice_ds*pz/bgi;
327 amrex::ParticleReal
const bgf = std::sqrt(powi<2>(ptf) - 1.0_prt);
330 refpart.px = px*bgf/bgi;
331 refpart.py = py*bgf/bgi;
332 refpart.pz = pz*bgf/bgi;
335 refpart.s =
s + slice_ds;
339 using LinearTransport::operator();
363 std::tuple<amrex::ParticleReal, amrex::ParticleReal, amrex::ParticleReal>
367 using namespace amrex::literals;
371#if AMREX_DEVICE_COMPILE
381 amrex::ParticleReal
const zlen =
m_ds;
382 amrex::ParticleReal
const zmid = zlen * 0.5_prt;
385 amrex::ParticleReal bfield = 0.0;
386 amrex::ParticleReal bfieldp = 0.0;
387 amrex::ParticleReal bfieldint = 0.0;
388 amrex::ParticleReal
const z = zeval - zmid;
390 if (std::abs(z) <= zmid)
392 bfield = 0.5_prt*cos_data[0];
393 bfieldint = z*bfield;
394 for (
int j=1; j <
m_ncoef; ++j)
396 bfield = bfield + cos_data[j] *std::cos(j * 2 * pi * z / zlen) +
397 sin_data[j] *std::sin(j * 2 * pi * z / zlen);
398 bfieldp = bfieldp - j * 2 * pi * cos_data[j] *std::sin(j * 2 * pi * z / zlen) / zlen +
399 j * 2 * pi * sin_data[j] *std::cos(j * 2 * pi * z / zlen) / zlen;
400 bfieldint = bfieldint + zlen * cos_data[j] *std::sin(j * 2 * pi * z / zlen) / (j * 2 * pi) -
401 zlen * sin_data[j] *std::cos(j * 2 * pi * z / zlen) / (j * 2 * pi);
404 return std::make_tuple(bfield, bfieldp, bfieldint);
416 void map1 (amrex::ParticleReal
const tau,
418 [[maybe_unused]] amrex::ParticleReal & zeval)
const
420 using namespace amrex::literals;
424 amrex::ParticleReal
const t = refpart.
t;
425 amrex::ParticleReal
const pt = refpart.
pt;
426 amrex::ParticleReal
const z = zeval;
429 refpart.
t =
t + tau/std::sqrt(1.0_prt - powi<-2>(pt));
441 amrex::ParticleReal
const betgam = refpart.
beta_gamma();
443 refpart.
map(1,1) = R(1,1) + tau*R(2,1);
444 refpart.
map(1,2) = R(1,2) + tau*R(2,2);
445 refpart.
map(1,3) = R(1,3) + tau*R(2,3);
446 refpart.
map(1,4) = R(1,4) + tau*R(2,4);
448 refpart.
map(3,1) = R(3,1) + tau*R(4,1);
449 refpart.
map(3,2) = R(3,2) + tau*R(4,2);
450 refpart.
map(3,3) = R(3,3) + tau*R(4,3);
451 refpart.
map(3,4) = R(3,4) + tau*R(4,4);
453 refpart.
map(5,5) = R(5,5) + tau*R(6,5)/powi<2>(betgam);
454 refpart.
map(5,6) = R(5,6) + tau*R(6,6)/powi<2>(betgam);
467 void map2 (amrex::ParticleReal
const tau,
469 amrex::ParticleReal & zeval)
const
471 using namespace amrex::literals;
473 amrex::ParticleReal
const t = refpart.
t;
474 amrex::ParticleReal
const pt = refpart.
pt;
477 amrex::ParticleReal
const G0 =
m_gscale;
488 amrex::ParticleReal
const alpha = G0*bz;
490 refpart.
map(2,1) = R(2,1) - tau*
alpha*R(1,1);
491 refpart.
map(2,2) = R(2,2) - tau*
alpha*R(1,2);
492 refpart.
map(2,3) = R(2,3) - tau*
alpha*R(1,3);
493 refpart.
map(2,4) = R(2,4) - tau*
alpha*R(1,4);
495 refpart.
map(4,1) = R(4,1) + tau*
alpha*R(3,1);
496 refpart.
map(4,2) = R(4,2) + tau*
alpha*R(3,2);
497 refpart.
map(4,3) = R(4,3) + tau*
alpha*R(3,3);
498 refpart.
map(4,4) = R(4,4) + tau*
alpha*R(3,4);
#define AMREX_FORCE_INLINE
#define AMREX_GPU_HOST_DEVICE
T_ParticleType ParticleType
static constexpr amrex::Real pi
void copyAsync(HostToDevice, InIter begin, InIter end, OutIter result) noexcept
static constexpr HostToDevice hostToDevice
void streamSynchronize() noexcept
PODVector< T, ArenaAllocator< T > > DeviceVector
constexpr T powi(T x) noexcept
__host__ __device__ void ignore_unused(const Ts &...)
SmallMatrix< T, N, 1, Order::F, StartIndex > SmallVector
Definition SoftQuad.H:101
std::map< int, amrex::Gpu::DeviceVector< amrex::ParticleReal > > d_cos_coef
device: cosine coefficients in Fourier expansion of on-axis magnetic field Bz
Definition SoftQuad.H:111
std::map< int, std::vector< amrex::ParticleReal > > h_sin_coef
host: sine coefficients in Fourier expansion of on-axis magnetic field Bz
Definition SoftQuad.H:108
std::map< int, amrex::Gpu::DeviceVector< amrex::ParticleReal > > d_sin_coef
device: sine coefficients in Fourier expansion of on-axis magnetic field Bz
Definition SoftQuad.H:113
std::map< int, std::vector< amrex::ParticleReal > > h_cos_coef
host: cosine coefficients in Fourier expansion of on-axis magnetic field Bz
Definition SoftQuad.H:106
int next_id
last used id for a created soft quad
Definition SoftQuad.H:103
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void symp2_integrate(RefPart &refpart, amrex::ParticleReal const zin, amrex::ParticleReal const zout, int const nsteps, T_Element const &element)
Definition Integrators.H:36
@ s
fixed s as the independent variable
Definition ImpactXParticleContainer.H:37
@ t
fixed t as the independent variable
Definition ImpactXParticleContainer.H:38
amrex::SmallMatrix< amrex::ParticleReal, 6, 6, amrex::Order::F, 1 > Map6x6
Definition CovarianceMatrix.H:20
static constexpr __host__ __device__ SmallMatrix< T, NRows, NCols, ORDER, StartIndex > Identity() noexcept
Definition ReferenceParticle.H:31
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal beta_gamma() const
Definition ReferenceParticle.H:110
amrex::ParticleReal pt
energy, normalized by rest energy
Definition ReferenceParticle.H:40
amrex::SmallMatrix< amrex::ParticleReal, 6, 6, amrex::Order::F, 1 > map
linearized map
Definition ReferenceParticle.H:45
amrex::ParticleReal t
clock time * c in meters
Definition ReferenceParticle.H:36
amrex::Vector< amrex::ParticleReal > default_cos_coef
Definition SoftQuad.H:59
amrex::Vector< amrex::ParticleReal > default_sin_coef
Definition SoftQuad.H:87
static constexpr auto type
Definition SoftQuad.H:126
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map1(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftQuad.H:416
amrex::ParticleReal * m_sin_h_data
non-owning pointer to host cosine coefficients
Definition SoftQuad.H:525
int m_ncoef
unique soft quad id used for data lookup map
Definition SoftQuad.H:523
ImpactXParticleContainer::ParticleType PType
Definition SoftQuad.H:127
amrex::ParticleReal * m_cos_d_data
non-owning pointer to host sine coefficients
Definition SoftQuad.H:526
SoftQuadrupole(amrex::ParticleReal ds, amrex::ParticleReal gscale, std::vector< amrex::ParticleReal > cos_coef, std::vector< amrex::ParticleReal > sin_coef, amrex::ParticleReal dx=0, amrex::ParticleReal dy=0, amrex::ParticleReal rotation_degree=0, amrex::ParticleReal aperture_x=0, amrex::ParticleReal aperture_y=0, int mapsteps=1, int nslice=1, std::optional< std::string > name=std::nullopt)
Definition SoftQuad.H:145
int m_id
number of map integration steps per slice
Definition SoftQuad.H:521
AMREX_GPU_HOST AMREX_FORCE_INLINE Map6x6 transport_map(RefPart const &AMREX_RESTRICT refpart) const
Definition SoftQuad.H:348
amrex::ParticleReal * m_cos_h_data
number of Fourier coefficients
Definition SoftQuad.H:524
std::tuple< amrex::ParticleReal, amrex::ParticleReal, amrex::ParticleReal > AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE Quad_Bfield(amrex::ParticleReal const zeval) const
Definition SoftQuad.H:365
void finalize()
Definition SoftQuad.H:505
amrex::ParticleReal m_gscale
Definition SoftQuad.H:519
int m_mapsteps
scaling factor for quad field gradient
Definition SoftQuad.H:520
amrex::ParticleReal * m_sin_d_data
non-owning pointer to device cosine coefficients
Definition SoftQuad.H:527
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void operator()(T_Real &AMREX_RESTRICT x, T_Real &AMREX_RESTRICT y, T_Real &AMREX_RESTRICT t, T_Real &AMREX_RESTRICT px, T_Real &AMREX_RESTRICT py, T_Real &AMREX_RESTRICT pt, T_IdCpu &AMREX_RESTRICT idcpu, RefPart const &AMREX_RESTRICT refpart) const
Definition SoftQuad.H:228
void compute_constants(RefPart const &refpart)
Definition SoftQuad.H:205
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map2(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftQuad.H:467
Definition alignment.H:27
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void shift_out(T_Real &AMREX_RESTRICT x, T_Real &AMREX_RESTRICT y, T_Real &AMREX_RESTRICT px, T_Real &AMREX_RESTRICT py) const
Definition alignment.H:109
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal dy() const
Definition alignment.H:146
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal dx() const
Definition alignment.H:136
Alignment(amrex::ParticleReal dx, amrex::ParticleReal dy, amrex::ParticleReal rotation_degree)
Definition alignment.H:36
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void shift_in(T_Real &AMREX_RESTRICT x, T_Real &AMREX_RESTRICT y, T_Real &AMREX_RESTRICT px, T_Real &AMREX_RESTRICT py) const
Definition alignment.H:78
Definition beamoptic.H:219
Definition lineartransport.H:29
AMREX_GPU_HOST Named(std::optional< std::string > name)
Definition named.H:57
AMREX_FORCE_INLINE std::string name() const
Definition named.H:122
Definition pipeaperture.H:26
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void apply_aperture(T_Real &AMREX_RESTRICT x, T_Real &AMREX_RESTRICT y, T_IdCpu &AMREX_RESTRICT idcpu) const
Definition pipeaperture.H:59
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal aperture_x() const
Definition pipeaperture.H:90
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal aperture_y() const
Definition pipeaperture.H:101
PipeAperture(amrex::ParticleReal aperture_x, amrex::ParticleReal aperture_y)
Definition pipeaperture.H:32
Thick(amrex::ParticleReal ds, int nslice)
Definition thick.H:30
amrex::ParticleReal m_ds
Definition thick.H:58
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal ds() const
Definition thick.H:53
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE int nslice() const
Definition thick.H:43