Logo ROOT   6.16/01
Reference Guide
df102_NanoAODDimuonAnalysis.C
Go to the documentation of this file.
1/// \file
2/// \ingroup tutorial_dataframe
3/// \notebook -draw
4/// This tutorial illustrates how NanoAOD files can be processed with ROOT
5/// dataframes. The NanoAOD-like input files are filled with 66 mio. events
6/// from CMS OpenData containing muon candidates from 2012 data
7/// ([DOI: 10.7483/OPENDATA.CMS.YLIC.86ZZ](http://opendata.cern.ch/record/6004)
8/// and [DOI: 10.7483/OPENDATA.CMS.M5AD.Y3V3](http://opendata.cern.ch/record/6030)).
9/// The script matches muon pairs and produces an histogram of the dimuon mass
10/// spectrum showing resonances up to the Z mass.
11/// Note that the bump at 30 GeV is not a resonance but a trigger effect.
12///
13/// \macro_image
14/// \macro_code
15/// \macro_output
16///
17/// \date August 2018
18/// \author Stefan Wunsch (KIT, CERN)
19
20#include "ROOT/RDataFrame.hxx"
21#include "ROOT/RVec.hxx"
22#include "TCanvas.h"
23#include "TH1D.h"
24#include "TLatex.h"
25#include "TLorentzVector.h"
26#include "TStyle.h"
27
28using namespace ROOT::VecOps;
29
30void df102_NanoAODDimuonAnalysis()
31{
32 // Enable multi-threading
34
35 // Create dataframe from NanoAOD files
36 ROOT::RDataFrame df("Events",
37 {"root://eospublic.cern.ch//eos/root-eos/cms_opendata_2012_nanoaod/Run2012B_DoubleMuParked.root",
38 "root://eospublic.cern.ch//eos/root-eos/cms_opendata_2012_nanoaod/Run2012C_DoubleMuParked.root"});
39
40 // For simplicity, select only events with exactly two muons and require opposite charge
41 auto df_2mu = df.Filter("nMuon == 2", "Events with exactly two muons");
42 auto df_os = df_2mu.Filter("Muon_charge[0] != Muon_charge[1]", "Muons with opposite charge");
43
44 // Compute invariant mass of the dimuon system
45 auto compute_mass = [](RVec<float> &pt, RVec<float> &eta, RVec<float> &phi, RVec<float> &mass) {
46 // Compose four-vectors of both muons
48 p1.SetPtEtaPhiM(pt[0], eta[0], phi[0], mass[0]);
49 p2.SetPtEtaPhiM(pt[1], eta[1], phi[1], mass[1]);
50
51 // Add four-vectors to build dimuon system and return the invariant mass
52 return (p1 + p2).M();
53 };
54 auto df_mass = df_os.Define("Dimuon_mass", compute_mass, {"Muon_pt", "Muon_eta", "Muon_phi", "Muon_mass"});
55
56 // Make histogram of dimuon mass spectrum
57 auto h = df_mass.Histo1D({"Dimuon_mass", "Dimuon_mass", 30000, 0.25, 300}, "Dimuon_mass");
58
59 // Request cut-flow report
60 auto report = df_mass.Report();
61
62 // Produce plot
64 auto c = new TCanvas("c", "", 800, 700);
65 c->SetLogx(); c->SetLogy();
66
67 h->SetTitle("");
68 h->GetXaxis()->SetTitle("m_{#mu#mu} (GeV)"); h->GetXaxis()->SetTitleSize(0.04);
69 h->GetYaxis()->SetTitle("N_{Events}"); h->GetYaxis()->SetTitleSize(0.04);
70 h->DrawClone();
71
72 TLatex label; label.SetNDC(true);
73 label.DrawLatex(0.175, 0.740, "#eta");
74 label.DrawLatex(0.205, 0.775, "#rho,#omega");
75 label.DrawLatex(0.270, 0.740, "#phi");
76 label.DrawLatex(0.400, 0.800, "J/#psi");
77 label.DrawLatex(0.415, 0.670, "#psi'");
78 label.DrawLatex(0.485, 0.700, "Y(1,2,3S)");
79 label.DrawLatex(0.755, 0.680, "Z");
80 label.SetTextSize(0.040); label.DrawLatex(0.100, 0.920, "#bf{CMS Open Data}");
81 label.SetTextSize(0.030); label.DrawLatex(0.630, 0.920, "#sqrt{s} = 8 TeV, L_{int} = 11.6 fb^{-1}");
82
83 c->SaveAs("dimuon_spectrum.pdf");
84
85 // Print cut-flow report
86 report->Print();
87}
88
89int main()
90{
91 df102_NanoAODDimuonAnalysis();
92}
#define c(i)
Definition: RSha256.hxx:101
#define h(i)
Definition: RSha256.hxx:106
static double p1(double t, double a, double b)
static double p2(double t, double a, double b, double c)
R__EXTERN TStyle * gStyle
Definition: TStyle.h:406
RInterface< RDFDetail::RFilter< F, Proxied >, DS_t > Filter(F f, const ColumnNames_t &columns={}, std::string_view name="")
Definition: RInterface.hxx:195
ROOT's RDataFrame offers a high level interface for analyses of data stored in TTrees,...
Definition: RDataFrame.hxx:41
A "std::vector"-like collection of values implementing handy operation to analyse them.
Definition: RVec.hxx:221
virtual void SetTextFont(Font_t tfont=62)
Set the text font.
Definition: TAttText.h:45
virtual void SetTextSize(Float_t tsize=1)
Set the text size.
Definition: TAttText.h:46
The Canvas class.
Definition: TCanvas.h:31
To draw Mathematical Formula.
Definition: TLatex.h:18
TLatex * DrawLatex(Double_t x, Double_t y, const char *text)
Make a copy of this object with the new parameters And copy object attributes.
Definition: TLatex.cxx:1914
TLorentzVector is a general four-vector class, which can be used either for the description of positi...
void SetOptStat(Int_t stat=1)
The type of information printed in the histogram statistics box can be selected via the parameter mod...
Definition: TStyle.cxx:1444
virtual void SetNDC(Bool_t isNDC=kTRUE)
Set NDC mode on if isNDC = kTRUE, off otherwise.
Definition: TText.cxx:814
TPaveText * pt
int main(int argc, char **argv)
void EnableImplicitMT(UInt_t numthreads=0)
Enable ROOT's implicit multi-threading for all objects and methods that provide an internal paralleli...
Definition: TROOT.cxx:576