8#ifndef WARPX_INJECTOR_MOMENTUM_H_
9#define WARPX_INJECTOR_MOMENTUM_H_
20#include <AMReX_Config.H>
103 int a_flux_normal_axis,
int a_flux_direction) noexcept
131 amrex::Real u = generateGaussianFluxDist(u_m, u_th, engine);
222 if (u_std.
x < 0.0_rt || u_std.
y < 0.0_rt || u_std.
z < 0.0_rt) {
223 amrex::Abort(
"The standard deviation of normalized momentum must be non-negative.");
269 amrex::Abort(
"Temperature parameter theta is less than zero, "
270 "which is not allowed for Maxwell-Juttner distribution.");
274 if (beta <= -1._rt || beta >= 1._rt) {
275 amrex::Abort(
"beta = v/c magnitude greater than or equal to 1");
277 int const dir =
velocity.direction();
290 if (theta < 0.1_rt) {
295 gamma = std::sqrt(1._rt + u[0]*u[0] + u[1]*u[1] + u[2]*u[2]);
304 while(u[dir]-gamma <= x1)
308 gamma = std::sqrt(1._rt+u[dir]*u[dir]);
318 u[(dir+1)%3] = 2._rt*u[dir]*std::sqrt(x1*(1._rt-x1))*sin_x2;
319 u[(dir+2)%3] = 2._rt*u[dir]*std::sqrt(x1*(1._rt-x1))*cos_x2;
321 u[dir] = u[dir]*(2._rt*x1-1._rt);
336 if(-beta*u[dir]/gamma>x1)
343 u[dir] = 1._rt/std::sqrt(1._rt-beta*beta)*(u[dir]+gamma*beta);
356 for (
auto& el : u) { el = 0.0_rt; }
358 int const dir =
velocity.direction();
359 auto const gamma = 1._rt/std::sqrt(1._rt-beta*beta);
414 object(t, a_ux, a_uy, a_uz)
423 object(t, a_ux_parser, a_uy_parser, a_uz_parser)
431 object(t,a_ux_m,a_uy_m,a_uz_m,a_ux_th,a_uy_th,a_uz_th)
438 int a_flux_normal_axis,
int a_flux_direction)
440 object(t,a_ux_m,a_uy_m,a_uz_m,a_ux_th,a_uy_th,a_uz_th,a_flux_normal_axis,a_flux_direction)
448 object(t,a_ux_min,a_uy_min,a_uz_min,a_ux_max,a_uy_max,a_uz_max)
454 object(t, temperature, velocity)
461 object(t, temperature, velocity)
488 return object.parser.getMomentum(x,y,z,engine);
492 return object.gaussian.getMomentum(x,y,z,engine);
496 return object.gaussianflux.getMomentum(x,y,z,engine);
500 return object.uniform.getMomentum(x,y,z,engine);
504 return object.maxwellian.getMomentum(x,y,z,engine);
508 return object.juttner.getMomentum(x,y,z,engine);
512 return object.constant.getMomentum(x,y,z,engine);
517 return {0.0,0.0,0.0};
533 return object.parser.getBulkMomentum(x,y,z);
537 return object.gaussian.getBulkMomentum(x,y,z);
541 return object.gaussianflux.getBulkMomentum(x,y,z);
545 return object.uniform.getBulkMomentum(x,y,z);
549 return object.maxwellian.getBulkMomentum(x,y,z);
553 return object.juttner.getBulkMomentum(x,y,z);
557 return object.constant.getBulkMomentum(x,y,z);
562 return {0.0,0.0,0.0};
582 :
gaussian(a_ux_m,a_uy_m,a_uz_m,a_ux_th,a_uy_th,a_uz_th) {}
587 int a_flux_normal_axis,
int a_flux_direction) noexcept
588 :
gaussianflux(a_ux_m,a_uy_m,a_uz_m,a_ux_th,a_uy_th,a_uz_th,a_flux_normal_axis,a_flux_direction) {}
593 :
uniform(a_ux_min,a_uy_min,a_uz_min,a_ux_max,a_uy_max,a_uz_max) {}
604 :
parser(a_ux_parser, a_uy_parser, a_uz_parser) {}
#define AMREX_GPU_HOST_DEVICE
Real RandomNormal(Real mean, Real stddev)
constexpr auto pi
ratio of a circle's circumference to its diameter
Definition constant.H:29
__host__ __device__ std::pair< double, double > sincos(double x)
void Abort(const std::string &msg)
Get temperature at a point on the grid.
Definition GetTemperature.H:23
Definition GetTemperature.H:73
Definition GetVelocity.H:21
Definition GetVelocity.H:91
Definition InjectorMomentum.H:34
amrex::Real m_uy
Definition InjectorMomentum.H:56
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real, amrex::Real, amrex::Real) const noexcept
Definition InjectorMomentum.H:50
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real, amrex::Real, amrex::Real, amrex::RandomEngine const &) const noexcept
Definition InjectorMomentum.H:41
amrex::Real m_ux
Definition InjectorMomentum.H:56
InjectorMomentumConstant(amrex::Real a_ux, amrex::Real a_uy, amrex::Real a_uz) noexcept
Definition InjectorMomentum.H:35
amrex::Real m_uz
Definition InjectorMomentum.H:56
Definition InjectorMomentum.H:618
void operator()(InjectorMomentum *p) const
Definition InjectorMomentum.H:619
Definition InjectorMomentum.H:99
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real, amrex::Real, amrex::Real) const noexcept
Definition InjectorMomentum.H:146
amrex::Real m_uy_m
Definition InjectorMomentum.H:152
int m_flux_normal_axis
Definition InjectorMomentum.H:154
amrex::Real m_ux_m
Definition InjectorMomentum.H:152
amrex::Real m_uz_th
Definition InjectorMomentum.H:153
amrex::Real m_ux_th
Definition InjectorMomentum.H:153
amrex::Real m_uy_th
Definition InjectorMomentum.H:153
InjectorMomentumGaussianFlux(amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th, int a_flux_normal_axis, int a_flux_direction) noexcept
Definition InjectorMomentum.H:100
amrex::Real m_uz_m
Definition InjectorMomentum.H:152
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real, amrex::Real, amrex::Real, amrex::RandomEngine const &engine) const noexcept
Definition InjectorMomentum.H:114
int m_flux_direction
Definition InjectorMomentum.H:155
Definition InjectorMomentum.H:62
amrex::Real m_uz_m
Definition InjectorMomentum.H:90
amrex::Real m_ux_m
Definition InjectorMomentum.H:90
amrex::Real m_ux_th
Definition InjectorMomentum.H:91
amrex::Real m_uy_th
Definition InjectorMomentum.H:91
amrex::Real m_uy_m
Definition InjectorMomentum.H:90
InjectorMomentumGaussian(amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th) noexcept
Definition InjectorMomentum.H:63
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real, amrex::Real, amrex::Real, amrex::RandomEngine const &engine) const noexcept
Definition InjectorMomentum.H:73
amrex::Real m_uz_th
Definition InjectorMomentum.H:91
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real, amrex::Real, amrex::Real) const noexcept
Definition InjectorMomentum.H:84
Definition InjectorMomentum.H:409
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real x, amrex::Real y, amrex::Real z, amrex::RandomEngine const &engine) const noexcept
Definition InjectorMomentum.H:481
Type type
Definition InjectorMomentum.H:568
InjectorMomentum(InjectorMomentum &&)=delete
~InjectorMomentum()=default
InjectorMomentum(InjectorMomentumParser *t, amrex::ParserExecutor< 3 > const &a_ux_parser, amrex::ParserExecutor< 3 > const &a_uy_parser, amrex::ParserExecutor< 3 > const &a_uz_parser)
Definition InjectorMomentum.H:418
void operator=(InjectorMomentum const &)=delete
void clear()
Definition InjectorMomentum.cpp:12
InjectorMomentum(InjectorMomentumConstant *t, amrex::Real a_ux, amrex::Real a_uy, amrex::Real a_uz)
Definition InjectorMomentum.H:411
InjectorMomentum(InjectorMomentum const &)=delete
InjectorMomentum(InjectorMomentumGaussian *t, amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th)
Definition InjectorMomentum.H:427
InjectorMomentum(InjectorMomentumUniform *t, amrex::Real a_ux_min, amrex::Real a_uy_min, amrex::Real a_uz_min, amrex::Real a_ux_max, amrex::Real a_uy_max, amrex::Real a_uz_max)
Definition InjectorMomentum.H:444
Type
Definition InjectorMomentum.H:567
@ maxwellian
Definition InjectorMomentum.H:567
@ gaussian
Definition InjectorMomentum.H:567
@ parser
Definition InjectorMomentum.H:567
@ gaussianflux
Definition InjectorMomentum.H:567
@ constant
Definition InjectorMomentum.H:567
@ juttner
Definition InjectorMomentum.H:567
@ uniform
Definition InjectorMomentum.H:567
Object object
Definition InjectorMomentum.H:613
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real x, amrex::Real y, amrex::Real z) const noexcept
Definition InjectorMomentum.H:527
InjectorMomentum(InjectorMomentumGaussianFlux *t, amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th, int a_flux_normal_axis, int a_flux_direction)
Definition InjectorMomentum.H:435
InjectorMomentum(InjectorMomentumMaxwellian *t, GetTemperatureVector const &temperature, GetVelocityVector const &velocity)
Definition InjectorMomentum.H:451
InjectorMomentum(InjectorMomentumJuttner *t, GetTemperature const &temperature, GetVelocity const &velocity)
Definition InjectorMomentum.H:458
Definition InjectorMomentum.H:250
GetVelocity velocity
Definition InjectorMomentum.H:365
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real const x, amrex::Real const y, amrex::Real const z) const noexcept
Definition InjectorMomentum.H:352
GetTemperature temperature
Definition InjectorMomentum.H:366
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real const x, amrex::Real const y, amrex::Real const z, amrex::RandomEngine const &engine) const noexcept
Definition InjectorMomentum.H:261
InjectorMomentumJuttner(GetTemperature const &t, GetVelocity const &b) noexcept
Definition InjectorMomentum.H:254
Definition InjectorMomentum.H:205
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real const x, amrex::Real const y, amrex::Real const z, amrex::RandomEngine const &engine) const noexcept
Definition InjectorMomentum.H:216
GetTemperatureVector temperature
Definition InjectorMomentum.H:243
GetVelocityVector velocity
Definition InjectorMomentum.H:242
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real const x, amrex::Real const y, amrex::Real const z) const noexcept
Definition InjectorMomentum.H:234
InjectorMomentumMaxwellian(GetTemperatureVector const &t, GetVelocityVector const &b) noexcept
Definition InjectorMomentum.H:209
Definition InjectorMomentum.H:371
AMREX_GPU_HOST_DEVICE amrex::XDim3 getMomentum(amrex::Real x, amrex::Real y, amrex::Real z, amrex::RandomEngine const &) const noexcept
Definition InjectorMomentum.H:381
InjectorMomentumParser(amrex::ParserExecutor< 3 > const &a_ux_parser, amrex::ParserExecutor< 3 > const &a_uy_parser, amrex::ParserExecutor< 3 > const &a_uz_parser) noexcept
Definition InjectorMomentum.H:372
amrex::ParserExecutor< 3 > m_uz_parser
Definition InjectorMomentum.H:395
AMREX_GPU_HOST_DEVICE amrex::XDim3 getBulkMomentum(amrex::Real x, amrex::Real y, amrex::Real z) const noexcept
Definition InjectorMomentum.H:390
amrex::ParserExecutor< 3 > m_uy_parser
Definition InjectorMomentum.H:395
amrex::ParserExecutor< 3 > m_ux_parser
Definition InjectorMomentum.H:395
Definition InjectorMomentum.H:574
InjectorMomentumGaussian gaussian
Definition InjectorMomentum.H:606
InjectorMomentumUniform uniform
Definition InjectorMomentum.H:608
Object(InjectorMomentumGaussianFlux *, amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th, int a_flux_normal_axis, int a_flux_direction) noexcept
Definition InjectorMomentum.H:583
Object(InjectorMomentumMaxwellian *, GetTemperatureVector const &t, GetVelocityVector const &b) noexcept
Definition InjectorMomentum.H:594
Object(InjectorMomentumParser *, amrex::ParserExecutor< 3 > const &a_ux_parser, amrex::ParserExecutor< 3 > const &a_uy_parser, amrex::ParserExecutor< 3 > const &a_uz_parser) noexcept
Definition InjectorMomentum.H:600
InjectorMomentumJuttner juttner
Definition InjectorMomentum.H:610
Object(InjectorMomentumUniform *, amrex::Real a_ux_min, amrex::Real a_uy_min, amrex::Real a_uz_min, amrex::Real a_ux_max, amrex::Real a_uy_max, amrex::Real a_uz_max) noexcept
Definition InjectorMomentum.H:589
InjectorMomentumGaussianFlux gaussianflux
Definition InjectorMomentum.H:607
InjectorMomentumMaxwellian maxwellian
Definition InjectorMomentum.H:609
Object(InjectorMomentumJuttner *, GetTemperature const &t, GetVelocity const &b) noexcept
Definition InjectorMomentum.H:597
Object(InjectorMomentumGaussian *, amrex::Real a_ux_m, amrex::Real a_uy_m, amrex::Real a_uz_m, amrex::Real a_ux_th, amrex::Real a_uy_th, amrex::Real a_uz_th) noexcept
Definition InjectorMomentum.H:578
InjectorMomentumParser parser
Definition InjectorMomentum.H:611
InjectorMomentumConstant constant
Definition InjectorMomentum.H:605
Object(InjectorMomentumConstant *, amrex::Real a_ux, amrex::Real a_uy, amrex::Real a_uz) noexcept
Definition InjectorMomentum.H:575