2 #ifndef RIVET_VetoedFinalState_HH 3 #define RIVET_VetoedFinalState_HH 5 #include "Rivet/Projections/FinalState.hh" 44 _vetoCuts.reserve(vetopids.size());
57 _vetoCuts.reserve(vetopids.size());
82 for (
const auto& it : vetocodes) {
83 addVeto(it.first, Cuts::pT > it.second.first && Cuts::pT < it.second.second);
104 _vetoCuts.push_back(cut);
110 _vetoCuts.push_back(Cuts::pid == pid && cut);
116 _vetoCuts.push_back(Cuts::abspid == pid && cut);
125 return addVeto(pid, Cuts::ptIn(ptmin, ptmax));
175 const double halfWidth = 0.5*width;
176 pair<double,double> massRange(mass-halfWidth, mass+halfWidth);
177 _compositeVetoes.insert(make_pair(nProducts, massRange));
178 _nCompositeDecays.insert(nProducts);
187 _parentVetoes.insert(pid);
193 const string name =
"FS_" +
to_str(_vetofsnames.size());
195 _vetofsnames.insert(name);
217 vector<Cut> _vetoCuts;
221 multimap<PdgId, pair<double,double> > _compositeVetoes;
222 set<int> _nCompositeDecays;
225 set<PdgId> _parentVetoes;
228 set<string> _vetofsnames;
void setName(const std::string &name)
Used by derived classes to set their name.
Definition: Projection.hh:142
Definition: MC_Cent_pPb.hh:10
VetoedFinalState & addVetoOnThisFinalState(const ParticleFinder &fs)
Veto particles from a supplied final state.
Definition: VetoedFinalState.hh:192
VetoedFinalState & addVetoId(PdgId pid)
Add a particle ID to veto (all range will be vetoed)
Definition: VetoedFinalState.hh:139
VetoedFinalState & addVetoPairDetail(PdgId pid, double ptmin, double ptmax=std::numeric_limits< double >::max())
Add a particle/antiparticle pair to veto in a given range.
Definition: VetoedFinalState.hh:133
const vector< Cut > & vetoDetails() const
Get the list of particle IDs and ranges to veto.
Definition: VetoedFinalState.hh:96
VetoedFinalState & addDecayProductsVeto(PdgId pid)
Definition: VetoedFinalState.hh:186
CmpState compare(const Projection &p) const
Compare projections.
DEFAULT_RIVET_PROJ_CLONE(VetoedFinalState)
Clone on the heap.
VetoedFinalState & vetoNeutrinos()
Veto all neutrinos (convenience method)
Definition: VetoedFinalState.hh:163
Base class for projections which return subsets of an event's particles.
Definition: ParticleFinder.hh:11
int pid(const Particle &p)
Unbound function access to PID code.
Definition: ParticleUtils.hh:23
VetoedFinalState(const vector< Cut > &cuts)
Constructor with a default FinalState and a cuts list to veto.
Definition: VetoedFinalState.hh:31
VetoedFinalState(const map< PdgId, pair< double, double >> &vetocodes)
Definition: VetoedFinalState.hh:79
VetoedFinalState(PdgId vetopid)
Constructor with a default FinalState and a PID to veto.
Definition: VetoedFinalState.hh:62
VetoedFinalState & addVeto(PdgId pid, const Cut &cut=Cuts::OPEN)
Add a particle selection to be vetoed from the final state.
Definition: VetoedFinalState.hh:109
FS modifier to exclude classes of particles from the final state.
Definition: VetoedFinalState.hh:11
VetoedFinalState(const FinalState &fsp, const Cut &cut)
Constructor with a specific FinalState and a single cut to veto.
Definition: VetoedFinalState.hh:26
Representation of a HepMC event, and enabler of Projection caching.
Definition: Event.hh:22
string to_str(const T &x)
Convert any object to a string.
Definition: Utils.hh:75
VetoedFinalState & addVeto(const Cut &cut)
Add a particle selection to be vetoed from the final state.
Definition: VetoedFinalState.hh:103
void project(const Event &e)
Apply the projection on the supplied event.
VetoedFinalState & addVetoDetail(PdgId pid, double ptmin, double ptmax=std::numeric_limits< double >::max())
Add a particle ID and range to veto.
Definition: VetoedFinalState.hh:124
VetoedFinalState & addVetoPairId(PdgId pid)
Add a particle/antiparticle pair to veto.
Definition: VetoedFinalState.hh:148
VetoedFinalState & setVetoDetails(const vector< Cut > &cuts)
Set the list of particle selections to veto.
Definition: VetoedFinalState.hh:155
virtual std::string name() const
Get the name of the projection.
Definition: Projection.hh:56
VetoedFinalState()
Default constructor with default FinalState and no cuts.
Definition: VetoedFinalState.hh:72
VetoedFinalState(const FinalState &fsp)
Constructor with specific FinalState but no cuts.
Definition: VetoedFinalState.hh:67
VetoedFinalState & reset()
Clear the list of particle IDs and ranges to veto.
Definition: VetoedFinalState.hh:201
VetoedFinalState(const Cut &cut)
Constructor with a default FinalState and a single cut to veto.
Definition: VetoedFinalState.hh:36
VetoedFinalState & addCompositeMassVeto(double mass, double width, int nProducts=2)
Definition: VetoedFinalState.hh:174
VetoedFinalState(const FinalState &fsp, const vector< PdgId > &vetopids)
Constructor with a specific FinalState and a PID list to veto.
Definition: VetoedFinalState.hh:41
Project out all final-state particles in an event. Probably the most important projection in Rivet! ...
Definition: FinalState.hh:12
const PROJ & declare(const PROJ &proj, const std::string &name)
Register a contained projection (user-facing version)
Definition: ProjectionApplier.hh:160
VetoedFinalState(const vector< PdgId > &vetopids)
Constructor with a default FinalState and a PID list to veto.
Definition: VetoedFinalState.hh:54
double max(const vector< double > &in, double errval=DBL_NAN)
Find the maximum value in the vector.
Definition: Utils.hh:612
VetoedFinalState(const FinalState &fsp, const vector< Cut > &cuts)
Constructor with a specific FinalState and a cuts list to veto.
Definition: VetoedFinalState.hh:18
VetoedFinalState & addVetoPair(PdgId pid, const Cut &cut=Cuts::OPEN)
Add a particle/antiparticle selection to be vetoed from the final state.
Definition: VetoedFinalState.hh:115
Base class for all Rivet projections.
Definition: Projection.hh:29
VetoedFinalState(const FinalState &fsp, PdgId vetopid)
Constructor with a specific FinalState and a PID to veto.
Definition: VetoedFinalState.hh:49