2#ifndef RIVET_LeadingParticlesFinalState_HH
3#define RIVET_LeadingParticlesFinalState_HH
5#include "Rivet/Event.hh"
6#include "Rivet/Projection.hh"
7#include "Rivet/Projections/FinalState.hh"
20 setName(
"LeadingParticlesFinalState");
28 using Projection::operator =;
39 for (PdgId
id : ids) _ids.insert(
id);
54 _leading_only = leadingonly;
Representation of a HepMC event, and enabler of Projection caching.
Definition Event.hh:22
Project out all final-state particles in an event. Probably the most important projection in Rivet!
Definition FinalState.hh:12
Get the highest-pT occurrences of FS particles with the specified PDG IDs.
Definition LeadingParticlesFinalState.hh:13
LeadingParticlesFinalState(const FinalState &fsp)
Constructor: the supplied FinalState projection is assumed to live through the run.
Definition LeadingParticlesFinalState.hh:17
RIVET_DEFAULT_PROJ_CLONE(LeadingParticlesFinalState)
Clone on the heap.
CmpState compare(const Projection &p) const
Compare projections.
LeadingParticlesFinalState & addParticleId(PdgId id)
Add a particle ID to the list of leading particles selected.
Definition LeadingParticlesFinalState.hh:32
LeadingParticlesFinalState & addParticleIdPair(PdgId id)
Add a particle ID to the list of leading particles selected.
Definition LeadingParticlesFinalState.hh:44
LeadingParticlesFinalState & addParticleIds(vector< PdgId > ids)
Add a particle ID to the list of leading particles selected.
Definition LeadingParticlesFinalState.hh:38
void setLeadingOnly(bool leadingonly)
Definition LeadingParticlesFinalState.hh:53
void project(const Event &e)
Apply the projection on the supplied event.
const PROJ & declare(const PROJ &proj, const std::string &name) const
Register a contained projection (user-facing version)
Definition ProjectionApplier.hh:175
Base class for all Rivet projections.
Definition Projection.hh:29
void setName(const std::string &name)
Used by derived classes to set their name.
Definition Projection.hh:148
Definition MC_CENT_PPB_Projections.hh:10