Particles and Phase Space Points
There are three layers of abstraction from particles to phase space points in the QEDjl project:
QEDbase.AbstractParticleType
: Base type for singleton particle type definitions. We also call these species.QEDbase.AbstractParticleStateful
: Base type for particles with a direction and carrying a momentum.QEDbase.AbstractPhaseSpacePoint
: Representation of a point in the phase space for a combination of anQEDbase.AbstractProcessDefinition
,QEDbase.AbstractModelDefinition
, andQEDbase.AbstractPhasespaceDefinition
.
This manual is intended to showcase the basic usage of these types and their implementations in QEDcore.
using QEDcore
To use concrete process definitions and models, we also need to use QEDprocesses.jl
using QEDprocesses
Particle Types
QEDcore currently defines the three basic particle types of QED, Electron
, Positron
, and Photon
, and a type hierarchy for them:
@assert Photon <: MajoranaBoson
@assert Electron <: Fermion
@assert Positron <: AntiFermion
All of these are subtypes of QEDbase.AbstractParticleType
. There are also convenience functions in Julia convention:
@assert is_boson(Photon())
@assert is_particle(Electron())
@assert is_anti_particle(Positron())
@assert !is_boson(Electron())
@assert !is_anti_particle(Electron())
@assert !is_fermion(Photon())
These functions are part of QEDbase.jl's particle interface.
ParticleStateful
ParticleStateful
is the implementation of QEDbase's QEDbase.AbstractParticleStateful
interface. It represents a particle with a direction
(as used in the context of scattering processes, QEDbase.Incoming
, QEDbase.Outgoing
, or QEDbase.UnknownDirection
), a particle species (Electron
, Positron
, Photon
, ...), and a 4-momentum vector.
ps = ParticleStateful(Incoming(), Electron(), rand(SFourMomentum))
ParticleStateful: incoming electron
momentum: [0.02798302184747614, 0.13123397127460057, 0.11009933815590955, 0.6393659325930585]
The relevant accessor functions for the interface are implemented:
particle_direction(ps)
incoming
particle_species(ps)
electron
momentum(ps)
4-element SFourMomentum with indices SOneTo(4):
0.02798302184747614
0.13123397127460057
0.11009933815590955
0.6393659325930585
Phase Space Points
A PhaseSpacePoint
is the combination of incoming and outgoing ParticleStateful
s. It also contains information about the scattering process, model, and phase space that it is created for.
Constructors
psp = PhaseSpacePoint(
Compton(), # scattering process
PerturbativeQED(), # physics model
PhasespaceDefinition( # phase space definition
SphericalCoordinateSystem(),# coordinate system
ElectronRestFrame(), # frame of reference
),
( # momenta of the incoming particles
rand(SFourMomentum),
rand(SFourMomentum),
),
( # momenta of the outgoing particles
rand(SFourMomentum),
rand(SFourMomentum),
),
)
PhaseSpacePoint:
process: one-photon Compton scattering
model: perturbative QED
phasespace definition: spherical coordinates in electron rest frame
incoming particles:
-> incoming electron: [0.379237486994076, 0.024582994202385522, 0.5049102139374004, 0.20976834290940338]
-> incoming photon: [0.3633542135145905, 0.19411570527967925, 0.8313889394891585, 0.5636466149790003]
outgoing particles:
-> outgoing electron: [0.42339141210480424, 0.767316344057772, 0.3656430695605948, 0.44998484214582646]
-> outgoing photon: [0.8492256040397043, 0.962655534614515, 0.9528040833773757, 0.13251278588953974]
This version of the constructor automatically creates ParticleStateful
obejcts from the momenta, matching the particles of the process. In the case of Compton
, this is means an incoming electron and photon, and outgoing electron and photon.
Automatic checks make sure that the number of 4-momenta given matches the necessary number of 4-momenta for the process (this adds 0 overhead at runtime because it is inferred from type information alone).
PhaseSpacePoint(
Compton(),
PerturbativeQED(),
PhasespaceDefinition(SphericalCoordinateSystem(), ElectronRestFrame()),
(rand(SFourMomentum),), # incorrect number of incoming momenta, should be 2
(rand(SFourMomentum), rand(SFourMomentum)),
)
┌ Error: InvalidInputError("expected 2 incoming particles for the process but got 1")
└ @ Main particles.md:115
Alternatively, a PhaseSpacePoint
can also be constructed from already existing ParticleStateful
objects.
psp = PhaseSpacePoint(
Compton(), # scattering process
PerturbativeQED(), # physics model
PhasespaceDefinition( # phase space definition
SphericalCoordinateSystem(),# coordinate system
ElectronRestFrame(), # frame of reference
),
( # incoming particles
ParticleStateful(Incoming(), Electron(), rand(SFourMomentum)),
ParticleStateful(Incoming(), Photon(), rand(SFourMomentum)),
),
( # outgoing particles
ParticleStateful(Outgoing(), Electron(), rand(SFourMomentum)),
ParticleStateful(Outgoing(), Photon(), rand(SFourMomentum)),
),
)
PhaseSpacePoint:
process: one-photon Compton scattering
model: perturbative QED
phasespace definition: spherical coordinates in electron rest frame
incoming particles:
-> incoming electron: [0.3232162137572939, 0.10777288772857241, 0.530716608929149, 0.20759725027729503]
-> incoming photon: [0.8724213619722047, 0.45963902500916043, 0.8596896875015564, 0.9991038465985183]
outgoing particles:
-> outgoing electron: [0.2678463019550571, 0.9730717838440996, 0.1511178047447561, 0.8272979417616493]
-> outgoing photon: [0.043808356982996455, 0.6007909401989368, 0.5985501856832413, 0.5491171289217269]
Similar to the constructor from momenta, this checks that the given ParticleStateful
s fit to the given process and throws otherwise. Again, since this can be infered from type information alone, it adds no overhead.
PhaseSpacePoint(
Compton(),
PerturbativeQED(),
PhasespaceDefinition(SphericalCoordinateSystem(), ElectronRestFrame()),
( # incoming particles
ParticleStateful(Incoming(), Positron(), rand(SFourMomentum)), # incorrect particle type
ParticleStateful(Incoming(), Photon(), rand(SFourMomentum)),
),
( # outgoing particles
ParticleStateful(Outgoing(), Electron(), rand(SFourMomentum)),
ParticleStateful(Outgoing(), Photon(), rand(SFourMomentum)),
),
)
┌ Error: InvalidInputError("expected incoming electron but got incoming positron")
└ @ Main particles.md:162
While these constructors check that the given types make sense and work together, they do not check whether the given momenta make a physical phase space point or that the incoming or outgoing particles have on-shell 4-momenta.
Accessors
The phase space point provides some convenient accessors to the stateful particles within:
psp[Incoming(), 1] # the first incoming particle
ParticleStateful: incoming electron
momentum: [0.3232162137572939, 0.10777288772857241, 0.530716608929149, 0.20759725027729503]
psp[Outgoing(), 2] # the second outgoing particle
ParticleStateful: outgoing photon
momentum: [0.043808356982996455, 0.6007909401989368, 0.5985501856832413, 0.5491171289217269]
particles(psp, Incoming()) # all incoming particles as a tuple
(incoming electron: [0.3232162137572939, 0.10777288772857241, 0.530716608929149, 0.20759725027729503], incoming photon: [0.8724213619722047, 0.45963902500916043, 0.8596896875015564, 0.9991038465985183])
Momentum accessors:
momentum(psp, Incoming(), Electron(), 1) # the momentum of the first incoming electron
4-element SFourMomentum with indices SOneTo(4):
0.3232162137572939
0.10777288772857241
0.530716608929149
0.20759725027729503
When only one particle of the species exists in the particle set, the 1 can be ommitted for convenience.
@assert ans == momentum(psp, Incoming(), Electron())
This method throws when multiple (or zero) particles of the given direction and species exist in the phase space point.
When the index of the required momentum is known at compile time, a Val(N)
can be used instead of N
. This performs bounds checks at compile time and removes loops from the runtime execution
using BenchmarkTools
judge(
median(@benchmark momentum($psp, Incoming(), Photon(), Val(1))),
median(@benchmark momentum($psp, Incoming(), Photon(), 1)),
)
BenchmarkTools.TrialJudgement:
time: -87.49% => improvement (5.00% tolerance)
memory: -100.00% => improvement (1.00% tolerance)
This is only faster when N
is actually known at compile time, for example when it is a literal integer or a function's type parameter. For dynamic values of N
, prefer the Int
variant or in case of loops, directly loop over the tuple of momenta
.
Some more overloads for the momentum function exist, for a complete list please refer to its documentation: QEDbase.momentum
, QEDbase.momenta
.
Finally, process
, model
, and phase_space_definition
can be used to request the object in question:
process(psp)
one-photon Compton scattering
incoming: electron (all spins), photon (all polarizations)
outgoing: electron (all spins), photon (all polarizations)
model(psp)
perturbative QED
phase_space_definition(psp)
PhasespaceDefinition
coordinate system: spherical coordinates
frame: electron rest frame
In/Out Phase Space Points
As a special case, phase space points are allowed to only contain the incoming or outgoing particle momenta. These types can be helpful for overloading some functions that don't require the entire phase space point to exist.
function in_sum(in_psp::AbstractInPhaseSpacePoint)
return sum(momenta(in_psp, Incoming()))
end
psp = InPhaseSpacePoint(
Compton(),
PerturbativeQED(),
PhasespaceDefinition(SphericalCoordinateSystem(), ElectronRestFrame()),
(rand(SFourMomentum), rand(SFourMomentum)),
)
in_sum(psp)
4-element SFourMomentum with indices SOneTo(4):
0.7387207643015822
1.2903164628557247
1.2657999485803584
1.505689236706658
Every full PhaseSpacePoint
is both an InPhaseSpacePoint
and an OutPhaseSpacePoint
, too. For example, the in_sum
function defined above still works with a full PhaseSpacePoint
:
psp = PhaseSpacePoint(
Compton(),
PerturbativeQED(),
PhasespaceDefinition(SphericalCoordinateSystem(), ElectronRestFrame()),
(rand(SFourMomentum), rand(SFourMomentum)),
(rand(SFourMomentum), rand(SFourMomentum)),
)
in_sum(psp)
4-element SFourMomentum with indices SOneTo(4):
1.1545716945819944
0.6751128742332435
0.5478479173215206
1.429827548807723
But an InPhaseSpacePoint
is not an OutPhaseSpacePoint
and vice versa. We cannot call in_sum
on an OutPhaseSpacePoint
:
psp = OutPhaseSpacePoint(
Compton(),
PerturbativeQED(),
PhasespaceDefinition(SphericalCoordinateSystem(), ElectronRestFrame()),
(rand(SFourMomentum), rand(SFourMomentum)),
)
in_sum(psp)
┌ Error: MethodError(Main.in_sum, (PhaseSpacePoint of one-photon Compton scattering,), 0x0000000000007b5c)
└ @ Main particles.md:280
This page was generated using Literate.jl.