ImpactX
Loading...
Searching...
No Matches
SoftSol.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_SOFTSOL_H
11#define IMPACTX_SOFTSOL_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/TrackedVector.H"
24
25#include <ablastr/constant.H>
26
27#include <AMReX.H>
28#include <AMReX_Extension.H>
29#include <AMReX_Math.H>
30#include <AMReX_REAL.H>
31#include <AMReX_SIMD.H>
32#include <AMReX_SmallMatrix.H>
33
34#include <cmath>
35#include <memory>
36#include <stdexcept>
37#include <tuple>
38#include <vector>
39
40
41namespace impactx::elements
42{
56 {
58 0.350807812299706,
59 0.323554693720069,
60 0.260320578919415,
61 0.182848575294969,
62 0.106921016050403,
63 4.409581845710694E-002,
64 -9.416427163897508E-006,
65 -2.459452716865687E-002,
66 -3.272762575737291E-002,
67 -2.936414401076162E-002,
68 -1.995780078926890E-002,
69 -9.102893342953847E-003,
70 -2.456410658713271E-006,
71 5.788233017324325E-003,
72 8.040408292420691E-003,
73 7.480064552867431E-003,
74 5.230254569468851E-003,
75 2.447614547094685E-003,
76 -1.095525090532255E-006,
77 -1.614586867387170E-003,
78 -2.281365457438345E-003,
79 -2.148709081338292E-003,
80 -1.522541739363011E-003,
81 -7.185505862719508E-004,
82 -6.171194824600157E-007,
83 4.842109305036943E-004,
84 6.874508102002901E-004,
85 6.535550288205728E-004,
86 4.648795813759210E-004,
87 2.216564722797528E-004,
88 -4.100982995210341E-007,
89 -1.499332112463395E-004,
90 -2.151538438342482E-004,
91 -2.044590946652016E-004,
92 -1.468242784844341E-004
93 };
94
96 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
97 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
98 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
99 0, 0, 0, 0, 0
100 };
101 };
102
113
115 : public mixin::Named,
116 public mixin::BeamOptic<SoftSolenoid>,
117 public mixin::LinearTransport<SoftSolenoid>,
118 public mixin::Thick,
119 public mixin::Alignment,
120 public mixin::NoFinalize,
121 public mixin::PipeAperture,
122 public amrex::simd::Vectorized<amrex::simd::native_simd_size_particlereal>
123 {
124 static constexpr auto type = "SoftSolenoid";
126
128
152 amrex::ParticleReal bscale,
153 std::vector<amrex::ParticleReal> cos_coef,
154 std::vector<amrex::ParticleReal> sin_coef,
155 int unit,
158 amrex::ParticleReal rotation_degree = 0,
161 int mapsteps = 1,
162 int nslice = 1,
163 std::optional<std::string> name = std::nullopt
164 )
165 : Named(std::move(name)),
166 Thick(ds, nslice),
167 Alignment(dx, dy, rotation_degree),
169 m_bscale(bscale), m_unit(unit), m_mapsteps(mapsteps),
170 m_id(DynamicData::allocate_id())
171 {
172 m_ncoef = int(cos_coef.size());
173 if (m_ncoef != int(sin_coef.size()))
174 throw std::runtime_error("SoftSolenoid: cos and sin coefficients must have same length!");
175
176 auto& coef = DynamicData::emplace(
177 m_id,
178 std::move(cos_coef),
179 std::move(sin_coef)
180 );
181 m_cos_h_data = coef.cos.host_const().data();
182 m_sin_h_data = coef.sin.host_const().data();
183 }
184
186 void reverse () {
187 // Reversing ds traverses the Fourier profile in the opposite z direction,
188 // so the odd sine terms change sign implicitly via sin(-kz) = -sin(kz).
189 Thick::reverse();
190 }
191
193 using BeamOptic::operator();
194
202 void compute_constants (RefPart const & refpart)
203 {
204 using namespace amrex::literals; // for _rt and _prt
205
206 Alignment::compute_constants(refpart);
207
208 // Ensure dynamic coefficient data is on GPU and we have fresh pointers to it
209 auto const & coef = *DynamicData::get(m_id);
210 m_cos_d_data = coef.cos.device_const().data();
211 m_sin_d_data = coef.sin.device_const().data();
212 }
213
228 template<typename T_Real=amrex::ParticleReal, typename T_IdCpu=uint64_t>
231 T_Real & AMREX_RESTRICT x,
232 T_Real & AMREX_RESTRICT y,
233 T_Real & AMREX_RESTRICT t,
234 T_Real & AMREX_RESTRICT px,
235 T_Real & AMREX_RESTRICT py,
236 T_Real & AMREX_RESTRICT pt,
237 T_IdCpu & AMREX_RESTRICT idcpu,
238 RefPart const & AMREX_RESTRICT refpart
239 ) const
240 {
241 using namespace amrex::literals; // for _rt and _prt
242
243 // shift due to alignment errors of the element
244 shift_in(x, y, px, py);
245
246 // get the linear map
248
249 // symplectic linear map for a solenoid is computed using the
250 // Hamiltonian formalism as described in:
251 // https://uspas.fnal.gov/materials/09UNM/ComputationalMethods.pdf.
252 // R denotes the transfer matrix in the basis (x,px,y,py,t,pt),
253 // so that, e.g., R(3,4) = dyf/dpyi.
254 amrex::SmallVector<T_Real, 6, 1> const v{x, px, y, py, t, pt};
255
256 // push particles using the linear map
257 auto const out = R * v;
258
259 // assign updated values
260 x = out[1];
261 px = out[2];
262 y = out[3];
263 py = out[4];
264 t = out[5];
265 pt = out[6];
266
267 // apply transverse aperture
268 apply_aperture(x, y, idcpu);
269
270 // undo shift due to alignment errors of the element
271 shift_out(x, y, px, py);
272 }
273
279 void operator() (RefPart & AMREX_RESTRICT refpart) const
280 {
281 using namespace amrex::literals; // for _rt and _prt
282 using amrex::Math::powi;
283
284 // assign input reference particle values
285 amrex::ParticleReal const x = refpart.x;
286 amrex::ParticleReal const px = refpart.px;
287 amrex::ParticleReal const y = refpart.y;
288 amrex::ParticleReal const py = refpart.py;
289 amrex::ParticleReal const z = refpart.z;
290 amrex::ParticleReal const pz = refpart.pz;
291 amrex::ParticleReal const pt = refpart.pt;
292 amrex::ParticleReal const s = refpart.s;
293 amrex::ParticleReal const sedge = refpart.sedge;
294
295 // initialize linear map (deviation) values
296 refpart.map = decltype(refpart.map)::Identity();
297
298 // length of the current slice
299 amrex::ParticleReal const slice_ds = m_ds / nslice();
300
301 // compute initial value of beta*gamma
302 amrex::ParticleReal const bgi = std::sqrt(powi<2>(pt) - 1.0_prt);
303
304 // call integrator to advance (t,pt)
305 amrex::ParticleReal const zin = s - sedge;
306 amrex::ParticleReal const zout = zin + slice_ds;
307 int const nsteps = m_mapsteps;
308
309 integrators::symp2_integrate_split3(refpart,zin,zout,nsteps,*this);
310 amrex::ParticleReal const ptf = refpart.pt;
311
312 /* print computed linear map:
313 for(int i=1; i<7; ++i){
314 for(int j=1; j<7; ++j){
315 amrex::PrintToFile("SolMap.txt") << i << " " <<
316 j << " " << refpart.map(i,j) << "\n";
317 }
318 }
319 */
320
321 // advance position (x,y,z)
322 refpart.x = x + slice_ds*px/bgi;
323 refpart.y = y + slice_ds*py/bgi;
324 refpart.z = z + slice_ds*pz/bgi;
325
326 // compute final value of beta*gamma
327 amrex::ParticleReal const bgf = std::sqrt(powi<2>(ptf) - 1.0_prt);
328
329 // advance momentum (px,py,pz)
330 refpart.px = px*bgf/bgi;
331 refpart.py = py*bgf/bgi;
332 refpart.pz = pz*bgf/bgi;
333
334 // advance integrated path length
335 refpart.s = s + slice_ds;
336 }
337
339 using LinearTransport::operator();
340
347 Map6x6
348 transport_map ([[maybe_unused]] RefPart const & AMREX_RESTRICT refpart) const
349 {
350
352 R = refpart.map;
353
354 return R;
355 }
356
363 std::tuple<amrex::ParticleReal, amrex::ParticleReal, amrex::ParticleReal>
365 Sol_Bfield (amrex::ParticleReal const zeval) const
366 {
367 using namespace amrex::literals; // for _rt and _prt
368
369 // pick the right data depending if we are on the host side
370 // (reference particle push) or device side (particles):
371#if AMREX_DEVICE_COMPILE
372 amrex::ParticleReal const * cos_data = m_cos_d_data;
373 amrex::ParticleReal const * sin_data = m_sin_d_data;
374#else
375 amrex::ParticleReal const * cos_data = m_cos_h_data;
376 amrex::ParticleReal const * sin_data = m_sin_h_data;
377#endif
378
379 // specify constants
381 amrex::ParticleReal const zlen = std::abs(m_ds);
382 amrex::ParticleReal const zmid = zlen * 0.5_prt;
383
384 // compute on-axis magnetic field (z is relative to solenoid midpoint)
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;
389
390 if (std::abs(z) <= zmid)
391 {
392 bfield = 0.5_prt*cos_data[0];
393 bfieldint = z*bfield;
394 for (int j=1; j < m_ncoef; ++j)
395 {
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);
402 }
403 }
404 return std::make_tuple(bfield, bfieldp, bfieldint);
405 }
406
416 void map1 (amrex::ParticleReal const tau,
417 RefPart & refpart,
418 [[maybe_unused]] amrex::ParticleReal & zeval) const
419 {
420 using namespace amrex::literals; // for _rt and _prt
421 using amrex::Math::powi;
422
423 // push the reference particle
424 amrex::ParticleReal const t = refpart.t;
425 amrex::ParticleReal const pt = refpart.pt;
426 amrex::ParticleReal const z = zeval;
427
428 if (pt < -1.0_prt) {
429 refpart.t = t + tau/std::sqrt(1.0_prt - powi<-2>(pt));
430 refpart.pt = pt;
431 }
432 else {
433 refpart.t = t;
434 refpart.pt = pt;
435 }
436
437 zeval = z + tau;
438
439 // push the linear map equations
441 amrex::ParticleReal const betgam = refpart.beta_gamma();
442
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);
447
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);
452
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);
455
456 }
457
467 void map2 (amrex::ParticleReal const tau,
468 RefPart & refpart,
469 amrex::ParticleReal & zeval) const
470 {
471 using namespace amrex::literals; // for _rt and _prt
472 using amrex::Math::powi;
473
474 amrex::ParticleReal const t = refpart.t;
475 amrex::ParticleReal const pt = refpart.pt;
476
477 // Define parameters and intermediate constants
478 amrex::ParticleReal const B0 =
479 m_unit == 1 ?
480 m_bscale / refpart.rigidity_Tm() :
481 m_bscale;
482
483 // push the reference particle
484 auto [bz, bzp, bzint] = Sol_Bfield(zeval);
485 amrex::ignore_unused(bzp, bzint);
486
487 refpart.t = t;
488 refpart.pt = pt;
489
490 // push the linear map equations
492 amrex::ParticleReal const alpha = B0*bz*0.5_prt;
493 amrex::ParticleReal const alpha2 = powi<2>(alpha);
494
495 refpart.map(2,1) = R(2,1) - tau*alpha2*R(1,1);
496 refpart.map(2,2) = R(2,2) - tau*alpha2*R(1,2);
497 refpart.map(2,3) = R(2,3) - tau*alpha2*R(1,3);
498 refpart.map(2,4) = R(2,4) - tau*alpha2*R(1,4);
499
500 refpart.map(4,1) = R(4,1) - tau*alpha2*R(3,1);
501 refpart.map(4,2) = R(4,2) - tau*alpha2*R(3,2);
502 refpart.map(4,3) = R(4,3) - tau*alpha2*R(3,3);
503 refpart.map(4,4) = R(4,4) - tau*alpha2*R(3,4);
504
505 }
506
516 void map3 (amrex::ParticleReal const tau,
517 RefPart & refpart,
518 amrex::ParticleReal & zeval) const
519 {
520 using namespace amrex::literals; // for _rt and _prt
521
522 amrex::ParticleReal const t = refpart.t;
523 amrex::ParticleReal const pt = refpart.pt;
524 amrex::ParticleReal const z = zeval;
525
526 // Define parameters and intermediate constants
527 amrex::ParticleReal const B0 =
528 m_unit == 1 ?
529 m_bscale / refpart.rigidity_Tm() :
530 m_bscale;
531
532 // push the reference particle
533 auto [bz, bzp, bzint] = Sol_Bfield(z);
534 amrex::ignore_unused(bzp, bzint);
535
536 refpart.t = t;
537 refpart.pt = pt;
538
539 // push the linear map equations
541 amrex::ParticleReal const theta = tau*B0*bz*0.5_prt;
542 amrex::ParticleReal const cs = std::cos(theta);
543 amrex::ParticleReal const sn = std::sin(theta);
544
545 refpart.map(1,1) = R(1,1)*cs + R(3,1)*sn;
546 refpart.map(1,2) = R(1,2)*cs + R(3,2)*sn;
547 refpart.map(1,3) = R(1,3)*cs + R(3,3)*sn;
548 refpart.map(1,4) = R(1,4)*cs + R(3,4)*sn;
549
550 refpart.map(2,1) = R(2,1)*cs + R(4,1)*sn;
551 refpart.map(2,2) = R(2,2)*cs + R(4,2)*sn;
552 refpart.map(2,3) = R(2,3)*cs + R(4,3)*sn;
553 refpart.map(2,4) = R(2,4)*cs + R(4,4)*sn;
554
555 refpart.map(3,1) = R(3,1)*cs - R(1,1)*sn;
556 refpart.map(3,2) = R(3,2)*cs - R(1,2)*sn;
557 refpart.map(3,3) = R(3,3)*cs - R(1,3)*sn;
558 refpart.map(3,4) = R(3,4)*cs - R(1,4)*sn;
559
560 refpart.map(4,1) = R(4,1)*cs - R(2,1)*sn;
561 refpart.map(4,2) = R(4,2)*cs - R(2,2)*sn;
562 refpart.map(4,3) = R(4,3)*cs - R(2,3)*sn;
563 refpart.map(4,4) = R(4,4)*cs - R(2,4)*sn;
564
565 }
566
568 int m_unit;
570 int m_id;
571
572 int m_ncoef = 0;
577 };
578
579} // namespace impactx
580
583
584#endif // IMPACTX_SOFTSOL_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:130
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_split3(RefPart &refpart, amrex::ParticleReal const zin, amrex::ParticleReal const zout, int const nsteps, T_Element const &element)
Definition Integrators.H:79
@ 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:166
amrex::ParticleReal pt
energy, normalized by rest energy
Definition ReferenceParticle.H:42
amrex::SmallMatrix< amrex::ParticleReal, 6, 6, amrex::Order::F, 1 > map
linearized map
Definition ReferenceParticle.H:48
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::ParticleReal rigidity_Tm() const
Definition ReferenceParticle.H:259
amrex::ParticleReal t
clock time * c in meters
Definition ReferenceParticle.H:38
Definition SoftSol.H:123
std::tuple< amrex::ParticleReal, amrex::ParticleReal, amrex::ParticleReal > AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE Sol_Bfield(amrex::ParticleReal const zeval) const
Definition SoftSol.H:365
int m_id
number of map integration steps per slice
Definition SoftSol.H:570
int m_mapsteps
unit specification for quad strength
Definition SoftSol.H:569
void compute_constants(RefPart const &refpart)
Definition SoftSol.H:202
amrex::ParticleReal const * m_sin_d_data
non-owning pointer to device cosine coefficients
Definition SoftSol.H:576
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 SoftSol.H:230
AMREX_GPU_HOST AMREX_FORCE_INLINE Map6x6 transport_map(RefPart const &AMREX_RESTRICT refpart) const
Definition SoftSol.H:348
static constexpr auto type
Definition SoftSol.H:124
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map3(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftSol.H:516
int m_ncoef
unique soft solenoid id used for data lookup map
Definition SoftSol.H:572
ImpactXParticleContainer::ParticleType PType
Definition SoftSol.H:125
SoftSolenoid(amrex::ParticleReal ds, amrex::ParticleReal bscale, std::vector< amrex::ParticleReal > cos_coef, std::vector< amrex::ParticleReal > sin_coef, int unit, 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 SoftSol.H:150
void reverse()
Definition SoftSol.H:186
amrex::ParticleReal const * m_sin_h_data
non-owning pointer to host cosine coefficients
Definition SoftSol.H:574
amrex::ParticleReal const * m_cos_h_data
number of Fourier coefficients
Definition SoftSol.H:573
amrex::ParticleReal m_bscale
Definition SoftSol.H:567
mixin::GPUDataRegistry< SolenoidFourierCoefficients > DynamicData
Definition SoftSol.H:127
int m_unit
scaling factor for solenoid Bz field
Definition SoftSol.H:568
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map2(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftSol.H:467
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void map1(amrex::ParticleReal const tau, RefPart &refpart, amrex::ParticleReal &zeval) const
Definition SoftSol.H:416
amrex::ParticleReal const * m_cos_d_data
non-owning pointer to host sine coefficients
Definition SoftSol.H:575
Definition SoftSol.H:56
amrex::Vector< amrex::ParticleReal > default_sin_coef
Definition SoftSol.H:95
amrex::Vector< amrex::ParticleReal > default_cos_coef
Definition SoftSol.H:57
mixin::TrackedVector< amrex::ParticleReal > sin
Definition SoftSol.H:111
mixin::TrackedVector< amrex::ParticleReal > cos
Definition SoftSol.H:110
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:436
static std::shared_ptr< SolenoidFourierCoefficients > const & get(int id)
Definition dynamicdata.H:73
static SolenoidFourierCoefficients & emplace(int id, Args &&... args)
Definition dynamicdata.H:100
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 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
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