Rivet API documentation

Rivet 4.1.3
MissingMomentum.hh
1// -*- C++ -*-
2#ifndef RIVET_MissingMomentum_HH
3#define RIVET_MissingMomentum_HH
4
5#include "Rivet/Config/RivetCommon.hh"
6#include "Rivet/Projection.hh"
7#include "Rivet/Projections/METFinder.hh"
8#include "Rivet/Projections/VisibleFinalState.hh"
9#include "Rivet/Particle.hh"
10#include "Rivet/Event.hh"
11
12namespace Rivet {
13
14
22 class MissingMomentum : public METFinder {
23 public:
24
25 using METFinder::operator=;
26
29 setName("MissingMomentum");
30 declare(fs, "FS");
31 declare(VisibleFinalState(fs), "VisibleFS");
32 }
33
37 { }
38
39
42
44 using Projection::operator =;
45
46
49
59 const FourMomentum visibleMomentum(double mass=0*GeV) const;
61 const FourMomentum visibleMom(double mass=0*GeV) const { return visibleMomentum(mass); }
62
70 const FourMomentum missingMomentum(double mass=0*GeV) const { return visibleMomentum(mass).reverse(); }
72 const FourMomentum missingMom(double mass=0*GeV) const { return missingMomentum(mass); }
73
75
76
84
88 const ThreeMomentum& vectorSumPt() const { return _vpt; }
89
91 double scalarSumPt() const { return _spt; }
92
94
95
103
107 const Vector3& vectorSumEt() const { return _vet; }
108
110 double scalarSumEt() const { return _set; }
111
113
114
116 void clear();
117
118
119 protected:
120
122 void project(const Event& e);
123
125 CmpState compare(const Projection& p) const;
126
127
128 protected:
129
131 FourMomentum _momentum;
132
134 double _set, _spt;
135
137 Vector3 _vet;
138 ThreeMomentum _vpt;
139
140 };
141
142
143
146
147
148}
149
150#endif
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
Specialized version of the FourVector with momentum/energy functionality.
Definition Vector4.hh:327
FourMomentum reverse() const
Multiply space components only by -1.
Definition Vector4.hh:752
Interface for projections that find missing transverse energy/momentum.
Definition METFinder.hh:11
Calculate missing , etc. as complements to the total visible momentum.
Definition MissingMomentum.hh:22
void clear()
Clear the projection results.
RIVET_DEFAULT_PROJ_CLONE(MissingMomentum)
Clone on the heap.
CmpState compare(const Projection &p) const
Compare projections.
void project(const Event &e)
Apply the projection to the event.
const Vector3 & vectorSumEt() const
The vector-summed visible transverse energy in the event, as a 3-vector with z=0.
Definition MissingMomentum.hh:107
const ThreeMomentum & vectorSumPt() const
The vector-summed visible transverse momentum in the event, as a 3-vector with z=0.
Definition MissingMomentum.hh:88
MissingMomentum(const FinalState &fs)
Canonical constructor taking a FinalState as argument.
Definition MissingMomentum.hh:28
const FourMomentum missingMomentum(double mass=0 *GeV) const
The missing four-momentum in the event, required to balance the final state.
Definition MissingMomentum.hh:70
double scalarSumPt() const
The scalar-summed visible transverse momentum in the event.
Definition MissingMomentum.hh:91
const FourMomentum missingMom(double mass=0 *GeV) const
Alias for missingMomentum.
Definition MissingMomentum.hh:72
const FourMomentum visibleMom(double mass=0 *GeV) const
Alias for visibleMomentum.
Definition MissingMomentum.hh:61
const FourMomentum visibleMomentum(double mass=0 *GeV) const
The vector-summed visible four-momentum in the event.
MissingMomentum(const Cut &c=Cuts::open())
Default constructor with optional cut.
Definition MissingMomentum.hh:35
double scalarSumEt() const
The scalar-summed visible transverse energy in the event.
Definition MissingMomentum.hh:110
const PROJ & declare(const PROJ &proj, const std::string &name) const
Register a contained projection (user-facing version).
Definition ProjectionApplier.hh:184
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
Specialized version of the ThreeVector with momentum functionality.
Definition Vector3.hh:349
Three-dimensional specialisation of Vector.
Definition Vector3.hh:40
Final state modifier excluding particles which are not experimentally visible.
Definition VisibleFinalState.hh:16
double mass(const FourMomentum &a, const FourMomentum &b)
Calculate mass of two 4-vectors.
Definition Vector4.hh:1482
double p(const ParticleBase &p)
Unbound function access to p.
Definition ParticleBaseUtils.hh:653
const Cut & open()
Fully open cut singleton, accepts everything.
Definition MC_CENT_PPB_Projections.hh:10
MissingMomentum MissingMom
A slightly more convenient name, following other Rivet shortening-conventions.
Definition MissingMomentum.hh:145