Rivet 3.1.9
GeneratedPercentileProjection.hh
1// -*- C++ -*-
2#ifndef RIVET_GENERATEDPERCENTILEPROJECTION_HH
3#define RIVET_GENERATEDPERCENTILEPROJECTION_HH
4
5#include "Rivet/Projections/SingleValueProjection.hh"
6#include "Rivet/Projections/HepMCHeavyIon.hh"
7
8namespace Rivet {
9
11 public:
12
14 setName("GeneratedPercentileProjection");
15 declare(HepMCHeavyIon(), "HepMC");
16 }
17
20
22 using Projection::operator =;
23
24
25 protected:
26
27 void project(const Event& e) {
28 clear();
29 set(apply<HepMCHeavyIon>(e, "HepMC").centrality());
30 }
31
32 CmpState compare(const Projection& p) const {
33 return CmpState::EQ;
34 }
35
36 };
37
38
39}
40
41#endif
Representation of a HepMC event, and enabler of Projection caching.
Definition Event.hh:22
Definition GeneratedPercentileProjection.hh:10
DEFAULT_RIVET_PROJ_CLONE(GeneratedPercentileProjection)
Clone on the heap.
CmpState compare(const Projection &p) const
Definition GeneratedPercentileProjection.hh:32
void project(const Event &e)
Definition GeneratedPercentileProjection.hh:27
Definition HepMCHeavyIon.hh:12
const PROJ & declare(const PROJ &proj, const std::string &name)
Register a contained projection (user-facing version)
Definition ProjectionApplier.hh:170
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:142
Base class for projections returning a single floating point value.
Definition SingleValueProjection.hh:17
void set(double v)
Definition SingleValueProjection.hh:55
void clear()
Unset the value.
Definition SingleValueProjection.hh:58
double p(const ParticleBase &p)
Unbound function access to p.
Definition ParticleBaseUtils.hh:684
Definition MC_Cent_pPb.hh:10