DAS  3.0
Das Analysis System
PhysicsObject.h
Go to the documentation of this file.
1 #pragma once
2 
3 #include <cmath>
4 #include <vector>
5 #include <iostream>
6 #include <string_view>
7 
8 #include "Math/Vector4D.h"
9 
12 
13 namespace DAS {
14 
15 typedef ROOT::Math::LorentzVector<ROOT::Math::PtEtaPhiM4D<float>> FourVector;
16 
23 
24  AbstractPhysicsObject () = default;
25  virtual ~AbstractPhysicsObject () = default;
26 
27  virtual FourVector CorrP4 (const Uncertainties::Variation&) const = 0;
28  virtual float CorrPt (const Uncertainties::Variation&) const = 0;
29  virtual double Weight (const Uncertainties::Variation&) const = 0;
30 
31  virtual float Rapidity (const Uncertainties::Variation&) const = 0;
32  virtual float AbsRap (const Uncertainties::Variation&) const = 0;
33 };
34 
42 protected:
43  virtual std::string_view scale_group () const = 0;
44  virtual std::string_view weight_group () const = 0;
45 
46  PhysicsObject () = default;
47  virtual ~PhysicsObject () = default;
48 
49 public:
51  std::vector<float> scales = {1.};
52  Weights weights = {{1.,0}};
53 
54  inline FourVector CorrP4 (size_t i = 0) const { return p4 * scales.at(i); }
55  inline float CorrPt (size_t i = 0) const { return p4.Pt() * scales.at(i); }
56  inline float Rapidity (const Uncertainties::Variation& = Uncertainties::nominal) const final
57  { return p4.Rapidity() ; }
58  inline float AbsRap (const Uncertainties::Variation& = Uncertainties::nominal) const final
59  { return std::abs(Rapidity()); }
60 
61  inline FourVector CorrP4 (const Uncertainties::Variation& v) const final
62  { return PhysicsObject::CorrP4(v.group == scale_group() ? v.index : 0); }
63 
64  inline float CorrPt (const Uncertainties::Variation& v) const final
65  { return PhysicsObject::CorrPt(v.group == scale_group() ? v.index : 0); }
66 
67  inline double Weight (const Uncertainties::Variation& v) const final
68  {
69  if (v.group == weight_group()) {
70  const DAS::Weight& w = weights.at(v.index);
71  if (w.i == v.bit) return w;
72  }
73  return weights.front();
74  }
75 };
76 
77 inline bool operator== (const PhysicsObject& l, const PhysicsObject& r)
78 {
79  return l.p4 == r.p4 && l.scales == r.scales && l.weights == r.weights;
80 }
81 
82 inline bool operator< (const PhysicsObject& l, const PhysicsObject& r)
83 {
84  return l.CorrPt() < r.CorrPt();
85 }
86 
87 inline bool operator> (const PhysicsObject& l, const PhysicsObject& r)
88 {
89  return l.CorrPt() > r.CorrPt();
90 }
91 
92 } // end of DAS namespace
93 
94 inline std::ostream& operator<< (std::ostream& s, const DAS::FourVector& p4)
95 {
96  return s << '(' << p4.Pt() << ',' << p4.Eta() << ',' << p4.Phi() << ',' << p4.M() << ')';
97 }
98 
99 inline std::ostream& operator<< (std::ostream& s, const DAS::PhysicsObject& obj)
100 {
101  return s << obj.p4 << ' ' << obj.scales.size() << ' ' << obj.weights.size();
102 }
103 
104 #if defined(__ROOTCLING__)
105 #pragma link C++ class DAS::AbstractPhysicsObject +;
106 #pragma link C++ class DAS::PhysicsObject +;
107 #pragma link C++ class std::vector<DAS::FourVector> +;
108 #endif
DAS::operator==
bool operator==(const PhysicsObject &l, const PhysicsObject &r)
Definition: PhysicsObject.h:77
DAS::Weights
std::vector< Weight > Weights
Definition: Weight.h:41
DAS
Definition: applyBTagSF.cc:31
DAS::AbstractPhysicsObject::CorrPt
virtual float CorrPt(const Uncertainties::Variation &) const =0
DAS::PhysicsObject::Weight
double Weight(const Uncertainties::Variation &v) const final
< weight
Definition: PhysicsObject.h:67
DAS::PhysicsObject::p4
FourVector p4
raw four-momentum directly after reconstruction
Definition: PhysicsObject.h:50
DAS::AbstractPhysicsObject::Rapidity
virtual float Rapidity(const Uncertainties::Variation &) const =0
DAS::PhysicsObject::scale_group
virtual std::string_view scale_group() const =0
DAS::AbstractPhysicsObject::Weight
virtual double Weight(const Uncertainties::Variation &) const =0
DAS::PhysicsObject::CorrP4
FourVector CorrP4(size_t i=0) const
corrected 4-vector
Definition: PhysicsObject.h:54
DAS::PhysicsObject::PhysicsObject
PhysicsObject()=default
DAS::PhysicsObject
Definition: PhysicsObject.h:41
DAS::PhysicsObject::scales
std::vector< float > scales
energy scale corrections and variations
Definition: PhysicsObject.h:51
DAS::JetEnergy::w
static const float w
Definition: common.h:51
DAS::operator>
bool operator>(const PhysicsObject &l, const PhysicsObject &r)
Definition: PhysicsObject.h:87
DAS::PhysicsObject::AbsRap
float AbsRap(const Uncertainties::Variation &=Uncertainties::nominal) const final
absolute rapidity
Definition: PhysicsObject.h:58
DAS::AbstractPhysicsObject::AbstractPhysicsObject
AbstractPhysicsObject()=default
DAS::AbstractPhysicsObject::~AbstractPhysicsObject
virtual ~AbstractPhysicsObject()=default
DAS::Uncertainties::nominal
const Variation nominal
Definition: Variation.h:55
DAS::AbstractPhysicsObject
Definition: PhysicsObject.h:22
DAS::PhysicsObject::weight_group
virtual std::string_view weight_group() const =0
DAS::AbstractPhysicsObject::CorrP4
virtual FourVector CorrP4(const Uncertainties::Variation &) const =0
DAS::Weight
Definition: Weight.h:16
DAS::PhysicsObject::CorrPt
float CorrPt(size_t i=0) const
corrected transverse momentum
Definition: PhysicsObject.h:55
DAS::AbstractPhysicsObject::AbsRap
virtual float AbsRap(const Uncertainties::Variation &) const =0
DAS::PhysicsObject::~PhysicsObject
virtual ~PhysicsObject()=default
DAS::operator<
bool operator<(const PhysicsObject &l, const PhysicsObject &r)
Definition: PhysicsObject.h:82
Weight.h
DAS::PhysicsObject::weights
Weights weights
object weights
Definition: PhysicsObject.h:52
operator<<
std::ostream & operator<<(std::ostream &s, const DAS::FourVector &p4)
Definition: PhysicsObject.h:94
DAS::PhysicsObject::CorrPt
float CorrPt(const Uncertainties::Variation &v) const final
< corrected transverse momentum
Definition: PhysicsObject.h:64
DAS::FourVector
ROOT::Math::LorentzVector< ROOT::Math::PtEtaPhiM4D< float > > FourVector
Definition: PhysicsObject.h:15
DAS::PhysicsObject::Rapidity
float Rapidity(const Uncertainties::Variation &=Uncertainties::nominal) const final
rapidity
Definition: PhysicsObject.h:56
DAS::Uncertainties::Variation
Definition: Variation.h:22
Variation.h
DAS::PhysicsObject::CorrP4
FourVector CorrP4(const Uncertainties::Variation &v) const final
< corrected 4-vector
Definition: PhysicsObject.h:61