ImpactX
Loading...
Searching...
No Matches
SoftQuad.H
Go to the documentation of this file.
1/* Copyright 2022-2026 The Regents of the University of California, through Lawrence
2 * Berkeley National Laboratory (subject to receipt of any required
3 * approvals from the U.S. Dept. of Energy). All rights reserved.
4 *
5 * This file is part of ImpactX.
6 *
7 * Authors: Chad Mitchell, Axel Huebl
8 * License: BSD-3-Clause-LBNL
9 */
10#ifndef IMPACTX_SOFTQUAD_H
11#define IMPACTX_SOFTQUAD_H
12
15#include "mixin/alignment.H"
16#include "mixin/beamoptic.H"
17#include "mixin/dynamicdata.H"
19#include "mixin/named.H"
20#include "mixin/nofinalize.H"
21#include "mixin/pipeaperture.H"
22#include "mixin/thick.H"
23#include "mixin/spintransport.H"
24#include "mixin/TrackedVector.H"
25
26#include <ablastr/constant.H>
27
28#include <AMReX.H>
29#include <AMReX_Extension.H>
30#include <AMReX_Math.H>
31#include <AMReX_REAL.H>
32#include <AMReX_SIMD.H>
33#include <AMReX_SmallMatrix.H>
34
35#include <cmath>
36#include <memory>
37#include <stdexcept>
38#include <tuple>
39#include <vector>
40
41
42namespace impactx::elements
43{
63 {
65 0.834166514794446,
66 0.598104328994702,
67 0.141852844428785,
68 -0.118211272182381,
69 -9.056149864743113E-002,
70 1.803476331179615E-002,
71 4.464887700797893E-002,
72 7.364410636252136E-003,
73 -1.697541023436736E-002,
74 -9.012679515542771E-003,
75 4.367667630047725E-003,
76 5.444030542119803E-003,
77 -5.889959910931886E-005,
78 -2.409098101409192E-003,
79 -7.962712154165590E-004,
80 7.855814707106538E-004,
81 6.174930463182168E-004,
82 -1.340154094301854E-004,
83 -3.167213724698439E-004,
84 -4.925292460592617E-005,
85 1.221580597451921E-004,
86 6.331025910961789E-005,
87 -3.202416719002774E-005,
88 -3.872103053895529E-005,
89 8.212882937116278E-007
90 };
91
93 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
94 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
95 0, 0, 0, 0, 0
96 };
97 };
98
109
111 : public mixin::Named,
112 public mixin::BeamOptic<SoftQuadrupole>,
113 public mixin::LinearTransport<SoftQuadrupole>,
114 public mixin::Thick,
115 public mixin::Alignment,
116 public mixin::NoFinalize,
117 public mixin::PipeAperture,
119 public amrex::simd::Vectorized<amrex::simd::native_simd_size_particlereal>
120 {
121 static constexpr auto type = "SoftQuadrupole";
123
125
144 amrex::ParticleReal gscale,
145 std::vector<amrex::ParticleReal> cos_coef,
146 std::vector<amrex::ParticleReal> sin_coef,
149 amrex::ParticleReal rotation_degree = 0,
152 int mapsteps = 10,
153 int nslice = 1,
154 std::optional<std::string> name = std::nullopt
155 )
156 : Named(std::move(name)),
157 Thick(ds, nslice),
158 Alignment(dx, dy, rotation_degree),
160 m_gscale(gscale), m_mapsteps(mapsteps),
161 m_id(DynamicData::allocate_id())
162 {
163 m_ncoef = int(cos_coef.size());
164 if (m_ncoef != int(sin_coef.size()))
165 throw std::runtime_error("SoftQuadrupole: cos and sin coefficients must have same length!");
166
167 auto& coef = DynamicData::emplace(
168 m_id,
169 std::move(cos_coef),
170 std::move(sin_coef)
171 );
172 m_cos_h_data = coef.cos.host_const().data();
173 m_sin_h_data = coef.sin.host_const().data();
174 }
175
177 void reverse () {
178 // Reversing ds traverses the Fourier profile in the opposite z direction,
179 // so the odd sine terms change sign implicitly via sin(-kz) = -sin(kz).
180 Thick::reverse();
181 }
182
184 using BeamOptic::operator();
185
193 void compute_constants (RefPart const & refpart)
194 {
195 using namespace amrex::literals; // for _rt and _prt
196
197 Alignment::compute_constants(refpart);
198
199 // Ensure dynamic coefficient data is on GPU and we have fresh pointers to it
200 auto const & coef = *DynamicData::get(m_id);
201 m_cos_d_data = coef.cos.device_const().data();
202 m_sin_d_data = coef.sin.device_const().data();
203 }
204
219 template<typename T_Real=amrex::ParticleReal, typename T_IdCpu=uint64_t>
222 T_Real & AMREX_RESTRICT x,
223 T_Real & AMREX_RESTRICT y,
224 T_Real & AMREX_RESTRICT t,
225 T_Real & AMREX_RESTRICT px,
226 T_Real & AMREX_RESTRICT py,
227 T_Real & AMREX_RESTRICT pt,
228 [[maybe_unused]] T_IdCpu const & AMREX_RESTRICT idcpu,
229 [[maybe_unused]] RefPart const & AMREX_RESTRICT refpart
230 ) const
231 {
232 using namespace amrex::literals; // for _rt and _prt
233
234 // get the linear map
236
237 // symplectic linear map for a quadrupole is computed using the
238 // Hamiltonian formalism as described in:
239 // https://uspas.fnal.gov/materials/09UNM/ComputationalMethods.pdf .
240 // R denotes the transfer matrix in the basis (x,px,y,py,t,pt),
241 // so that, e.g., R(3,4) = dyf/dpyi.
242 amrex::SmallVector<T_Real, 6, 1> const v{x, px, y, py, t, pt};
243
244 // push particles using the linear map
245 auto const out = R * v;
246
247 // assign updated values
248 x = out[1];
249 px = out[2];
250 y = out[3];
251 py = out[4];
252 t = out[5];
253 pt = out[6];
254 }
255
261 void operator() (RefPart & AMREX_RESTRICT refpart) const
262 {
263 using namespace amrex::literals; // for _rt and _prt
264 using amrex::Math::powi;
265
266 // assign input reference particle values
267 amrex::ParticleReal const x = refpart.x;
268 amrex::ParticleReal const px = refpart.px;
269 amrex::ParticleReal const y = refpart.y;
270 amrex::ParticleReal const py = refpart.py;
271 amrex::ParticleReal const z = refpart.z;
272 amrex::ParticleReal const pz = refpart.pz;
273 amrex::ParticleReal const pt = refpart.pt;
274 amrex::ParticleReal const s = refpart.s;
275 amrex::ParticleReal const sedge = refpart.sedge;
276
277 // initialize linear map (deviation) values
278 m_map = decltype(m_map)::Identity();
279
280 // initialize the spin-orbit coupling matrix
281 m_spin_coupling = {};
282
283 // length of the current slice
284 amrex::ParticleReal const slice_ds = m_ds / nslice();
285
286 // compute initial value of beta*gamma
287 amrex::ParticleReal const bgi = std::sqrt(powi<2>(pt) - 1.0_prt);
288
289 // call integrator to advance (t,pt)
290 amrex::ParticleReal const zin = s - sedge;
291 amrex::ParticleReal const zout = zin + slice_ds;
292 int const nsteps = m_mapsteps;
293
294 integrators::symp2_integrate(refpart,zin,zout,nsteps,*this);
295 amrex::ParticleReal const ptf = refpart.pt;
296
297 /*
298 // print computed linear map:
299 for(int i=1; i<7; ++i){
300 for(int j=1; j<7; ++j){
301 amrex::PrintToFile("QuadMap.txt") << i << " " <<
302 j << " " << m_map(i,j) << "\n";
303 }
304 }
305 //
306 */
307
308 // advance position (x,y,z)
309 refpart.x = x + slice_ds*px/bgi;
310 refpart.y = y + slice_ds*py/bgi;
311 refpart.z = z + slice_ds*pz/bgi;
312
313 // compute final value of beta*gamma
314 amrex::ParticleReal const bgf = std::sqrt(powi<2>(ptf) - 1.0_prt);
315
316 // advance momentum (px,py,pz)
317 refpart.px = px*bgf/bgi;
318 refpart.py = py*bgf/bgi;
319 refpart.pz = pz*bgf/bgi;
320
321 // advance integrated path length
322 refpart.s = s + slice_ds;
323 }
324
325
340 template<typename T_Real=amrex::ParticleReal, typename T_IdCpu=uint64_t>
343 T_Real & AMREX_RESTRICT x,
344 T_Real & AMREX_RESTRICT y,
345 T_Real & AMREX_RESTRICT t,
346 T_Real & AMREX_RESTRICT px,
347 T_Real & AMREX_RESTRICT py,
348 T_Real & AMREX_RESTRICT pt,
349 T_Real & AMREX_RESTRICT sx,
350 T_Real & AMREX_RESTRICT sy,
351 T_Real & AMREX_RESTRICT sz,
352 T_IdCpu const & AMREX_RESTRICT idcpu,
353 RefPart const & AMREX_RESTRICT refpart
354 ) const
355 {
356 using namespace amrex::literals; // for _rt and _prt
357
358 // initialize the three components of the axis-angle vector
359 T_Real lambdax = 0_prt;
360 T_Real lambday = 0_prt;
361 T_Real lambdaz = 0_prt;
362
363 // store the phase space variables in vector form
364 amrex::SmallVector<T_Real, 6, 1> const v{x, px, y, py, t, pt};
365
366 // get the spin-orbit coupling matrix
368
369 // use phase space variables to obtain the angle-axis generator of spin rotation
370 auto const out = A * v;
371
372 // update the angle-axis generator
373 lambdax = out[1];
374 lambday = out[2];
375 lambdaz = out[3];
376
377 // push the spin vector using the generator just determined
378 rotate_spin(lambdax,lambday,lambdaz,sx,sy,sz);
379
380 // phase space push
381 (*this)(x, y, t, px, py, pt, idcpu, refpart);
382 }
383
384
386 using LinearTransport::operator();
387
394 Map6x6
395 transport_map ([[maybe_unused]] RefPart const & AMREX_RESTRICT refpart) const
396 {
397
399 R = m_map;
400
401 // apply the transverse rotation (roll) alignment error
402 return rotate_aligned_map(R);
403 }
404
411 std::tuple<amrex::ParticleReal, amrex::ParticleReal, amrex::ParticleReal>
414 {
415 using namespace amrex::literals; // for _rt and _prt
416
417 // pick the right data depending if we are on the host side
418 // (reference particle push) or device side (particles):
419#if AMREX_DEVICE_COMPILE
420 amrex::ParticleReal const * cos_data = m_cos_d_data;
421 amrex::ParticleReal const * sin_data = m_sin_d_data;
422#else
423 amrex::ParticleReal const * cos_data = m_cos_h_data;
424 amrex::ParticleReal const * sin_data = m_sin_h_data;
425#endif
426
427 // specify constants
429 amrex::ParticleReal const zlen = std::abs(m_ds);
430 amrex::ParticleReal const zmid = zlen * 0.5_prt;
431
432 // compute on-axis magnetic field (z is relative to quadrupole midpoint)
433 amrex::ParticleReal bfield = 0.0;
434 amrex::ParticleReal bfieldp = 0.0;
435 amrex::ParticleReal bfieldint = 0.0;
436 amrex::ParticleReal const z = zeval - zmid;
437
438 if (std::abs(z) <= zmid)
439 {
440 bfield = 0.5_prt*cos_data[0];
441 bfieldint = z*bfield;
442 for (int j=1; j < m_ncoef; ++j)
443 {
444 bfield = bfield + cos_data[j] *std::cos(j * 2 * pi * z / zlen) +
445 sin_data[j] *std::sin(j * 2 * pi * z / zlen);
446 bfieldp = bfieldp - j * 2 * pi * cos_data[j] *std::sin(j * 2 * pi * z / zlen) / zlen +
447 j * 2 * pi * sin_data[j] *std::cos(j * 2 * pi * z / zlen) / zlen;
448 bfieldint = bfieldint + zlen * cos_data[j] *std::sin(j * 2 * pi * z / zlen) / (j * 2 * pi) -
449 zlen * sin_data[j] *std::cos(j * 2 * pi * z / zlen) / (j * 2 * pi);
450 }
451 }
452 return std::make_tuple(bfield, bfieldp, bfieldint);
453 }
454
464 void map1 (amrex::ParticleReal const tau,
465 RefPart & refpart,
466 [[maybe_unused]] amrex::ParticleReal & zeval) const
467 {
468 using namespace amrex::literals; // for _rt and _prt
469 using amrex::Math::powi;
470
471 // push the reference particle
472 amrex::ParticleReal const t = refpart.t;
473 amrex::ParticleReal const pt = refpart.pt;
474 amrex::ParticleReal const z = zeval;
475
476 if (pt < -1.0_prt) {
477 refpart.t = t + tau/std::sqrt(1.0_prt - powi<-2>(pt));
478 refpart.pt = pt;
479 }
480 else {
481 refpart.t = t;
482 refpart.pt = pt;
483 }
484
485 zeval = z + tau;
486
487 // push the linear map equations
489 amrex::ParticleReal const betgam = refpart.beta_gamma();
490
491 m_map(1,1) = R(1,1) + tau*R(2,1);
492 m_map(1,2) = R(1,2) + tau*R(2,2);
493 m_map(1,3) = R(1,3) + tau*R(2,3);
494 m_map(1,4) = R(1,4) + tau*R(2,4);
495
496 m_map(3,1) = R(3,1) + tau*R(4,1);
497 m_map(3,2) = R(3,2) + tau*R(4,2);
498 m_map(3,3) = R(3,3) + tau*R(4,3);
499 m_map(3,4) = R(3,4) + tau*R(4,4);
500
501 m_map(5,5) = R(5,5) + tau*R(6,5) / powi<2>(betgam);
502 m_map(5,6) = R(5,6) + tau*R(6,6) / powi<2>(betgam);
503 }
504
514 void map2 (amrex::ParticleReal const tau,
515 RefPart & refpart,
516 amrex::ParticleReal & zeval) const
517 {
518 using namespace amrex::literals; // for _rt and _prt
519
520 amrex::ParticleReal const t = refpart.t;
521 amrex::ParticleReal const pt = refpart.pt;
522
523 // Define parameters and intermediate constants
524 amrex::ParticleReal const G0 = m_gscale;
525
526 // push the reference particle
527 auto [bz, bzp, bzint] = Quad_Bfield(zeval);
528 amrex::ignore_unused(bzp, bzint);
529
530 refpart.t = t;
531 refpart.pt = pt;
532
533 // push the linear map equations
535 amrex::ParticleReal const alpha = G0*bz;
536
537 m_map(2,1) = R(2,1) - tau*alpha*R(1,1);
538 m_map(2,2) = R(2,2) - tau*alpha*R(1,2);
539 m_map(2,3) = R(2,3) - tau*alpha*R(1,3);
540 m_map(2,4) = R(2,4) - tau*alpha*R(1,4);
541
542 m_map(4,1) = R(4,1) + tau*alpha*R(3,1);
543 m_map(4,2) = R(4,2) + tau*alpha*R(3,2);
544 m_map(4,3) = R(4,3) + tau*alpha*R(3,3);
545 m_map(4,4) = R(4,4) + tau*alpha*R(3,4);
546
547 // BELOW: if spin is needed only:
550 amrex::ParticleReal const gamma = refpart.gamma();
552
553 // Update spin-orbit coupling matrix here
554 dA(1,3) = -(1_prt + G*gamma) * tau * alpha;
555 dA(2,1) = -(1_prt + G*gamma) * tau * alpha;
556
557 // update the spin-orbit coupling matrix here
558 m_spin_coupling = A + dA*R;
559
560 }
561
564 int m_id;
565
566 int m_ncoef = 0;
571
572 // Reference-trajectory linearization around the reference particle.
573 // Computed during the reference-particle push and consumed during the
574 // particle push.
575 // mutable: written by the const reference push before the element is copied
576 // into the particle-push functor.
579 };
580
581} // namespace impactx
582
585
586#endif // IMPACTX_SOFTQUAD_H
#define AMREX_FORCE_INLINE
#define AMREX_RESTRICT
#define AMREX_GPU_HOST_DEVICE
#define AMREX_GPU_HOST
#define IMPACTX_PUSH_EXTERN_TEMPLATE(ElementType)
Definition PushAll.H:78
#define IMPACTX_GPUDATA_EXTERN(ElementType)
Definition dynamicdata.H:169
amrex_particle_real ParticleReal
constexpr T powi(T x) noexcept
__host__ __device__ void ignore_unused(const Ts &...)
SmallMatrix< T, N, 1, Order::F, StartIndex > SmallVector
Definition All.H:56
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:39
@ 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:33
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal beta_gamma() const
Definition ReferenceParticle.H:167
amrex::ParticleReal pt
energy, normalized by rest energy
Definition ReferenceParticle.H:42
amrex::ParticleReal gyromagnetic_anomaly
anomalous magnetic moment [unitless]
Definition ReferenceParticle.H:45
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal gamma() const
Definition ReferenceParticle.H:139
amrex::ParticleReal t
clock time * c in meters
Definition ReferenceParticle.H:38
Definition SoftQuad.H:63
amrex::Vector< amrex::ParticleReal > default_cos_coef
Definition SoftQuad.H:64
amrex::Vector< amrex::ParticleReal > default_sin_coef
Definition SoftQuad.H:92
mixin::TrackedVector< amrex::ParticleReal > sin
Definition SoftQuad.H:107
mixin::TrackedVector< amrex::ParticleReal > cos
Definition SoftQuad.H:106
Definition SoftQuad.H:120
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 const &AMREX_RESTRICT idcpu, RefPart const &AMREX_RESTRICT refpart) const
Definition SoftQuad.H:221
static constexpr auto type
Definition SoftQuad.H:121
mixin::GPUDataRegistry< QuadrupoleFourierCoefficients > DynamicData
Definition SoftQuad.H:124
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map1(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftQuad.H:464
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=10, int nslice=1, std::optional< std::string > name=std::nullopt)
Definition SoftQuad.H:142
int m_ncoef
unique soft quad id used for data lookup map
Definition SoftQuad.H:566
ImpactXParticleContainer::ParticleType PType
Definition SoftQuad.H:122
amrex::ParticleReal const * m_cos_d_data
non-owning pointer to host sine coefficients
Definition SoftQuad.H:569
int m_id
number of map integration steps per slice
Definition SoftQuad.H:564
amrex::ParticleReal const * m_sin_h_data
non-owning pointer to host cosine coefficients
Definition SoftQuad.H:568
AMREX_GPU_HOST AMREX_FORCE_INLINE Map6x6 transport_map(RefPart const &AMREX_RESTRICT refpart) const
Definition SoftQuad.H:395
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:413
amrex::SmallMatrix< amrex::ParticleReal, 3, 6, amrex::Order::F, 1 > m_spin_coupling
linearized map
Definition SoftQuad.H:578
amrex::ParticleReal m_gscale
Definition SoftQuad.H:562
int m_mapsteps
scaling factor for quad field gradient
Definition SoftQuad.H:563
void reverse()
Definition SoftQuad.H:177
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void spin_and_phasespace_push(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_Real &AMREX_RESTRICT sx, T_Real &AMREX_RESTRICT sy, T_Real &AMREX_RESTRICT sz, T_IdCpu const &AMREX_RESTRICT idcpu, RefPart const &AMREX_RESTRICT refpart) const
Definition SoftQuad.H:342
amrex::SmallMatrix< amrex::ParticleReal, 6, 6, amrex::Order::F, 1 > m_map
non-owning pointer to device sine coefficients
Definition SoftQuad.H:577
amrex::ParticleReal const * m_sin_d_data
non-owning pointer to device cosine coefficients
Definition SoftQuad.H:570
amrex::ParticleReal const * m_cos_h_data
number of Fourier coefficients
Definition SoftQuad.H:567
void compute_constants(RefPart const &refpart)
Definition SoftQuad.H:193
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map2(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftQuad.H:514
Definition alignment.H:29
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal dy() const
Definition alignment.H:189
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal dx() const
Definition alignment.H:179
AMREX_GPU_HOST AMREX_FORCE_INLINE Map6x6 rotate_aligned_map(Map6x6 const &R) const
Definition alignment.H:263
Alignment(amrex::ParticleReal dx, amrex::ParticleReal dy, amrex::ParticleReal rotation_degree)
Definition alignment.H:39
Definition beamoptic.H:529
static std::shared_ptr< QuadrupoleFourierCoefficients > const & get(int id)
Definition dynamicdata.H:98
static QuadrupoleFourierCoefficients & emplace(int id, Args &&... args)
Definition dynamicdata.H:125
Definition lineartransport.H:50
Definition named.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 nofinalize.H:22
Definition pipeaperture.H:26
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
Definition spintransport.H:36
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void rotate_spin(T_Real const &AMREX_RESTRICT lambdax, T_Real const &AMREX_RESTRICT lambday, T_Real const &AMREX_RESTRICT lambdaz, T_Real &AMREX_RESTRICT sx, T_Real &AMREX_RESTRICT sy, T_Real &AMREX_RESTRICT sz) const
Definition spintransport.H:48
Definition thick.H:24
Thick(amrex::ParticleReal ds, int nslice)
Definition thick.H:30
amrex::ParticleReal m_ds
Definition thick.H:68
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
Definition TrackedVector.H:49