rivet is hosted by Hepforge, IPPP Durham
Rivet 3.1.6
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
27 setName("MissingMomentum");
28 declare(fs, "FS");
29 declare(VisibleFinalState(fs), "VisibleFS");
30 }
31
35 { }
36
37
40
41
44
54 const FourMomentum visibleMomentum(double mass=0*GeV) const;
56 const FourMomentum visibleMom(double mass=0*GeV) const { return visibleMomentum(mass); }
57
65 const FourMomentum missingMomentum(double mass=0*GeV) const { return visibleMomentum(mass).reverse(); }
67 const FourMomentum missingMom(double mass=0*GeV) const { return missingMomentum(mass); }
68
70
71
76
80 const ThreeMomentum& vectorPt() const { return _vpt; }
81
83 const ThreeMomentum vectorPtMiss() const { return -vectorPt(); }
84
86 double scalarPtMiss() const { return vectorPtMiss().pT(); }
87
89 double scalarPt() const { return _spt; }
90 // /// Alias for scalarPt
91 // double spt() const { return scalarPt(); }
92
94
95
100
104 const Vector3& vectorEt() const { return _vet; }
105
107 const Vector3 vectorEtMiss() const { return -vectorEt(); }
108
110 double scalarEtMiss() const { return vectorEtMiss().perp(); }
111
113 double scalarEt() const { return _set; }
116 double set() const { return scalarEt(); }
117
119
120
122 void clear();
123
124
125 protected:
126
128 void project(const Event& e);
129
131 CmpState compare(const Projection& p) const;
132
133
134 private:
135
137 FourMomentum _momentum;
138
140 double _set, _spt;
141
143 Vector3 _vet;
144 ThreeMomentum _vpt;
145
146 };
147
148
149
152
153
154}
155
156#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:306
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
double scalarEt() const
The scalar-summed visible transverse energy in the event.
Definition: MissingMomentum.hh:113
double scalarEtMiss() const
The scalar value of missing transverse energy in the event.
Definition: MissingMomentum.hh:110
void clear()
Clear the projection results.
double scalarPt() const
The scalar-summed visible transverse momentum in the event.
Definition: MissingMomentum.hh:89
const ThreeMomentum vectorPtMiss() const
The vector missing transverse momentum in the event, as a 3-vector with z=0.
Definition: MissingMomentum.hh:83
double scalarPtMiss() const
The scalar value of missing transverse momentum in the event.
Definition: MissingMomentum.hh:86
CmpState compare(const Projection &p) const
Compare projections.
void project(const Event &e)
Apply the projection to the event.
const Vector3 & vectorEt() const
The vector-summed visible transverse energy in the event, as a 3-vector with z=0.
Definition: MissingMomentum.hh:104
MissingMomentum(const FinalState &fs)
Canonical constructor taking a FinalState as argument.
Definition: MissingMomentum.hh:26
const FourMomentum missingMomentum(double mass=0 *GeV) const
The missing four-momentum in the event, required to balance the final state.
Definition: MissingMomentum.hh:65
const ThreeMomentum & vectorPt() const
The vector-summed visible transverse momentum in the event, as a 3-vector with z=0.
Definition: MissingMomentum.hh:80
const Vector3 vectorEtMiss() const
The vector missing transverse energy in the event, as a 3-vector with z=0.
Definition: MissingMomentum.hh:107
double set() const
Definition: MissingMomentum.hh:116
DEFAULT_RIVET_PROJ_CLONE(MissingMomentum)
Clone on the heap.
const FourMomentum missingMom(double mass=0 *GeV) const
Alias for missingMomentum.
Definition: MissingMomentum.hh:67
const FourMomentum visibleMom(double mass=0 *GeV) const
Alias for visibleMomentum.
Definition: MissingMomentum.hh:56
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:33
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
Specialized version of the ThreeVector with momentum functionality.
Definition: Vector3.hh:339
double pT() const
Calculate the transverse momentum .
Definition: Vector3.hh:432
Three-dimensional specialisation of Vector.
Definition: Vector3.hh:40
double perp() const
Synonym for polarRadius.
Definition: Vector3.hh:162
Final state modifier excluding particles which are not experimentally visible.
Definition: VisibleFinalState.hh:16
FourMomentum reverse() const
Multiply space components only by -1.
Definition: Vector4.hh:757
double mass(const ParticleBase &p)
Unbound function access to mass.
Definition: ParticleBaseUtils.hh:674
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.hh:10