diff --git a/src/phase_spaces/create.jl b/src/phase_spaces/create.jl index 4364e5a..bb1d4d4 100644 --- a/src/phase_spaces/create.jl +++ b/src/phase_spaces/create.jl @@ -1,5 +1,22 @@ -# PSP constructors from particle statefuls +""" + ParticleStateful{DIR, SPECIES}(mom::AbstractFourMomentum) + ParticleStateful{DIR, SPECIES, EL}(mom::EL) + +Construct a [`ParticleStateful`](@ref) from the given momentum on a fully or partially specified type. +""" +@inline function ParticleStateful{DIR,SPECIES}( + mom::AbstractFourMomentum +) where {DIR<:ParticleDirection,SPECIES<:AbstractParticleType} + return ParticleStateful(DIR(), SPECIES(), mom) +end + +@inline function ParticleStateful{DIR,SPECIES,EL}( + mom::EL +) where {DIR<:ParticleDirection,SPECIES<:AbstractParticleType,EL<:AbstractFourMomentum} + return ParticleStateful(DIR(), SPECIES(), mom) +end +# PSP constructors from particle statefuls """ InPhaseSpacePoint( proc::AbstractProcessDefinition, diff --git a/test/phase_spaces.jl b/test/phase_spaces.jl index 00db741..fc87a45 100644 --- a/test/phase_spaces.jl +++ b/test/phase_spaces.jl @@ -22,6 +22,9 @@ end mom = rand(RNG, SFourMomentum) particle_stateful = ParticleStateful(dir, species, mom) + @test particle_stateful == ParticleStateful{typeof(dir),typeof(species)}(mom) + @test particle_stateful == + ParticleStateful{typeof(dir),typeof(species),typeof(mom)}(mom) # particle interface @test is_fermion(particle_stateful) == is_fermion(species)