-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtask_6_5.C
119 lines (93 loc) · 5.02 KB
/
task_6_5.C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include "common.h"
void task_6_5()
{
double bdt_min = 0.8;
TFile *fin_wspace = new TFile("wspace_constr.root");
RooWorkspace *wspace = (RooWorkspace*)fin_wspace->Get("wspace");
RooRealVar *m = wspace->var("m");
RooArgSet nset(*m);
RooCategory cate("cate","");
for(int idx=0; idx<N_Categories; idx++)
cate.defineType(Form("c%d",idx),idx);
RooSimultaneous *model = new RooSimultaneous("model", "", cate);
// Main POI: Bs->mumu branching fraction
RooRealVar *BF_bs = new RooRealVar("BF_bs","",3.57E-9,0.,1E-8);
// BF(B+ -> J/psi K+) = (1.010 +- 0.028) E-3 (PDG)
// BF(J/psi -> mu+mu-) = (5.961 +- 0.033) E-2 (PDG)
RooRealVar *BF_bu = wspace->var("BF_bu");
// fs/fu = 0.252 +- 0.012 (PDG) +- 0.015 (energy/pt dependence)
RooRealVar *fs_over_fu = wspace->var("fs_over_fu");
RooFormulaVar *N_bs[N_Categories];
RooAddPdf *pdf_sum[N_Categories];
RooProdPdf *pdf_prod[N_Categories];
for(int idx=0; idx<N_Categories; idx++) {
RooRealVar *Eff_bs = wspace->var(Form("Eff_bs_%d",idx));
RooRealVar *Eff_bu = wspace->var(Form("Eff_bu_%d",idx));
RooRealVar *N_bu = wspace->var(Form("N_bu_%d",idx));
N_bs[idx] = new RooFormulaVar(Form("N_bs_%d", idx), "", "@0*@1*@2*@3/@4/@5",
RooArgList(*BF_bs, *N_bu, *fs_over_fu, *Eff_bs, *Eff_bu, *BF_bu));
RooRealVar *N_peak = wspace->var(Form("N_peak_%d",idx));
RooRealVar *N_semi = wspace->var(Form("N_semi_%d",idx));
RooRealVar *N_comb = wspace->var(Form("N_comb_%d",idx));
RooArgList pdf_list;
pdf_list.add(*wspace->pdf(Form("pdf_bs_%d",idx)));
pdf_list.add(*wspace->pdf(Form("pdf_peak_%d",idx)));
pdf_list.add(*wspace->pdf(Form("pdf_semi_%d",idx)));
pdf_list.add(*wspace->pdf(Form("pdf_comb_%d",idx)));
RooArgList N_list;
N_list.add(*N_bs[idx]);
N_list.add(*N_peak);
N_list.add(*N_semi);
N_list.add(*N_comb);
pdf_sum[idx] = new RooAddPdf(Form("pdf_sum_%d",idx), "", pdf_list, N_list);
RooArgList prod_list;
prod_list.add(*pdf_sum[idx]);
prod_list.add(*wspace->pdf(Form("Eff_bs_%d_gau",idx)));
prod_list.add(*wspace->pdf(Form("N_bu_%d_gau",idx)));
prod_list.add(*wspace->pdf(Form("N_peak_%d_lnn",idx)));
prod_list.add(*wspace->pdf(Form("N_semi_%d_lnn",idx)));
pdf_prod[idx] = new RooProdPdf(Form("pdf_prod_%d",idx), "", prod_list);
model->addPdf(*pdf_prod[idx],Form("c%d",idx));
}
RooDataSet *rds_data = new RooDataSet("rds_data","",RooArgSet(*m,cate));
TFile *fin_data = new TFile("/eos/uscms/store/user/cmsdas/2025/long_exercises/long-ex-bs-mumu/bmmSoup10.root");
TTree *tin = (TTree*)fin_data->Get("bmmSoup10_100");
uint cate_t;
float m_t, bdt_t;
tin->SetBranchAddress("cate",&cate_t);
tin->SetBranchAddress("m",&m_t);
tin->SetBranchAddress("bdt",&bdt_t);
for(int evt=0; evt<tin->GetEntries(); evt++) {
tin->GetEntry(evt);
if (bdt_t<=bdt_min) continue;
cate.setIndex(cate_t);
m->setVal(m_t);
rds_data->add(RooArgSet(*m,cate));
}
model->fitTo(*rds_data,Extended(true),Minos(RooArgSet(*BF_bs)),
ExternalConstraints(RooArgSet(*wspace->pdf("BF_bu_gau"),*wspace->pdf("fs_over_fu_gau"))));
TCanvas* canvas = new TCanvas("canvas", "", 1200, 600);
canvas->Divide(4,2);
RooPlot *frame[N_Categories];
for(int idx=0; idx<N_Categories; idx++) {
TVirtualPad* pad = canvas->cd(idx+1);
pad->SetMargin(0.15,0.06,0.13,0.07);
frame[idx] = m->frame(Title(" "),Bins(25));
rds_data->plotOn(frame[idx], Cut(Form("cate==%d",idx)), MarkerSize(0.8));
double norm = pdf_sum[idx]->expectedEvents(&nset);
pdf_sum[idx]->plotOn(frame[idx], Normalization(norm, RooAbsReal::NumEvent), LineWidth(3));
pdf_sum[idx]->plotOn(frame[idx], Normalization(norm, RooAbsReal::NumEvent), Components(RooArgSet(*wspace->pdf(Form("pdf_bs_%d",idx)))), DrawOption("F"), FillColor(kRed), FillStyle(3365));
pdf_sum[idx]->plotOn(frame[idx], Normalization(norm, RooAbsReal::NumEvent), Components(RooArgSet(*wspace->pdf(Form("pdf_peak_%d",idx)))), DrawOption("F"), FillColor(kViolet-4), FillStyle(3344));
pdf_sum[idx]->plotOn(frame[idx], Normalization(norm, RooAbsReal::NumEvent), Components(RooArgSet(*wspace->pdf(Form("pdf_semi_%d",idx)))), DrawOption("L"), LineColor(kGreen-3), LineStyle(2));
frame[idx]->GetYaxis()->SetTitleOffset(1.50);
frame[idx]->GetYaxis()->SetTitle("Entries / 0.04 GeV");
frame[idx]->GetXaxis()->SetTitleOffset(1.15);
frame[idx]->GetXaxis()->SetLabelOffset(0.01);
frame[idx]->GetXaxis()->SetTitle("M(#mu#mu) [GeV]");
frame[idx]->GetXaxis()->SetTitleSize(0.043);
frame[idx]->GetYaxis()->SetTitleSize(0.043);
frame[idx]->Draw();
}
canvas->Print("task6_5.pdf");
canvas->Print("task6_5.png");
}