#include "TH1D.h" #include "TH2D.h" #include "THStack.h" #include "TGraph.h" #include "TTree.h" #include "TChain.h" #include "TFile.h" #include "TCanvas.h" #include "TROOT.h" #include "TStyle.h" #include "TColor.h" #include "TLorentzVector.h" #include "TRandom3.h" #include "TLegend.h" #include "RooDataHist.h" #include "RooRealVar.h" #include "RooPlot.h" #include "RooGaussian.h" #include "RooExponential.h" #include "RooRealConstant.h" #include "RooAddPdf.h" #include "RooFitResult.h" #include "RooProduct.h" #include "RooCrystalBall.h" #include "RooBreitWigner.h" #include "RooArgSet.h" #include "RooFFTConvPdf.h" #include "RooNovosibirsk.h" #include #include #include #include #include const Double_t B_MASS_VAR_MIN = 5100.; const Double_t B_MASS_VAR_MAX = 6000.; const Int_t B_MASS_HIST_BINS = 70; const Double_t K_MASS = 493.677; const Double_t PSI2S_MASS = 3686.093; const Double_t JPSI_MASS = 3096.900; const Double_t KSTAR_MASS = 891.760; const int PID_KAON = 321; const int PID_PION = 211; const int PID_MUON = 13; class FourVect { private: Float_t px, py, pz, energy; Float_t *PtrPX() { return &px; } Float_t *PtrPY() { return &py; } Float_t *PtrPZ() { return &pz; } Float_t *PtrEnergy() { return &energy; } public: static FourVect *Init(TTree *tree, const char *particle) { FourVect *v = new FourVect{}; tree->SetBranchAddress(TString::Format("%s_PX", particle).Data(), v->PtrPX()); tree->SetBranchAddress(TString::Format("%s_PY", particle).Data(), v->PtrPY()); tree->SetBranchAddress(TString::Format("%s_PZ", particle).Data(), v->PtrPZ()); tree->SetBranchAddress(TString::Format("%s_ENERGY", particle).Data(), v->PtrEnergy()); return v; } TLorentzVector LorentzVector() { return TLorentzVector(px, py, pz, energy); } TLorentzVector LorentzVector(double sub_mass) { TVector3 momentum(px, py, pz); float energy = TMath::Sqrt(TMath::Sq(sub_mass) + momentum.Mag2()); return TLorentzVector(momentum, energy); } std::string ToString() { return TString::Format("(%f, %f, %f, %f)", px, py, pz, energy).Data(); } }; struct Hlt1Decision { std::string name; int index; Bool_t value; std::string GetName() const { return TString::Format("Hlt1%sDecision", name.c_str()).Data(); } Bool_t *GetValuePointer() { return &value; } }; std::vector Hlt1Decisions{ Hlt1Decision{"DiMuonHighMass", 1}, Hlt1Decision{"DiMuonLowMass", 2}, Hlt1Decision{"DiMuonNoIP", 3}, Hlt1Decision{"DiMuonSoft", 4}, Hlt1Decision{"DisplacedLeptons", 5}, Hlt1Decision{"LowPtDiMuon", 6}, Hlt1Decision{"LowPtMuon", 7}, Hlt1Decision{"OneMuonTrackLine", 8}, Hlt1Decision{"SingleHighEt", 9}, Hlt1Decision{"SingleHighPtMuon", 10}, Hlt1Decision{"TrackMVA", 11}, Hlt1Decision{"TrackMuonMVA", 12}, Hlt1Decision{"TwoTrackMVA", 13}, }; struct Hlt1DecisionPlot { std::string name; bool exclusive; std::set lines; }; const std::vector Hlt1DecisionSets{ Hlt1DecisionPlot{"mva_excl", true, std::set{"TwoTrackMVA", "TrackMuonMVA", "TrackMVA"}}, Hlt1DecisionPlot{"mva_incl", false, std::set{"TwoTrackMVA", "TrackMuonMVA", "TrackMVA"}}, Hlt1DecisionPlot{"pt_excl", true, std::set{"LowPtMuon", "LowPtDiMuon", "DisplacedLeptons"}}, Hlt1DecisionPlot{"pt_incl", false, std::set{"LowPtMuon", "LowPtDiMuon", "DisplacedLeptons"}}, Hlt1DecisionPlot{"dimu_excl", true, std::set{"DiMuonNoIP", "DiMuonLowMass", "DiMuonHighMass"}}, Hlt1DecisionPlot{"dimu_incl", false, std::set{"DiMuonNoIP", "DiMuonLowMass", "DiMuonHighMass"}}, Hlt1DecisionPlot{"mvapt_incl", false, std::set{"TwoTrackMVA", "TrackMuonMVA", "TrackMVA", "LowPtMuon", "LowPtDiMuon", "DisplacedLeptons"}}, Hlt1DecisionPlot{"mvadimu_incl", false, std::set{"TwoTrackMVA", "TrackMuonMVA", "TrackMVA", "DiMuonNoIP", "DiMuonLowMass", "DiMuonHighMass"}}, Hlt1DecisionPlot{"mvadimupt_incl", false, std::set{"TwoTrackMVA", "TrackMuonMVA", "TrackMVA", "LowPtMuon", "LowPtDiMuon", "DisplacedLeptons", "DiMuonNoIP", "DiMuonLowMass", "DiMuonHighMass"}}, Hlt1DecisionPlot{"ptdimu_incl", false, std::set{"LowPtMuon", "LowPtDiMuon", "DisplacedLeptons", "DiMuonNoIP", "DiMuonLowMass", "DiMuonHighMass"}}, }; bool CutHlt1DecisionsAnd(const std::set &decision_list) { bool okay = true; for (const auto &var : Hlt1Decisions) { if (decision_list.find(var.name) != decision_list.end()) { okay = okay && var.value; } } return okay; } bool CutHlt1DecisionsOr(const std::set &decision_list) { bool okay = false; for (const auto &var : Hlt1Decisions) { if (decision_list.find(var.name) != decision_list.end()) { okay = okay || var.value; } } return okay; } bool CutHlt1DecisionsOrOnly(const std::set &decision_list) { bool okay = false; for (const auto &var : Hlt1Decisions) { if (decision_list.find(var.name) != decision_list.end()) { okay = okay || var.value; } else { if (var.value) { okay = false; break; } } } return okay; } void ConnectHlt1Decisions(TChain *chain) { for (auto &var : Hlt1Decisions) { if (chain->FindBranch(var.GetName().c_str())) chain->SetBranchAddress(var.GetName().c_str(), var.GetValuePointer()); } } void DrawInDefaultCanvas(TH1 *histogram, const char *folder, double margin_left = 0, Option_t *option = "") { std::filesystem::create_directory(TString::Format("output_files/analysis/%s", folder).Data()); TString name = TString::Format("%s_canvas", histogram->GetName()); TCanvas *c = new TCanvas(name, histogram->GetName(), 0, 0, 800, 600); c->SetLeftMargin(margin_left); histogram->SetStats(0); histogram->Draw(option); c->Draw(); c->SaveAs(TString::Format("output_files/analysis/%s/%s.pdf", folder, name.Data()).Data()); } void DrawInDefaultCanvas(RooPlot *rooPlot, const char *folder, double margin_left = 0, Option_t *option = "") { std::filesystem::create_directory(TString::Format("output_files/analysis/%s", folder).Data()); TString name = TString::Format("%s_canvas", rooPlot->GetName()); TCanvas *c = new TCanvas(name, rooPlot->GetName(), 0, 0, 800, 600); c->SetLeftMargin(margin_left); rooPlot->Draw(option); c->Draw(); c->SaveAs(TString::Format("output_files/analysis/%s/%s.pdf", folder, name.Data()).Data()); } void PrintProgress(const char *title, unsigned int total, unsigned int every, unsigned int current) { if ((current + 1) % every == 0 || current + 1 == total) { std::cout << "[" << title << "] Processed event: " << current + 1 << " (" << TString::Format("%.2f", ((double)(current + 1) / (double)total) * 100.) << "%)" << std::endl; } } RooPlot *CreateRooFitHistogram(TH1D *hist) { RooRealVar roo_var_mass("var_mass", "B Mass Variable", B_MASS_VAR_MIN, B_MASS_VAR_MAX); roo_var_mass.setRange("fitting_range", B_MASS_VAR_MIN, B_MASS_VAR_MAX); RooDataHist roohist_B_M("roohist_B_M", "B Mass Histogram", roo_var_mass, RooFit::Import(*hist)); RooPlot *roo_frame_mass = roo_var_mass.frame(RooFit::Title(hist->GetTitle()), RooFit::Name(TString::Format("%s_rplt", hist->GetName()))); roohist_B_M.plotOn(roo_frame_mass, RooFit::Binning(B_MASS_HIST_BINS), RooFit::Name("B Mass Distribution")); roo_frame_mass->GetXaxis()->SetTitle(hist->GetXaxis()->GetTitle()); return roo_frame_mass; } void CheckHlt1Decisioins(TH2D *incl_hist, TH2D *excl_hist, std::map &exclusive_hits, const double reco_mass) { for (const auto &var : Hlt1Decisions) { if (var.value) { incl_hist->Fill(reco_mass, var.name.c_str(), 1); } } bool exclusive = true; std::string line{}; for (const auto &var : Hlt1Decisions) { if (var.value) { if (!line.empty()) { exclusive = false; } line = var.name; } } if (!line.empty() && exclusive) { int &hits = exclusive_hits[line]; if (hits) { hits += 1; } else { hits = 1; } excl_hist->Fill(reco_mass, line.c_str(), 1); } } std::vector CreateHlt1DecisionHistos(const char *analysis_name) { std::vector histos{}; for (int i = 0; i < Hlt1DecisionSets.size(); i++) { TH1D *h1_B_Mass_hlt1 = new TH1D(TString::Format("h1_B_Mass_hlt1_%s", Hlt1DecisionSets[i].name.c_str()), TString::Format("(%s) (%s)", Hlt1DecisionSets[i].name.c_str(), analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); histos.push_back(h1_B_Mass_hlt1); } return histos; } void FillHlt1DecisionHistos(std::vector histos, double reco_mass) { for (int i = 0; i < Hlt1DecisionSets.size(); i++) { if (Hlt1DecisionSets[i].exclusive) { if (CutHlt1DecisionsOrOnly(Hlt1DecisionSets[i].lines)) { histos[i]->Fill(reco_mass); } } else { if (CutHlt1DecisionsOr(Hlt1DecisionSets[i].lines)) { histos[i]->Fill(reco_mass); } } } } void DrawHlt1DecisionHistos(const char *folder, std::vector histos) { std::filesystem::create_directory(TString::Format("output_files/analysis/%s", folder).Data()); TString name = TString::Format("%s_canvas", "hlt1_decisions"); TCanvas *c = new TCanvas(name, "HLT 1 Decisions", 0, 0, 1200, 700); c->Divide(4, 3); for (int i = 0; i < histos.size(); i++) { c->cd(i + 1); histos[i]->SetStats(0); histos[i]->Draw(); TLegend *leg1 = new TLegend(0.58, 0.89 - (0.05 * (Hlt1DecisionSets[i].lines.size() + (int)(Hlt1DecisionSets[i].lines.size() / 3))), 0.88, 0.89); leg1->SetFillStyle(0); leg1->SetLineStyle(0); leg1->SetMargin(0.1); int index = 1; std::for_each(Hlt1DecisionSets[i].lines.begin(), Hlt1DecisionSets[i].lines.end(), [leg1, i, &index](std::string s) { leg1->AddEntry((TObject *)0, s.c_str(), ""); if (index != Hlt1DecisionSets[i].lines.size() && index % 3 == 0) { leg1->AddEntry((TObject *)0, "", ""); } index++; }); leg1->AddEntry((TObject *)0, TString::Format("# Entries: %d", (int)histos[i]->GetEntries()), ""); leg1->Draw(); } c->Draw(); c->SaveAs(TString::Format("output_files/analysis/%s/%s.pdf", folder, name.Data()).Data()); } // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Bu To Hp Mu Mu %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% int analyze_bu2hpmumu_data() { const char *analysis_name = "BuToHpMuMu"; const char *end_state_mass_literal = "m(#pi^{+}_{(#rightarrow K^{+})}#mu^{+}#mu^{-})"; TChain *data_chain = new TChain(TString::Format("%s/DecayTree", analysis_name)); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/spruce_magdown_2023_v0_tuple_90000000_v0r0p6288631.root"); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/spruce_magdown_2023_v0r1_tuple_90000000_2023_v0r0p6288631.root"); FourVect *l14v = FourVect::Init(data_chain, "L1"); FourVect *l24v = FourVect::Init(data_chain, "L2"); FourVect *hp4v = FourVect::Init(data_chain, "Hp"); TH1D *h1_B_Mass_jpsi = new TH1D("h1_B_Mass_jpsi", TString::Format("B Mass, J/#psi Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH1D *h1_B_Mass_psi2s = new TH1D("h1_B_Mass_psi2s", TString::Format("B Mass, #psi(2S) Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH2D *h2_Hlt1_flags_B_Mass = new TH2D("h2_Hlt1_flags_B_Mass", "Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); TH2D *h2_Hlt1_flags_excl_B_Mass = new TH2D("h2_Hlt1_flags_excl_B_Mass", "Excl Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); h1_B_Mass_jpsi->GetXaxis()->SetTitle(end_state_mass_literal); h1_B_Mass_psi2s->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_excl_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); ConnectHlt1Decisions(data_chain); for (const auto &var : Hlt1Decisions) { if (data_chain->FindBranch(var.GetName().c_str())) { h2_Hlt1_flags_B_Mass->Fill(0., var.name.c_str(), 0.); h2_Hlt1_flags_excl_B_Mass->Fill(0., var.name.c_str(), 0.); } } auto hlt1_decision_histos = CreateHlt1DecisionHistos(analysis_name); std::map exclusive_hits{}; unsigned int entries = data_chain->GetEntries(); for (unsigned int i = 0; i < entries; i++) { data_chain->GetEntry(i); TLorentzVector dimuon = l14v->LorentzVector() + l24v->LorentzVector(); Double_t reconstructed_B_Mass = (hp4v->LorentzVector(K_MASS) + dimuon).M(); if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { CheckHlt1Decisioins(h2_Hlt1_flags_B_Mass, h2_Hlt1_flags_excl_B_Mass, exclusive_hits, reconstructed_B_Mass); FillHlt1DecisionHistos(hlt1_decision_histos, reconstructed_B_Mass); } if (CutHlt1DecisionsOr({"TwoTrackMuonMVA", "DiMuonHighMass"})) { if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { h1_B_Mass_jpsi->Fill(reconstructed_B_Mass); } else if (TMath::Abs(dimuon.M() - PSI2S_MASS) < 100.) { h1_B_Mass_psi2s->Fill(reconstructed_B_Mass); } } PrintProgress(analysis_name, entries, 10000, i); } std::cout << "# Exclusive Hits" << std::endl; for (const auto &[line, hits] : exclusive_hits) { std::cout << line << ": " << hits << std::endl; } DrawInDefaultCanvas(h2_Hlt1_flags_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h2_Hlt1_flags_excl_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h1_B_Mass_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(h1_B_Mass_psi2s, analysis_name, 0.1); auto roofit_hist_jpsi = CreateRooFitHistogram(h1_B_Mass_jpsi); auto roofit_hist_psi2s = CreateRooFitHistogram(h1_B_Mass_psi2s); DrawInDefaultCanvas(roofit_hist_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(roofit_hist_psi2s, analysis_name, 0.1); DrawHlt1DecisionHistos(analysis_name, hlt1_decision_histos); return 0; } int analyze_bu2hpmumu_simulation() { const char *analysis_name = "BuToHpMuMu_noPID"; const char *end_state_mass_literal = "m(#pi^{+}_{(#rightarrow K^{+})}#mu^{+}#mu^{-})"; TChain *sim_chain = new TChain(TString::Format("%s/DecayTree", analysis_name)); sim_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/MC/rd_btoxll_simulation_fullstream_v0r0p6671378_BuToKpMuMu_12143001_magdown.root"); FourVect *l14v = FourVect::Init(sim_chain, "L1"); FourVect *l24v = FourVect::Init(sim_chain, "L2"); FourVect *hp4v = FourVect::Init(sim_chain, "Hp"); Int_t B_BKGCAT, L1_TRUEID, L2_TRUEID, Hp_TRUEID; sim_chain->SetBranchAddress("L1_TRUEID", &L1_TRUEID); sim_chain->SetBranchAddress("L2_TRUEID", &L2_TRUEID); sim_chain->SetBranchAddress("Hp_TRUEID", &Hp_TRUEID); sim_chain->SetBranchAddress("B_BKGCAT", &B_BKGCAT); TH1D *h1_B_Mass_jpsi = new TH1D("h1_B_Mass_jpsi", TString::Format("B Mass, J/#psi Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH1D *h1_B_Mass_psi2s = new TH1D("h1_B_Mass_psi2s", TString::Format("B Mass, #psi(2S) Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH2D *h2_Hlt1_flags_B_Mass = new TH2D("h2_Hlt1_flags_B_Mass", "Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); TH2D *h2_Hlt1_flags_excl_B_Mass = new TH2D("h2_Hlt1_flags_excl_B_Mass", "Excl Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); h1_B_Mass_jpsi->GetXaxis()->SetTitle(end_state_mass_literal); h1_B_Mass_psi2s->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_excl_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); ConnectHlt1Decisions(sim_chain); for (const auto &var : Hlt1Decisions) { if (sim_chain->FindBranch(var.GetName().c_str())) { h2_Hlt1_flags_B_Mass->Fill(0., var.name.c_str(), 0.); h2_Hlt1_flags_excl_B_Mass->Fill(0., var.name.c_str(), 0.); } } auto hlt1_decision_histos = CreateHlt1DecisionHistos(analysis_name); std::map exclusive_hits{}; unsigned int entries = sim_chain->GetEntries(); for (unsigned int i = 0; i < entries; i++) { sim_chain->GetEntry(i); if (B_BKGCAT == 30 && TMath::Abs(L1_TRUEID) == PID_MUON && L2_TRUEID == -L1_TRUEID && TMath::Abs(Hp_TRUEID) == PID_KAON) { TLorentzVector dimuon = l14v->LorentzVector() + l24v->LorentzVector(); Double_t reconstructed_B_Mass = (hp4v->LorentzVector(K_MASS) + dimuon).M(); if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { CheckHlt1Decisioins(h2_Hlt1_flags_B_Mass, h2_Hlt1_flags_excl_B_Mass, exclusive_hits, reconstructed_B_Mass); FillHlt1DecisionHistos(hlt1_decision_histos, reconstructed_B_Mass); } if (CutHlt1DecisionsOr({"TwoTrackMuonMVA", "DiMuonHighMass"})) { if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { h1_B_Mass_jpsi->Fill(reconstructed_B_Mass); } else if (TMath::Abs(dimuon.M() - PSI2S_MASS) < 100.) { h1_B_Mass_psi2s->Fill(reconstructed_B_Mass); } } } PrintProgress(analysis_name, entries, 10000, i); } std::cout << "# Exclusive Hits" << std::endl; for (const auto &[line, hits] : exclusive_hits) { std::cout << line << ": " << hits << std::endl; } DrawInDefaultCanvas(h2_Hlt1_flags_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h2_Hlt1_flags_excl_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h1_B_Mass_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(h1_B_Mass_psi2s, analysis_name, 0.1); auto roofit_hist_jpsi = CreateRooFitHistogram(h1_B_Mass_jpsi); auto roofit_hist_psi2s = CreateRooFitHistogram(h1_B_Mass_psi2s); DrawInDefaultCanvas(roofit_hist_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(roofit_hist_psi2s, analysis_name, 0.1); DrawHlt1DecisionHistos(analysis_name, hlt1_decision_histos); return 0; } // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% B0 To Hp Hm Mu Mu %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% int analyze_b02hphmmumu() { const char *analysis_name = "B0ToHpHmMuMu"; const char *end_state_mass_literal = "m(#pi^{+}_{(#rightarrow K^{+})} #pi^{-} #mu^{+}#mu^{-})"; TChain *data_chain = new TChain(TString::Format("%s/DecayTree", analysis_name)); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/spruce_magdown_2023_v0_tuple_90000000_v0r0p6288631.root"); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/spruce_magdown_2023_v0r1_tuple_90000000_2023_v0r0p6288631.root"); Double_t Hp_PID_K, Hm_PID_K, Hp_PID_PI, Hm_PID_PI; data_chain->SetBranchAddress("Hp_PID_K", &Hp_PID_K); data_chain->SetBranchAddress("Hm_PID_K", &Hm_PID_K); data_chain->SetBranchAddress("Hp_PID_PI", &Hp_PID_PI); data_chain->SetBranchAddress("Hm_PID_PI", &Hm_PID_PI); FourVect *l14v = FourVect::Init(data_chain, "L1"); FourVect *l24v = FourVect::Init(data_chain, "L2"); FourVect *hp4v = FourVect::Init(data_chain, "Hp"); FourVect *hm4v = FourVect::Init(data_chain, "Hm"); TH1D *h1_B_Mass_jpsi = new TH1D("h1_B_Mass_jpsi", TString::Format("B Mass, J/#psi Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH1D *h1_B_Mass_psi2s = new TH1D("h1_B_Mass_psi2s", TString::Format("B Mass, #psi(2S) Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH2D *h2_Hlt1_flags_B_Mass = new TH2D("h2_Hlt1_flags_B_Mass", "Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); TH2D *h2_Hlt1_flags_excl_B_Mass = new TH2D("h2_Hlt1_flags_excl_B_Mass", "Excl Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); h1_B_Mass_jpsi->GetXaxis()->SetTitle(end_state_mass_literal); h1_B_Mass_psi2s->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_excl_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); ConnectHlt1Decisions(data_chain); for (const auto &var : Hlt1Decisions) { h2_Hlt1_flags_B_Mass->Fill(0., var.name.c_str(), 0.); h2_Hlt1_flags_excl_B_Mass->Fill(0., var.name.c_str(), 0.); } auto hlt1_decision_histos = CreateHlt1DecisionHistos(analysis_name); std::map exclusive_hits{}; unsigned int entries = data_chain->GetEntries(); for (unsigned int i = 0; i < entries; i++) { data_chain->GetEntry(i); TLorentzVector dimuon = l14v->LorentzVector() + l24v->LorentzVector(); TLorentzVector lv_hp{}; TLorentzVector lv_hm{}; if (Hp_PID_K > 0 && Hm_PID_K < 0) { continue; lv_hp = hp4v->LorentzVector(K_MASS); lv_hm = hm4v->LorentzVector(); } else if (Hp_PID_K < 0 && Hm_PID_K > 0) { lv_hp = hp4v->LorentzVector(); lv_hm = hm4v->LorentzVector(K_MASS); } else { continue; } Double_t reconstructed_Kstar_Mass = (lv_hp + lv_hm).M(); Double_t reconstructed_B_Mass = (lv_hp + lv_hm + dimuon).M(); if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { CheckHlt1Decisioins(h2_Hlt1_flags_B_Mass, h2_Hlt1_flags_excl_B_Mass, exclusive_hits, reconstructed_B_Mass); FillHlt1DecisionHistos(hlt1_decision_histos, reconstructed_B_Mass); } if (CutHlt1DecisionsOr({"TwoTrackMuonMVA", "DiMuonHighMass"})) { if (TMath::Abs(reconstructed_Kstar_Mass - KSTAR_MASS) < 50.) { if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { h1_B_Mass_jpsi->Fill(reconstructed_B_Mass); } else if (TMath::Abs(dimuon.M() - PSI2S_MASS) < 100.) { h1_B_Mass_psi2s->Fill(reconstructed_B_Mass); } } } PrintProgress(analysis_name, entries, 10000, i); } std::cout << "# Exclusive Hits" << std::endl; for (const auto &[line, hits] : exclusive_hits) { std::cout << line << ": " << hits << std::endl; } DrawInDefaultCanvas(h2_Hlt1_flags_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h2_Hlt1_flags_excl_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h1_B_Mass_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(h1_B_Mass_psi2s, analysis_name, 0.1); auto roofit_hist_jpsi = CreateRooFitHistogram(h1_B_Mass_jpsi); auto roofit_hist_psi2s = CreateRooFitHistogram(h1_B_Mass_psi2s); DrawInDefaultCanvas(roofit_hist_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(roofit_hist_psi2s, analysis_name, 0.1); DrawHlt1DecisionHistos(analysis_name, hlt1_decision_histos); return 0; } // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Hlt2RD_BuToKpMuMu %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% int analyze_Hlt2RD_BuToKpMuMu() { const char *analysis_name = "Hlt2RD_BuToKpMuMu"; const char *end_state_mass_literal = "m(K^{+} #mu^{+}#mu^{-})"; TChain *data_chain = new TChain(TString::Format("%s/DecayTree", analysis_name)); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/Collision23_Beam6800GeV-VeloClosed-MagDown-Excl-UT_RealData_SprucingPass23r1_94000000_RD.root"); FourVect *l14v = FourVect::Init(data_chain, "muplus"); FourVect *l24v = FourVect::Init(data_chain, "muminus"); FourVect *hp4v = FourVect::Init(data_chain, "Kplus"); TH1D *h1_B_Mass_jpsi = new TH1D("h1_B_Mass_jpsi", TString::Format("B Mass, J/#psi Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH1D *h1_B_Mass_psi2s = new TH1D("h1_B_Mass_psi2s", TString::Format("B Mass, #psi(2S) Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH2D *h2_Hlt1_flags_B_Mass = new TH2D("h2_Hlt1_flags_B_Mass", "Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); TH2D *h2_Hlt1_flags_excl_B_Mass = new TH2D("h2_Hlt1_flags_excl_B_Mass", "Excl Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); h1_B_Mass_jpsi->GetXaxis()->SetTitle(end_state_mass_literal); h1_B_Mass_psi2s->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_excl_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); ConnectHlt1Decisions(data_chain); for (const auto &var : Hlt1Decisions) { h2_Hlt1_flags_B_Mass->Fill(0., var.name.c_str(), 0.); h2_Hlt1_flags_excl_B_Mass->Fill(0., var.name.c_str(), 0.); } auto hlt1_decision_histos = CreateHlt1DecisionHistos(analysis_name); std::map exclusive_hits{}; unsigned int entries = data_chain->GetEntries(); for (unsigned int i = 0; i < entries; i++) { data_chain->GetEntry(i); TLorentzVector dimuon = l14v->LorentzVector() + l24v->LorentzVector(); TLorentzVector lv_hp = hp4v->LorentzVector(); Double_t reconstructed_B_Mass = (lv_hp + dimuon).M(); if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { CheckHlt1Decisioins(h2_Hlt1_flags_B_Mass, h2_Hlt1_flags_excl_B_Mass, exclusive_hits, reconstructed_B_Mass); FillHlt1DecisionHistos(hlt1_decision_histos, reconstructed_B_Mass); } if (CutHlt1DecisionsOr({"TwoTrackMuonMVA", "DiMuonHighMass"})) { if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { h1_B_Mass_jpsi->Fill(reconstructed_B_Mass); } else if (TMath::Abs(dimuon.M() - PSI2S_MASS) < 100.) { h1_B_Mass_psi2s->Fill(reconstructed_B_Mass); } } PrintProgress("Hlt2RD_BuToKpMuMu", entries, 10000, i); } std::cout << "# Exclusive Hits" << std::endl; for (const auto &[line, hits] : exclusive_hits) { std::cout << line << ": " << hits << std::endl; } DrawInDefaultCanvas(h2_Hlt1_flags_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h2_Hlt1_flags_excl_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h1_B_Mass_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(h1_B_Mass_psi2s, analysis_name, 0.1); auto roofit_hist_jpsi = CreateRooFitHistogram(h1_B_Mass_jpsi); auto roofit_hist_psi2s = CreateRooFitHistogram(h1_B_Mass_psi2s); DrawInDefaultCanvas(roofit_hist_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(roofit_hist_psi2s, analysis_name, 0.1); DrawHlt1DecisionHistos(analysis_name, hlt1_decision_histos); return 0; } // %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% Hlt2RD_B0ToKpPimMuMu %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% int analyze_Hlt2RD_B0ToKpPimMuMu() { const char *analysis_name = "Hlt2RD_B0ToKpPimMuMu"; const char *end_state_mass_literal = "m(K^{+} #pi^{-} #mu^{+}#mu^{-})"; TChain *data_chain = new TChain(TString::Format("%s/DecayTree", analysis_name)); data_chain->Add("/auto/data/pfeiffer/inclusive_detached_dilepton/data_samples/Collision23_Beam6800GeV-VeloClosed-MagDown-Excl-UT_RealData_SprucingPass23r1_94000000_RD.root"); FourVect *l14v = FourVect::Init(data_chain, "muplus"); FourVect *l24v = FourVect::Init(data_chain, "muminus"); FourVect *hp4v = FourVect::Init(data_chain, "Kplus"); FourVect *hm4v = FourVect::Init(data_chain, "piminus"); TH1D *h1_B_Mass_jpsi = new TH1D("h1_B_Mass_jpsi", TString::Format("B Mass, J/#psi Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH1D *h1_B_Mass_psi2s = new TH1D("h1_B_Mass_psi2s", TString::Format("B Mass, #psi(2S) Mode (%s)", analysis_name), B_MASS_HIST_BINS, B_MASS_VAR_MIN, B_MASS_VAR_MAX); TH2D *h2_Hlt1_flags_B_Mass = new TH2D("h2_Hlt1_flags_B_Mass", "Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); TH2D *h2_Hlt1_flags_excl_B_Mass = new TH2D("h2_Hlt1_flags_excl_B_Mass", "Excl Hlt1 Decision vs B Mass", 50, 5100, 5400, 13, 1., 14.); h1_B_Mass_jpsi->GetXaxis()->SetTitle(end_state_mass_literal); h1_B_Mass_psi2s->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); h2_Hlt1_flags_excl_B_Mass->GetXaxis()->SetTitle(end_state_mass_literal); ConnectHlt1Decisions(data_chain); for (const auto &var : Hlt1Decisions) { h2_Hlt1_flags_B_Mass->Fill(0., var.name.c_str(), 0.); h2_Hlt1_flags_excl_B_Mass->Fill(0., var.name.c_str(), 0.); } auto hlt1_decision_histos = CreateHlt1DecisionHistos(analysis_name); std::map exclusive_hits{}; unsigned int entries = data_chain->GetEntries(); for (unsigned int i = 0; i < entries; i++) { data_chain->GetEntry(i); TLorentzVector dimuon = l14v->LorentzVector() + l24v->LorentzVector(); TLorentzVector lv_hp = hp4v->LorentzVector(); TLorentzVector lv_hm = hm4v->LorentzVector(); Double_t reconstructed_Kstar_Mass = (lv_hp + lv_hm).M(); Double_t reconstructed_B_Mass = (lv_hp + lv_hm + dimuon).M(); if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { CheckHlt1Decisioins(h2_Hlt1_flags_B_Mass, h2_Hlt1_flags_excl_B_Mass, exclusive_hits, reconstructed_B_Mass); FillHlt1DecisionHistos(hlt1_decision_histos, reconstructed_B_Mass); } if (CutHlt1DecisionsOr({"TwoTrackMuonMVA", "DiMuonHighMass"})) { if (TMath::Abs(reconstructed_Kstar_Mass - KSTAR_MASS) < 50.) { if (TMath::Abs(dimuon.M() - JPSI_MASS) < 100.) { h1_B_Mass_jpsi->Fill(reconstructed_B_Mass); } else if (TMath::Abs(dimuon.M() - PSI2S_MASS) < 100.) { h1_B_Mass_psi2s->Fill(reconstructed_B_Mass); } } } PrintProgress(analysis_name, entries, 10000, i); } std::cout << "# Exclusive Hits" << std::endl; for (const auto &[line, hits] : exclusive_hits) { std::cout << line << ": " << hits << std::endl; } DrawInDefaultCanvas(h2_Hlt1_flags_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h2_Hlt1_flags_excl_B_Mass, analysis_name, 0.16, "COLZ"); DrawInDefaultCanvas(h1_B_Mass_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(h1_B_Mass_psi2s, analysis_name, 0.1); auto roofit_hist_jpsi = CreateRooFitHistogram(h1_B_Mass_jpsi); auto roofit_hist_psi2s = CreateRooFitHistogram(h1_B_Mass_psi2s); DrawInDefaultCanvas(roofit_hist_jpsi, analysis_name, 0.1); DrawInDefaultCanvas(roofit_hist_psi2s, analysis_name, 0.1); DrawHlt1DecisionHistos(analysis_name, hlt1_decision_histos); return 0; } int new_analysis() { return analyze_bu2hpmumu_data(); }