AmpGen 2.1
Loading...
Searching...
No Matches
AmpGen::Particle Class Reference

Detailed Description

Encodes a multi-body decay tree structure, is largely limited to describe a sequence of quasi two-body processes (i.e. the isobar model) by the implemented lineshapes (propagators) and spin structure (vertices) Decay chains are usually constucted by parsing strings, for example:

D0{rho(770)0{pi+,pi-},K0S0}

is the tree structure for the decay of a neutral D-meson into a \(\rho\) meson and the short-lived neutral kaon, \( K^0_S \). States are lists of particles, separated by commas, and included within {} braces. As a trivial example, this decay descriptor can be used to generate some of its own documentation, in this case a formatted latex string:

AmpGen::Particle example("D0{rho(770)0{pi+,pi-},K0S0}");
std::cout << example.texLabel(true) << std::endl;
Describes a particle, its decay process and subsequent decay products, which are also Particles.
Definition Particle.h:103

produces the latex source for the output

\[D^{0}\rightarrow \rho(770)^{0}\left[\pi^{+} \pi^{-} \right] K_{S}^{0} \]

There are also modifiers to the amplitude that alter the details of the decay process. For example, there may multiple orbital angular momentum substates. These will be denoted by the use of [] braces, so for example

a(1)(1260)+{rho(770)0,pi+}
a(1)(1260)+[D]{rho(770)0,pi+}

correspond to the S-wave and D-wave decays of the \(a(1)(1260)^{+}\) meson. As a rule, the lowest orbital state permitted by the relevant conservation laws of the decay is used if the orbital state is not specified, so the conservation of angular momentum, and the conservation of parity if the decay proceeds via the strong or electromagnetic force.

The modifier syntax is also used to specify a different choice of lineshape for the resonance. For example, a common parameterisation for the \(\rho(770)\) meson is the Gounaris-Sakurai propagator, which accounts for dispersive corrections to the \(I=1\) dipion system. In this example

rho(770)0[GounarisSakurai]{pi+,pi-}

Multiple modifiers can be applied to the same particle, by including them in a semi-colon separated list. For example, for three-body decays of broad resonances, such as the \(a_1(1260)\), the propagator must take the evolution of the width of resonance from a numerical calculation, which can be supplied via a cubic spline (hence using the GSpline propagator). Additionally, for the decay chain \( a_1(1260)^{+} \to \rho^{0} \pi^{+} \), the decay products can either be in a relative S or D wave, and hence the two particle descriptors

a(1)(1260)+[GSpline]{rho(770)0,pi+}
a(1)(1260)+[D;GSpline]{rho(770)0,pi+}

are relevant for the decay.
Similar to other components of AmpGen, Particles will rarely be constructed in the C++ context, and will instead be instantiated dynamically at runtime from a user supplied options file.

Definition at line 102 of file Particle.h.

Public Types

enum  MatchState {
  None = ( 1<<0 ) , Exact = ( 1<<1 ) , PartialExpansion = ( 1<<2 ) , DifferentOrbital = ( 1<<3 ) ,
  DifferentPolarisation = ( 1<<4 )
}
 

Public Member Functions

 Particle ()
 Default Constructor.
 
 Particle (const std::string &name, const Particle &p1, const Particle &p2)
 Constructor that takes a pair of other particles (i.e. this particle's decay products) as arguments and looks up the properties of this particle using the particle name.
 
 Particle (const int &pdg_id, const Particle &p1, const Particle &p2)
 Constructor that takes a pair of other particles (i.e. this particle's decay products) as arguments and looks up the properties of this particle using the PDG MC ID.
 
 Particle (const std::string &name, const unsigned int &index)
 Constructor by name and with an index to match to the event type.
 
 Particle (const std::string &decayString, const std::vector< std::string > &finalStates={}, const bool &orderDaughters=true)
 Constructor that takes a decay descriptor as an argument and a list of final state particles to match to the event type. Constructs the entire decay tree.
 
 Particle (const std::string &name, const std::vector< Particle > &particles)
 Constructor that takes a set of particles.
 
Particle conj (bool invertHead=true, bool reorder=true)
 (Quasi) Constructor that returns the (quasi)CP conjugated amplitude. The full behaviour of the amplitude is made more complicated by the ordering convention.
 
void conjThis ()
 CP conjugate this particle //.
 
void setOrbital (const unsigned int &orbital)
 Set the orbital quantum number 'L' for this decay.
 
void setLineshape (const std::string &lineshape)
 Set the lineshape for the decay of this particle.
 
void setDaughter (const Particle &particle, const unsigned int &index)
 Set the index'th daughter of this to particle.
 
void setParent (const Particle *particle)
 Set the parent particle for this particle.
 
void setIndex (const unsigned int &index, const bool &setOri=false)
 Set the index of this particle, i.e. where it is positioned in the event data structure.
 
void clearDecayProducts ()
 Remove all of the decay products of this particle.
 
void addModifier (const std::string &mod)
 Add some modifier to the particle, such as a lineshape or a different spin state.
 
void parseModifier (const std::string &mod)
 Parse some set of modifiers, delimited with semicolons.
 
void setOrdering (const std::vector< size_t > &ordering)
 Set some particle ordering of the decay products of this particle, mostly used internally by the symmetrisation.
 
void setName (const std::string &name)
 Set the particle name.
 
void addDaughter (const std::shared_ptr< Particle > &particle)
 Add a decay product.
 
void setPolarisationState (const int &state)
 Set the polarisation state of this particle, which is twice the projection of the spin along the quantisation axis.
 
void setPolarisationState (const std::vector< int > &state)
 
std::pair< size_t, size_t > orbitalRange (const bool &converseParity=true) const
 Returns the range of orbital angular momentum between the decay products.
 
std::vector< std::pair< double, double > > spinOrbitCouplings (const bool &conserveParity=true) const
 Returns the set of possible spin-orbit couplings allowed by conservation of angular momentum, and if specified parity.
 
void setDaughters (const std::vector< Particle > &particles)
 
stdx::optional< std::string > attribute (const std::string &key) const
 Return the additional optional attribute keyed by variable key.
 
const ParticlePropertiesprops () const
 Return the particleProperties object for this particle.
 
QuarkContent quarks () const
 Return the quarks of this particle.
 
QuarkContent daughterQuarks () const
 Returns the quark content of the sum of the decay products of this particle.
 
int parity () const
 Returns the parity of this particle.
 
int finalStateParity () const
 Returns the parity of the final state of this particle.
 
int polState () const
 Returns the polarisation state, i.e. twice the projection of the spin along the quantisation axis, of this particle.
 
int CP () const
 Returns the CP of this decay.
 
int C () const
 Returns the C quantum number for this decay.
 
double mass () const
 Returns the (PDG) mass of the particle.
 
double spin () const
 Returns the spin of the particle.
 
double S () const
 Returns the spin configuration of the decay products of the particle.
 
unsigned L () const
 Returns the orbital angular.
 
bool isHead () const
 Returns whether if this particle is the head of the decay, i.e. has no parent.
 
bool isWeakDecay () const
 Returns whether is this particle decays weakly or not.
 
bool isStateGood () const
 Returns whether this particle, and its decays have been configured correctly.
 
bool isStable () const
 Check whether this particle is stable, has any decay products.
 
bool isQuasiStable () const
 Check whether the particle is quasi-stable, i.e. may have some appreciable flight distance.
 
bool conservesParity (unsigned int L=0) const
 Check whether the decay of this particle with angular momentum L conserves parity or not.
 
unsigned index () const
 Returns the current index of the particle in event data structure. Can differ from the original index due to symmetrisation.
 
unsigned originalIndex () const
 Returns the original index of the particle.
 
std::string name () const
 Name of the decaying particle.
 
std::string lineshape () const
 Name of the propagator to use for the decay of this particle.
 
std::string uniqueString () const
 Returns the unique string (i.e. decay descriptor) that identifies this decay, which can be parsed to generate the decay tree.
 
std::string decayDescriptor () const
 Returns the unique string (i.e. decay descriptor) that identifies this decay, which can be parsed to generate the decay tree.
 
std::string topologicalString () const
 The string that describes the spin/orbital topology of this decay, i.e.
 
std::string orbitalString () const
 The string that describes the spin/orbit configuration of this decay.
 
std::string texLabel (const bool &printHead=false, const bool &recurse=true) const
 Decay descriptor formatted as LaTeX for this decay.
 
EventType eventType () const
 Return the eventType for this decay (i.e. the initial and final state particles)
 
const Particleparent () const
 Returns the parent of the particle.
 
std::shared_ptr< Particledaughter (const size_t &index)
 Returns the indexth decay product of this particle.
 
std::shared_ptr< Particledaughter (const size_t &index) const
 Returns in indexth decay product of this particle (as constant)
 
std::shared_ptr< Particledaughter (const std::string &name, const int &maxDepth=-1) const
 Returns in indexth decay product of this particle (as constant)
 
std::vector< std::shared_ptr< Particle > > daughters () const
 Vector of decay products of this particle.
 
std::vector< std::vector< size_t > > identicalDaughterOrderings () const
 Get orderings of the final state that are identical to each other, i.e. those that only differ by exchanging identical particles.
 
std::vector< std::shared_ptr< Particle > > getFinalStateParticles (const bool &sort=true) const
 Returns the final state particles for this decay process.
 
Particle quasiStableTree () const
 Calculate the particle tree only including quasi-stable processes, i.e.
 
Tensor P () const
 Calculates the momentum sum of the decay products.
 
Tensor Q () const
 Calculates the momentum difference between the decay products (only well defined for quasi two-body processes )
 
Tensor spinTensor (DebugSymbols *db=nullptr) const
 Calculates the spin tensor or generalised current for this particle.
 
Tensor externalSpinTensor (const int &polState, DebugSymbols *db=nullptr) const
 Calculates the polarisation vector / spinor etc. of this particle, used for the initial/final state particles.
 
Expression massSq () const
 Calculates the invariant mass-squared of the mass of this particle.
 
Expression propagator (DebugSymbols *db=nullptr) const
 Calculates the lineshape / propagator for this particle.
 
Expression getExpression (DebugSymbols *db=nullptr, const std::vector< int > &={})
 Calculates the total expression for this particle, including symmetrisation and the current polarisation state.
 
bool lineshapeContains (const std::vector< std::string > &container) const
 Check if lineshape contains a substring.
 
Tensor transitionMatrix (DebugSymbols *db=nullptr)
 Calculate the transition matrix for this decay.
 
bool operator< (const Particle &other)
 
bool operator> (const Particle &other)
 
unsigned int matches (const Particle &other) const
 matches Check the matching between two decay chains, according to the MatchState enum.
 
std::string makeUniqueString ()
 Generate the decay descriptor for this decay.
 
Particle clone () const
 
void setDaughter (const unsigned int &index, const Particle &p)
 
bool expand (const Particle &particle)
 

Static Public Member Functions

static bool isValidDecayDescriptor (const std::string &decayDescriptor)
 

Member Enumeration Documentation

◆ MatchState

Enumerator
None 
Exact 
PartialExpansion 
DifferentOrbital 
DifferentPolarisation 

Definition at line 280 of file Particle.h.

Constructor & Destructor Documentation

◆ Particle() [1/6]

AmpGen::Particle::Particle ( )

◆ Particle() [2/6]

AmpGen::Particle::Particle ( const std::string & name,
const Particle & p1,
const Particle & p2 )

◆ Particle() [3/6]

AmpGen::Particle::Particle ( const int & pdg_id,
const Particle & p1,
const Particle & p2 )

◆ Particle() [4/6]

AmpGen::Particle::Particle ( const std::string & name,
const unsigned int & index )

◆ Particle() [5/6]

AmpGen::Particle::Particle ( const std::string & decayString,
const std::vector< std::string > & finalStates = {},
const bool & orderDaughters = true )

◆ Particle() [6/6]

AmpGen::Particle::Particle ( const std::string & name,
const std::vector< Particle > & particles )

Member Function Documentation

◆ addDaughter()

void AmpGen::Particle::addDaughter ( const std::shared_ptr< Particle > & particle)

◆ addModifier()

void AmpGen::Particle::addModifier ( const std::string & mod)

◆ attribute()

stdx::optional< std::string > AmpGen::Particle::attribute ( const std::string & key) const

◆ C()

int AmpGen::Particle::C ( ) const

◆ clearDecayProducts()

void AmpGen::Particle::clearDecayProducts ( )

◆ clone()

Particle AmpGen::Particle::clone ( ) const

◆ conj()

Particle AmpGen::Particle::conj ( bool invertHead = true,
bool reorder = true )

◆ conjThis()

void AmpGen::Particle::conjThis ( )

◆ conservesParity()

bool AmpGen::Particle::conservesParity ( unsigned int L = 0) const

◆ CP()

int AmpGen::Particle::CP ( ) const

◆ daughter() [1/3]

std::shared_ptr< Particle > AmpGen::Particle::daughter ( const size_t & index)

◆ daughter() [2/3]

std::shared_ptr< Particle > AmpGen::Particle::daughter ( const size_t & index) const

◆ daughter() [3/3]

std::shared_ptr< Particle > AmpGen::Particle::daughter ( const std::string & name,
const int & maxDepth = -1 ) const

◆ daughterQuarks()

QuarkContent AmpGen::Particle::daughterQuarks ( ) const

◆ daughters()

std::vector< std::shared_ptr< Particle > > AmpGen::Particle::daughters ( ) const

◆ decayDescriptor()

std::string AmpGen::Particle::decayDescriptor ( ) const

◆ eventType()

EventType AmpGen::Particle::eventType ( ) const

◆ expand()

bool AmpGen::Particle::expand ( const Particle & particle)

◆ externalSpinTensor()

Tensor AmpGen::Particle::externalSpinTensor ( const int & polState,
DebugSymbols * db = nullptr ) const

◆ finalStateParity()

int AmpGen::Particle::finalStateParity ( ) const

◆ getExpression()

Expression AmpGen::Particle::getExpression ( DebugSymbols * db = nullptr,
const std::vector< int > & = {} )

◆ getFinalStateParticles()

std::vector< std::shared_ptr< Particle > > AmpGen::Particle::getFinalStateParticles ( const bool & sort = true) const

◆ identicalDaughterOrderings()

std::vector< std::vector< size_t > > AmpGen::Particle::identicalDaughterOrderings ( ) const

◆ index()

unsigned AmpGen::Particle::index ( ) const

◆ isHead()

bool AmpGen::Particle::isHead ( ) const

◆ isQuasiStable()

bool AmpGen::Particle::isQuasiStable ( ) const

◆ isStable()

bool AmpGen::Particle::isStable ( ) const

◆ isStateGood()

bool AmpGen::Particle::isStateGood ( ) const

◆ isValidDecayDescriptor()

static bool AmpGen::Particle::isValidDecayDescriptor ( const std::string & decayDescriptor)
static

◆ isWeakDecay()

bool AmpGen::Particle::isWeakDecay ( ) const

◆ L()

unsigned AmpGen::Particle::L ( ) const

◆ lineshape()

std::string AmpGen::Particle::lineshape ( ) const

◆ lineshapeContains()

bool AmpGen::Particle::lineshapeContains ( const std::vector< std::string > & container) const
inline

Definition at line 271 of file Particle.h.

◆ makeUniqueString()

std::string AmpGen::Particle::makeUniqueString ( )

◆ mass()

double AmpGen::Particle::mass ( ) const

◆ massSq()

Expression AmpGen::Particle::massSq ( ) const

◆ matches()

unsigned int AmpGen::Particle::matches ( const Particle & other) const

◆ name()

std::string AmpGen::Particle::name ( ) const

◆ operator<()

bool AmpGen::Particle::operator< ( const Particle & other)

◆ operator>()

bool AmpGen::Particle::operator> ( const Particle & other)

◆ orbitalRange()

std::pair< size_t, size_t > AmpGen::Particle::orbitalRange ( const bool & converseParity = true) const

◆ orbitalString()

std::string AmpGen::Particle::orbitalString ( ) const

◆ originalIndex()

unsigned AmpGen::Particle::originalIndex ( ) const

◆ P()

Tensor AmpGen::Particle::P ( ) const

◆ parent()

const Particle * AmpGen::Particle::parent ( ) const

◆ parity()

int AmpGen::Particle::parity ( ) const

◆ parseModifier()

void AmpGen::Particle::parseModifier ( const std::string & mod)

◆ polState()

int AmpGen::Particle::polState ( ) const

◆ propagator()

Expression AmpGen::Particle::propagator ( DebugSymbols * db = nullptr) const

◆ props()

const ParticleProperties * AmpGen::Particle::props ( ) const

◆ Q()

Tensor AmpGen::Particle::Q ( ) const

◆ quarks()

QuarkContent AmpGen::Particle::quarks ( ) const

◆ quasiStableTree()

Particle AmpGen::Particle::quasiStableTree ( ) const

only includes states with lifetimes > ParticleProperties::qsThreshold (default ~ 1 KeV )

◆ S()

double AmpGen::Particle::S ( ) const

◆ setDaughter() [1/2]

void AmpGen::Particle::setDaughter ( const Particle & particle,
const unsigned int & index )

◆ setDaughter() [2/2]

void AmpGen::Particle::setDaughter ( const unsigned int & index,
const Particle & p )

◆ setDaughters()

void AmpGen::Particle::setDaughters ( const std::vector< Particle > & particles)

◆ setIndex()

void AmpGen::Particle::setIndex ( const unsigned int & index,
const bool & setOri = false )

◆ setLineshape()

void AmpGen::Particle::setLineshape ( const std::string & lineshape)

◆ setName()

void AmpGen::Particle::setName ( const std::string & name)

◆ setOrbital()

void AmpGen::Particle::setOrbital ( const unsigned int & orbital)

◆ setOrdering()

void AmpGen::Particle::setOrdering ( const std::vector< size_t > & ordering)

◆ setParent()

void AmpGen::Particle::setParent ( const Particle * particle)

◆ setPolarisationState() [1/2]

void AmpGen::Particle::setPolarisationState ( const int & state)

◆ setPolarisationState() [2/2]

void AmpGen::Particle::setPolarisationState ( const std::vector< int > & state)

◆ spin()

double AmpGen::Particle::spin ( ) const

◆ spinOrbitCouplings()

std::vector< std::pair< double, double > > AmpGen::Particle::spinOrbitCouplings ( const bool & conserveParity = true) const

◆ spinTensor()

Tensor AmpGen::Particle::spinTensor ( DebugSymbols * db = nullptr) const

◆ texLabel()

std::string AmpGen::Particle::texLabel ( const bool & printHead = false,
const bool & recurse = true ) const

◆ topologicalString()

std::string AmpGen::Particle::topologicalString ( ) const

replacing specific particle names with their spins.

◆ transitionMatrix()

Tensor AmpGen::Particle::transitionMatrix ( DebugSymbols * db = nullptr)

◆ uniqueString()

std::string AmpGen::Particle::uniqueString ( ) const

The documentation for this class was generated from the following file: