ImpactX
Loading...
Searching...
No Matches
Marker.H
Go to the documentation of this file.
1/* Copyright 2022-2023 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: Axel Huebl
8 * License: BSD-3-Clause-LBNL
9 */
10#ifndef IMPACTX_ELEMENT_MARKER_H
11#define IMPACTX_ELEMENT_MARKER_H
12
14#include "mixin/thin.H"
16#include "mixin/named.H"
17#include "mixin/nofinalize.H"
18
19#include <AMReX_Extension.H>
20#include <AMReX_REAL.H>
21#include <AMReX_SIMD.H>
22
23
24namespace impactx::elements
25{
26 struct Marker
27 : public mixin::Named,
28 public mixin::LinearTransport<Marker>,
29 public mixin::Thin,
30 public mixin::NoFinalize,
31 public amrex::simd::Vectorized<amrex::simd::native_simd_size_particlereal>
32 {
33 static constexpr auto type = "Marker";
35
40 Marker (std::string name)
41 : Named(name)
42 {
43 }
44
47 ImpactXParticleContainer & /* pc */,
48 int /* step */,
49 int /* period */
50 ) {
51 // nothing to do
52 }
53
55 void compute_constants (RefPart const & /* refpart */)
56 {
57 // nothing to do
58 }
59
63 RefPart & AMREX_RESTRICT /* ref_part */
64 ) {
65 // nothing to do
66 }
67
79 template<typename T_Real=amrex::ParticleReal, typename T_IdCpu=uint64_t>
82 [[maybe_unused]] T_Real & AMREX_RESTRICT x,
83 [[maybe_unused]] T_Real & AMREX_RESTRICT y,
84 [[maybe_unused]] T_Real & AMREX_RESTRICT t,
85 [[maybe_unused]] T_Real & AMREX_RESTRICT px,
86 [[maybe_unused]] T_Real & AMREX_RESTRICT py,
87 [[maybe_unused]] T_Real & AMREX_RESTRICT pt,
88 [[maybe_unused]] T_IdCpu & AMREX_RESTRICT idcpu,
89 [[maybe_unused]] RefPart const & AMREX_RESTRICT refpart
90 ) const
91 {
92 // nothing to do
93 }
94
96 using Thin::operator();
97
99 using LinearTransport::operator();
100
107 Map6x6
108 transport_map ([[maybe_unused]] RefPart const & AMREX_RESTRICT refpart) const
109 {
110 // nothing to do
111 return Map6x6::Identity();
112 }
113 };
114
115} // namespace impactx
116
117#endif // IMPACTX_ELEMENT_MARKER_H
#define AMREX_FORCE_INLINE
#define AMREX_RESTRICT
#define AMREX_GPU_HOST_DEVICE
#define AMREX_GPU_HOST
Definition ImpactXParticleContainer.H:133
impactx::ParIterSoA iterator
amrex iterator for particle boxes
Definition ImpactXParticleContainer.H:136
Definition All.H:54
@ 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
void operator()(ImpactXParticleContainer &, int, int)
Definition Marker.H:46
void compute_constants(RefPart const &)
Definition Marker.H:55
ImpactXParticleContainer::ParticleType PType
Definition Marker.H:34
AMREX_GPU_HOST AMREX_FORCE_INLINE Map6x6 transport_map(RefPart const &AMREX_RESTRICT refpart) const
Definition Marker.H:108
static constexpr auto type
Definition Marker.H:33
Marker(std::string name)
Definition Marker.H:40
Definition lineartransport.H:29
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 thin.H:24