diff --git a/DQMOffline/MuonDPG/plugins/GEMTnPEfficiencyTask.cc b/DQMOffline/MuonDPG/plugins/GEMTnPEfficiencyTask.cc index f69a9a0054dc7..170ec3d988060 100644 --- a/DQMOffline/MuonDPG/plugins/GEMTnPEfficiencyTask.cc +++ b/DQMOffline/MuonDPG/plugins/GEMTnPEfficiencyTask.cc @@ -50,10 +50,14 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, auto baseDir = topFolder() + "Task/"; iBooker.setCurrentFolder(baseDir); - MonitorElement* me_GEM_pass_Ch_region = - iBooker.book2D("GEM_nPassingProbe_Ch_region", "GEM_nPassingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); - MonitorElement* me_GEM_fail_Ch_region = - iBooker.book2D("GEM_nFailingProbe_Ch_region", "GEM_nFailingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); + MonitorElement* me_GE11_pass_Ch_region = + iBooker.book2D("GE11_nPassingProbe_Ch_region", "GE11_nPassingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); + MonitorElement* me_GE11_fail_Ch_region = + iBooker.book2D("GE11_nFailingProbe_Ch_region", "GE11_nFailingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); + MonitorElement* me_GE21_pass_Ch_region = + iBooker.book2D("GE21_nPassingProbe_Ch_region", "GE21_nPassingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); + MonitorElement* me_GE21_fail_Ch_region = + iBooker.book2D("GE21_nFailingProbe_Ch_region", "GE21_nFailingProbe_Ch_region", 2, -1.5, 1.5, 36, 1, 37); MonitorElement* me_GEM_pass_Ch_region_GE1 = iBooker.book2D("GEM_nPassingProbe_Ch_region_GE1", "GEM_nPassingProbe_Ch_region_GE1", 4, 0, 4, 36, 1, 37); MonitorElement* me_GEM_fail_Ch_region_GE1 = @@ -62,22 +66,38 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, iBooker.book2D("GEM_nPassingProbe_Ch_region_GE1_NoL", "GEM_nPassingProbe_Ch_region_GE1_NoL", 2, 0, 2, 36, 1, 37); MonitorElement* me_GEM_fail_Ch_region_GE1_NoL = iBooker.book2D("GEM_nFailingProbe_Ch_region_GE1_NoL", "GEM_nFailingProbe_Ch_region_GE1_NoL", 2, 0, 2, 36, 1, 37); - MonitorElement* me_GEM_pass_Ch_eta = - iBooker.book2D("GEM_nPassingProbe_Ch_eta", "GEM_nPassingProbe_Ch_eta", 24, 0, 2.4, 36, 1, 37); - MonitorElement* me_GEM_fail_Ch_eta = - iBooker.book2D("GEM_nFailingProbe_Ch_eta", "GEM_nFailingProbe_Ch_eta", 24, 0, 2.4, 36, 1, 37); - MonitorElement* me_GEM_pass_Ch_phi = - iBooker.book2D("GEM_nPassingProbe_Ch_phi", "GEM_nPassingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37); - MonitorElement* me_GEM_fail_Ch_phi = - iBooker.book2D("GEM_nFailingProbe_Ch_phi", "GEM_nFailingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37); - MonitorElement* me_GEM_pass_allCh_1D = - iBooker.book1D("GEM_nPassingProbe_allCh_1D", "GEM_nPassingProbe_allCh_1D", 2, -1.5, 1.5); - MonitorElement* me_GEM_fail_allCh_1D = - iBooker.book1D("GEM_nFailingProbe_allCh_1D", "GEM_nFailingProbe_allCh_1D", 2, -1.5, 1.5); - MonitorElement* me_GEM_pass_chamber_1D = - iBooker.book1D("GEM_nPassingProbe_chamber_1D", "GEM_nPassingProbe_chamber_1D", 36, 1, 37); - MonitorElement* me_GEM_fail_chamber_1D = - iBooker.book1D("GEM_nFailingProbe_chamber_1D", "GEM_nFailingProbe_chamber_1D", 36, 1, 37); + MonitorElement* me_GE11_pass_Ch_ieta = + iBooker.book2D("GE11_nPassingProbe_Ch_ieta", "GE11_nPassingProbe_Ch_ieta", 8, 1, 9, 36, 1, 37); + MonitorElement* me_GE11_fail_Ch_ieta = + iBooker.book2D("GE11_nFailingProbe_Ch_ieta", "GE11_nFailingProbe_Ch_ieta", 8, 1, 9, 36, 1, 37); + MonitorElement* me_GE11_pass_Ch_phi = iBooker.book2D( + "GE11_nPassingProbe_Ch_phi", "GE11_nPassingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37); + MonitorElement* me_GE11_fail_Ch_phi = iBooker.book2D( + "GE11_nFailingProbe_Ch_phi", "GE11_nFailingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 36, 1, 37); + MonitorElement* me_GE11_pass_allCh_1D = + iBooker.book1D("GE11_nPassingProbe_allCh_1D", "GE11_nPassingProbe_allCh_1D", 2, -1.5, 1.5); + MonitorElement* me_GE11_fail_allCh_1D = + iBooker.book1D("GE11_nFailingProbe_allCh_1D", "GE11_nFailingProbe_allCh_1D", 2, -1.5, 1.5); + MonitorElement* me_GE11_pass_chamber_1D = + iBooker.book1D("GE11_nPassingProbe_chamber_1D", "GE11_nPassingProbe_chamber_1D", 36, 1, 37); + MonitorElement* me_GE11_fail_chamber_1D = + iBooker.book1D("GE11_nFailingProbe_chamber_1D", "GE11_nFailingProbe_chamber_1D", 36, 1, 37); + MonitorElement* me_GE21_pass_Ch_ieta = + iBooker.book2D("GE21_nPassingProbe_Ch_ieta", "GE21_nPassingProbe_Ch_ieta", 16, 1, 17, 18, 1, 19); + MonitorElement* me_GE21_fail_Ch_ieta = + iBooker.book2D("GE21_nFailingProbe_Ch_ieta", "GE21_nFailingProbe_Ch_ieta", 16, 1, 17, 18, 1, 19); + MonitorElement* me_GE21_pass_Ch_phi = iBooker.book2D( + "GE21_nPassingProbe_Ch_phi", "GE21_nPassingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 18, 1, 19); + MonitorElement* me_GE21_fail_Ch_phi = iBooker.book2D( + "GE21_nFailingProbe_Ch_phi", "GE21_nFailingProbe_Ch_phi", 20, -TMath::Pi(), TMath::Pi(), 18, 1, 19); + MonitorElement* me_GE21_pass_allCh_1D = + iBooker.book1D("GE21_nPassingProbe_allCh_1D", "GE21_nPassingProbe_allCh_1D", 2, -1.5, 1.5); + MonitorElement* me_GE21_fail_allCh_1D = + iBooker.book1D("GE21_nFailingProbe_allCh_1D", "GE21_nFailingProbe_allCh_1D", 2, -1.5, 1.5); + MonitorElement* me_GE21_pass_chamber_1D = + iBooker.book1D("GE21_nPassingProbe_chamber_1D", "GE21_nPassingProbe_chamber_1D", 18, 1, 19); + MonitorElement* me_GE21_fail_chamber_1D = + iBooker.book1D("GE21_nFailingProbe_chamber_1D", "GE21_nFailingProbe_chamber_1D", 18, 1, 19); MonitorElement* me_GEM_pass_chamber_p1_1D = iBooker.book1D("GEM_nPassingProbe_chamber_p1_1D", "GEM_nPassingProbe_chamber_p1_1D", 36, 1, 37); MonitorElement* me_GEM_fail_chamber_p1_1D = @@ -164,18 +184,31 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, MonitorElement* me_GEM_fail_Ch_region_layer_phase2 = iBooker.book2D( "GEM_nFailingProbe_Ch_region_layer_phase2", "GEM_nFailingProbe_Ch_region_layer_phase2", 10, 0, 10, 36, 1, 37); - me_GEM_pass_allCh_1D->setBinLabel(1, "GE-11", 1); - me_GEM_pass_allCh_1D->setBinLabel(2, "GE11", 1); - me_GEM_pass_allCh_1D->setAxisTitle("Number of passing probes", 2); + me_GE11_pass_allCh_1D->setBinLabel(1, "GE-11", 1); + me_GE11_pass_allCh_1D->setBinLabel(2, "GE+11", 1); + me_GE11_pass_allCh_1D->setAxisTitle("Number of passing probes", 2); - me_GEM_fail_allCh_1D->setBinLabel(1, "GE-11", 1); - me_GEM_fail_allCh_1D->setBinLabel(2, "GE11", 1); - me_GEM_fail_allCh_1D->setAxisTitle("Number of failing probes", 2); + me_GE11_fail_allCh_1D->setBinLabel(1, "GE-11", 1); + me_GE11_fail_allCh_1D->setBinLabel(2, "GE+11", 1); + me_GE11_fail_allCh_1D->setAxisTitle("Number of failing probes", 2); - me_GEM_pass_chamber_1D->setAxisTitle("Chamber", 1); - me_GEM_pass_chamber_1D->setAxisTitle("Number of passing probes", 2); - me_GEM_fail_chamber_1D->setAxisTitle("Chamber", 1); - me_GEM_fail_chamber_1D->setAxisTitle("Number of failing probes", 2); + me_GE11_pass_chamber_1D->setAxisTitle("Chamber", 1); + me_GE11_pass_chamber_1D->setAxisTitle("Number of passing probes", 2); + me_GE11_fail_chamber_1D->setAxisTitle("Chamber", 1); + me_GE11_fail_chamber_1D->setAxisTitle("Number of failing probes", 2); + + me_GE21_pass_allCh_1D->setBinLabel(1, "GE-21", 1); + me_GE21_pass_allCh_1D->setBinLabel(2, "GE+21", 1); + me_GE21_pass_allCh_1D->setAxisTitle("Number of passing probes", 2); + + me_GE21_fail_allCh_1D->setBinLabel(1, "GE-21", 1); + me_GE21_fail_allCh_1D->setBinLabel(2, "GE+21", 1); + me_GE21_fail_allCh_1D->setAxisTitle("Number of failing probes", 2); + + me_GE21_pass_chamber_1D->setAxisTitle("Chamber", 1); + me_GE21_pass_chamber_1D->setAxisTitle("Number of passing probes", 2); + me_GE21_fail_chamber_1D->setAxisTitle("Chamber", 1); + me_GE21_fail_chamber_1D->setAxisTitle("Number of failing probes", 2); me_GEM_pass_chamber_p1_1D->setAxisTitle("Chamber", 1); me_GEM_pass_chamber_p1_1D->setAxisTitle("Number of passing probes", 2); @@ -272,26 +305,42 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, me_GEM_fail_phi_n2_1D->setAxisTitle("#phi", 1); me_GEM_fail_phi_n2_1D->setAxisTitle("Number of failing probes", 2); - me_GEM_fail_Ch_region->setBinLabel(1, "GE-11", 1); - me_GEM_fail_Ch_region->setBinLabel(2, "GE11", 1); + me_GE11_fail_Ch_region->setBinLabel(1, "GE-11", 1); + me_GE11_fail_Ch_region->setBinLabel(2, "GE+11", 1); for (int i = 1; i < 37; ++i) { - me_GEM_fail_Ch_region->setBinLabel(i, std::to_string(i), 2); + me_GE11_fail_Ch_region->setBinLabel(i, std::to_string(i), 2); } - me_GEM_fail_Ch_region->setAxisTitle("Chamber", 2); - me_GEM_fail_Ch_region->setAxisTitle("Number of failing probes", 3); + me_GE11_fail_Ch_region->setAxisTitle("Chamber", 2); + me_GE11_fail_Ch_region->setAxisTitle("Number of failing probes", 3); - me_GEM_pass_Ch_region->setBinLabel(1, "GE-11", 1); - me_GEM_pass_Ch_region->setBinLabel(2, "GE11", 1); + me_GE11_pass_Ch_region->setBinLabel(1, "GE-11", 1); + me_GE11_pass_Ch_region->setBinLabel(2, "GE+11", 1); for (int i = 1; i < 37; ++i) { - me_GEM_pass_Ch_region->setBinLabel(i, std::to_string(i), 2); + me_GE11_pass_Ch_region->setBinLabel(i, std::to_string(i), 2); + } + me_GE11_pass_Ch_region->setAxisTitle("Chamber", 2); + me_GE11_pass_Ch_region->setAxisTitle("Number of passing probes", 3); + + me_GE21_fail_Ch_region->setBinLabel(1, "GE-21", 1); + me_GE21_fail_Ch_region->setBinLabel(2, "GE+21", 1); + for (int i = 1; i < 19; ++i) { + me_GE21_fail_Ch_region->setBinLabel(i, std::to_string(i), 2); } - me_GEM_pass_Ch_region->setAxisTitle("Chamber", 2); - me_GEM_pass_Ch_region->setAxisTitle("Number of passing probes", 3); + me_GE21_fail_Ch_region->setAxisTitle("Chamber", 2); + me_GE21_fail_Ch_region->setAxisTitle("Number of failing probes", 3); + + me_GE21_pass_Ch_region->setBinLabel(1, "GE-21", 1); + me_GE21_pass_Ch_region->setBinLabel(2, "GE+21", 1); + for (int i = 1; i < 19; ++i) { + me_GE21_pass_Ch_region->setBinLabel(i, std::to_string(i), 2); + } + me_GE21_pass_Ch_region->setAxisTitle("Chamber", 2); + me_GE21_pass_Ch_region->setAxisTitle("Number of passing probes", 3); me_GEM_fail_Ch_region_GE1->setBinLabel(1, "GE-1/1_L2", 1); me_GEM_fail_Ch_region_GE1->setBinLabel(2, "GE-1/1_L1", 1); - me_GEM_fail_Ch_region_GE1->setBinLabel(3, "GE1/1_L1", 1); - me_GEM_fail_Ch_region_GE1->setBinLabel(4, "GE1/1_L2", 1); + me_GEM_fail_Ch_region_GE1->setBinLabel(3, "GE+1/1_L1", 1); + me_GEM_fail_Ch_region_GE1->setBinLabel(4, "GE+1/1_L2", 1); for (int i = 1; i < 37; ++i) { me_GEM_fail_Ch_region_GE1->setBinLabel(i, std::to_string(i), 2); } @@ -300,8 +349,8 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, me_GEM_pass_Ch_region_GE1->setBinLabel(1, "GE-1/1_L2", 1); me_GEM_pass_Ch_region_GE1->setBinLabel(2, "GE-1/1_L1", 1); - me_GEM_pass_Ch_region_GE1->setBinLabel(3, "GE1/1_L1", 1); - me_GEM_pass_Ch_region_GE1->setBinLabel(4, "GE1/1_L2", 1); + me_GEM_pass_Ch_region_GE1->setBinLabel(3, "GE+1/1_L1", 1); + me_GEM_pass_Ch_region_GE1->setBinLabel(4, "GE+1/1_L2", 1); for (int i = 1; i < 37; ++i) { me_GEM_pass_Ch_region_GE1->setBinLabel(i, std::to_string(i), 2); } @@ -323,34 +372,74 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, } me_GEM_pass_Ch_region_GE1_NoL->setAxisTitle("Chamber", 2); me_GEM_pass_Ch_region_GE1_NoL->setAxisTitle("Number of passing probes", 3); - + /////////////// for (int i = 1; i < 37; ++i) { - me_GEM_fail_Ch_eta->setBinLabel(i, std::to_string(i), 2); + me_GE11_fail_Ch_ieta->setBinLabel(i, std::to_string(i), 2); } - me_GEM_fail_Ch_eta->setAxisTitle("#eta", 1); - me_GEM_fail_Ch_eta->setAxisTitle("Chamber", 2); - me_GEM_fail_Ch_eta->setAxisTitle("Number of failing probes", 3); + for (int i = 1; i < 9; ++i) { + me_GE11_fail_Ch_ieta->setBinLabel(i, std::to_string(i), 1); + } + me_GE11_fail_Ch_ieta->setAxisTitle("#ieta", 1); + me_GE11_fail_Ch_ieta->setAxisTitle("Chamber", 2); + me_GE11_fail_Ch_ieta->setAxisTitle("Number of failing probes", 3); for (int i = 1; i < 37; ++i) { - me_GEM_pass_Ch_eta->setBinLabel(i, std::to_string(i), 2); + me_GE11_pass_Ch_ieta->setBinLabel(i, std::to_string(i), 2); + } + for (int i = 1; i < 9; ++i) { + me_GE11_pass_Ch_ieta->setBinLabel(i, std::to_string(i), 1); } - me_GEM_pass_Ch_eta->setAxisTitle("#eta", 1); - me_GEM_pass_Ch_eta->setAxisTitle("Chamber", 2); - me_GEM_pass_Ch_eta->setAxisTitle("Number of passing probes", 3); + me_GE11_pass_Ch_ieta->setAxisTitle("#ieta", 1); + me_GE11_pass_Ch_ieta->setAxisTitle("Chamber", 2); + me_GE11_pass_Ch_ieta->setAxisTitle("Number of passing probes", 3); for (int i = 1; i < 37; ++i) { - me_GEM_fail_Ch_phi->setBinLabel(i, std::to_string(i), 2); + me_GE11_fail_Ch_phi->setBinLabel(i, std::to_string(i), 2); } - me_GEM_fail_Ch_phi->setAxisTitle("#phi", 1); - me_GEM_fail_Ch_phi->setAxisTitle("Chamber", 2); - me_GEM_fail_Ch_phi->setAxisTitle("Number of failing probes", 3); + me_GE11_fail_Ch_phi->setAxisTitle("#phi", 1); + me_GE11_fail_Ch_phi->setAxisTitle("Chamber", 2); + me_GE11_fail_Ch_phi->setAxisTitle("Number of failing probes", 3); for (int i = 1; i < 37; ++i) { - me_GEM_pass_Ch_phi->setBinLabel(i, std::to_string(i), 2); + me_GE11_pass_Ch_phi->setBinLabel(i, std::to_string(i), 2); } - me_GEM_pass_Ch_phi->setAxisTitle("#phi", 1); - me_GEM_pass_Ch_phi->setAxisTitle("Chamber", 2); - me_GEM_pass_Ch_phi->setAxisTitle("Number of passing probes", 3); + me_GE11_pass_Ch_phi->setAxisTitle("#phi", 1); + me_GE11_pass_Ch_phi->setAxisTitle("Chamber", 2); + me_GE11_pass_Ch_phi->setAxisTitle("Number of passing probes", 3); + + for (int i = 1; i < 19; ++i) { + me_GE21_fail_Ch_ieta->setBinLabel(i, std::to_string(i), 2); + } + for (int i = 1; i < 17; ++i) { + me_GE21_fail_Ch_ieta->setBinLabel(i, std::to_string(i), 1); + } + me_GE21_fail_Ch_ieta->setAxisTitle("#ieta", 1); + me_GE21_fail_Ch_ieta->setAxisTitle("Chamber", 2); + me_GE21_fail_Ch_ieta->setAxisTitle("Number of failing probes", 3); + + for (int i = 1; i < 19; ++i) { + me_GE21_pass_Ch_ieta->setBinLabel(i, std::to_string(i), 2); + } + for (int i = 1; i < 17; ++i) { + me_GE21_pass_Ch_ieta->setBinLabel(i, std::to_string(i), 1); + } + me_GE21_pass_Ch_ieta->setAxisTitle("#ieta", 1); + me_GE21_pass_Ch_ieta->setAxisTitle("Chamber", 2); + me_GE21_pass_Ch_ieta->setAxisTitle("Number of passing probes", 3); + ///////////////////// + for (int i = 1; i < 19; ++i) { + me_GE21_fail_Ch_phi->setBinLabel(i, std::to_string(i), 2); + } + me_GE21_fail_Ch_phi->setAxisTitle("#phi", 1); + me_GE21_fail_Ch_phi->setAxisTitle("Chamber", 2); + me_GE21_fail_Ch_phi->setAxisTitle("Number of failing probes", 3); + + for (int i = 1; i < 19; ++i) { + me_GE21_pass_Ch_phi->setBinLabel(i, std::to_string(i), 2); + } + me_GE21_pass_Ch_phi->setAxisTitle("#phi", 1); + me_GE21_pass_Ch_phi->setAxisTitle("Chamber", 2); + me_GE21_pass_Ch_phi->setAxisTitle("Number of passing probes", 3); for (int i = 1; i < 19; ++i) { me_ME0_pass_chamber_1D->setBinLabel(i, std::to_string(i), 1); @@ -367,12 +456,12 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, me_GEM_fail_Ch_region_layer_phase2->setBinLabel(2, "GE-2/1_L1", 1); me_GEM_fail_Ch_region_layer_phase2->setBinLabel(3, "GE-1/1_L2", 1); me_GEM_fail_Ch_region_layer_phase2->setBinLabel(4, "GE-1/1_L1", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(5, "GE0-1", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(6, "GE0+1", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(7, "GE1/1_L1", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(8, "GE1/1_L2", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(9, "GE2/1_L1", 1); - me_GEM_fail_Ch_region_layer_phase2->setBinLabel(10, "GE2/1_L2", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(5, "GE0-", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(6, "GE0+", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(7, "GE+1/1_L1", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(8, "GE+1/1_L2", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(9, "GE+2/1_L1", 1); + me_GEM_fail_Ch_region_layer_phase2->setBinLabel(10, "GE+2/1_L2", 1); for (int i = 1; i < 37; ++i) { me_GEM_fail_Ch_region_layer_phase2->setBinLabel(i, std::to_string(i), 2); } @@ -383,12 +472,12 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, me_GEM_pass_Ch_region_layer_phase2->setBinLabel(2, "GE-2/1_L1", 1); me_GEM_pass_Ch_region_layer_phase2->setBinLabel(3, "GE-1/1_L2", 1); me_GEM_pass_Ch_region_layer_phase2->setBinLabel(4, "GE-1/1_L1", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(5, "GE0-1", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(6, "GE0+1", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(7, "GE1/1_L1", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(8, "GE1/1_L2", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(9, "GE2/1_L1", 1); - me_GEM_pass_Ch_region_layer_phase2->setBinLabel(10, "GE2/1_L2", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(5, "GE0-", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(6, "GE0+", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(7, "GE+1/1_L1", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(8, "GE+1/1_L2", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(9, "GE+2/1_L1", 1); + me_GEM_pass_Ch_region_layer_phase2->setBinLabel(10, "GE+2/1_L2", 1); for (int i = 1; i < 37; ++i) { me_GEM_pass_Ch_region_layer_phase2->setBinLabel(i, std::to_string(i), 2); @@ -396,20 +485,30 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, me_GEM_pass_Ch_region_layer_phase2->setAxisTitle("Chamber", 2); me_GEM_pass_Ch_region_layer_phase2->setAxisTitle("Number of passing probes", 3); - m_histos["GEM_nPassingProbe_Ch_region"] = me_GEM_pass_Ch_region; - m_histos["GEM_nFailingProbe_Ch_region"] = me_GEM_fail_Ch_region; + m_histos["GE11_nPassingProbe_Ch_region"] = me_GE11_pass_Ch_region; + m_histos["GE11_nFailingProbe_Ch_region"] = me_GE11_fail_Ch_region; + m_histos["GE21_nPassingProbe_Ch_region"] = me_GE21_pass_Ch_region; + m_histos["GE21_nFailingProbe_Ch_region"] = me_GE21_fail_Ch_region; m_histos["GEM_nPassingProbe_Ch_region_GE1"] = me_GEM_pass_Ch_region_GE1; m_histos["GEM_nFailingProbe_Ch_region_GE1"] = me_GEM_fail_Ch_region_GE1; m_histos["GEM_nPassingProbe_Ch_region_GE1_NoL"] = me_GEM_pass_Ch_region_GE1_NoL; m_histos["GEM_nFailingProbe_Ch_region_GE1_NoL"] = me_GEM_fail_Ch_region_GE1_NoL; - m_histos["GEM_nPassingProbe_Ch_eta"] = me_GEM_pass_Ch_eta; - m_histos["GEM_nFailingProbe_Ch_eta"] = me_GEM_fail_Ch_eta; - m_histos["GEM_nPassingProbe_Ch_phi"] = me_GEM_pass_Ch_phi; - m_histos["GEM_nFailingProbe_Ch_phi"] = me_GEM_fail_Ch_phi; - m_histos["GEM_nPassingProbe_allCh_1D"] = me_GEM_pass_allCh_1D; - m_histos["GEM_nFailingProbe_allCh_1D"] = me_GEM_fail_allCh_1D; - m_histos["GEM_nPassingProbe_chamber_1D"] = me_GEM_pass_chamber_1D; - m_histos["GEM_nFailingProbe_chamber_1D"] = me_GEM_fail_chamber_1D; + m_histos["GE11_nPassingProbe_Ch_ieta"] = me_GE11_pass_Ch_ieta; + m_histos["GE11_nFailingProbe_Ch_ieta"] = me_GE11_fail_Ch_ieta; + m_histos["GE11_nPassingProbe_Ch_phi"] = me_GE11_pass_Ch_phi; + m_histos["GE11_nFailingProbe_Ch_phi"] = me_GE11_fail_Ch_phi; + m_histos["GE21_nPassingProbe_Ch_ieta"] = me_GE21_pass_Ch_ieta; + m_histos["GE21_nFailingProbe_Ch_ieta"] = me_GE21_fail_Ch_ieta; + m_histos["GE21_nPassingProbe_Ch_phi"] = me_GE21_pass_Ch_phi; + m_histos["GE21_nFailingProbe_Ch_phi"] = me_GE21_fail_Ch_phi; + m_histos["GE11_nPassingProbe_allCh_1D"] = me_GE11_pass_allCh_1D; + m_histos["GE11_nFailingProbe_allCh_1D"] = me_GE11_fail_allCh_1D; + m_histos["GE21_nPassingProbe_allCh_1D"] = me_GE21_pass_allCh_1D; + m_histos["GE21_nFailingProbe_allCh_1D"] = me_GE21_fail_allCh_1D; + m_histos["GE11_nPassingProbe_chamber_1D"] = me_GE11_pass_chamber_1D; + m_histos["GE11_nFailingProbe_chamber_1D"] = me_GE11_fail_chamber_1D; + m_histos["GE21_nPassingProbe_chamber_1D"] = me_GE21_pass_chamber_1D; + m_histos["GE21_nFailingProbe_chamber_1D"] = me_GE21_fail_chamber_1D; m_histos["GEM_nPassingProbe_chamber_p1_1D"] = me_GEM_pass_chamber_p1_1D; m_histos["GEM_nFailingProbe_chamber_p1_1D"] = me_GEM_fail_chamber_p1_1D; m_histos["GEM_nPassingProbe_chamber_p2_1D"] = me_GEM_pass_chamber_p2_1D; @@ -455,15 +554,16 @@ void GEMTnPEfficiencyTask::bookHistograms(DQMStore::IBooker& iBooker, std::string baseDir_ = topFolder() + "/detailed/"; iBooker.setCurrentFolder(baseDir_); - m_histos["GEMhit_dx"] = iBooker.book1D("GEMhit_dx", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.); - m_histos["GEMseg_dx"] = iBooker.book1D("GEMseg_dx", "GEMseg_dx;probe dx [cm];Events", 100, 0., 20.); + m_histos["GEMseg_dx_ME0"] = iBooker.book1D("GEMseg_dx_ME0", "GEMseg_dx;probe dx [cm];Events", 100, 0., 20.); + m_histos["GEMhit_dx_GE1"] = iBooker.book1D("GEMhit_dx_GE1", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.); + m_histos["GEMhit_dx_GE2"] = iBooker.book1D("GEMhit_dx_GE2", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.); - m_histos["GEMhit_x"] = iBooker.book1D("GEMhit_x", "GEMhit_x;probe x [cm];Events", 100, -10., 10.); + m_histos["GEMseg_x_ME0"] = iBooker.book1D("GEMhit_x_ME0", "GEMhit_x;probe x [cm];Events", 100, -10., 10.); + m_histos["GEMhit_x_GE1"] = iBooker.book1D("GEMhit_x_GE1", "GEMhit_x;probe x [cm];Events", 100, -10., 10.); m_histos["GEMhit_x_GE2"] = iBooker.book1D("GEMhit_x_GE2", "GEMhit_x;probe x [cm];Events", 100, -10., 10.); - m_histos["Cham_x"] = iBooker.book1D("Cham_x", "Cham_x;probe x [cm];Events", 100, -10., 10.); + m_histos["Cham_x_ME0"] = iBooker.book1D("Cham_x_ME0", "Cham_x;probe x [cm];Events", 100, -10., 10.); + m_histos["Cham_x_GE1"] = iBooker.book1D("Cham_x_GE1", "Cham_x;probe x [cm];Events", 100, -10., 10.); m_histos["Cham_x_GE2"] = iBooker.book1D("Cham_x_GE2", "Cham_x;probe x [cm];Events", 100, -10., 10.); - - m_histos["GEMhit_dx_GE2"] = iBooker.book1D("GEMhit_dx_GE2", "GEMhit_dx;probe dx [cm];Events", 100, 0., 10.); } void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetup& context) { @@ -472,16 +572,29 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu edm::Handle muons; event.getByToken(m_muToken, muons); - //GEM variables - std::vector> probe_coll_GEM_region; - std::vector> probe_coll_GEM_lay; - std::vector> probe_coll_GEM_chamber; - std::vector> probe_coll_GEM_pt; - std::vector> probe_coll_GEM_eta; - std::vector> probe_coll_GEM_phi; - std::vector> probe_coll_GEM_sta; - std::vector> probe_coll_GEM_dx; - std::vector probe_coll_GEM_staMatch; + //GE11 variables + std::vector> probe_coll_GE11_region; + std::vector> probe_coll_GE11_lay; + std::vector> probe_coll_GE11_chamber; + std::vector> probe_coll_GE11_pt; + std::vector> probe_coll_GE11_eta; + std::vector> probe_coll_GE11_ieta; + std::vector> probe_coll_GE11_phi; + std::vector> probe_coll_GE11_sta; + std::vector> probe_coll_GE11_dx; + + //GE21 variables + std::vector> probe_coll_GE21_region; + std::vector> probe_coll_GE21_lay; + std::vector> probe_coll_GE21_chamber; + std::vector> probe_coll_GE21_pt; + std::vector> probe_coll_GE21_eta; + std::vector> probe_coll_GE21_ieta; + std::vector> probe_coll_GE21_phi; + std::vector> probe_coll_GE21_sta; + std::vector> probe_coll_GE21_dx; + + std::vector probe_coll_GEM_staMatch; // ME0 to 0b0001, GE11 to 0b0010, GE21 to 0b0100 //ME0 variables std::vector> probe_coll_ME0_region; @@ -490,10 +603,10 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu std::vector> probe_coll_ME0_chamber; std::vector> probe_coll_ME0_pt; std::vector> probe_coll_ME0_eta; + std::vector> probe_coll_ME0_ieta; std::vector> probe_coll_ME0_phi; std::vector> probe_coll_ME0_sta; std::vector> probe_coll_ME0_dx; - std::vector probe_coll_ME0_staMatch; std::vector probe_indices; if (!m_probeIndices.empty()) @@ -501,15 +614,26 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu //Fill probe dx + subdetector coordinates for (const auto i : probe_indices) { - //GEM variables - std::vector probe_GEM_region; - std::vector probe_GEM_sta; - std::vector probe_GEM_lay; - std::vector probe_GEM_chamber; - std::vector probe_GEM_pt; - std::vector probe_GEM_eta; - std::vector probe_GEM_phi; - std::vector probe_GEM_dx; + //GE11 variables + std::vector probe_GE11_region; + std::vector probe_GE11_sta; + std::vector probe_GE11_lay; + std::vector probe_GE11_chamber; + std::vector probe_GE11_pt; + std::vector probe_GE11_eta; + std::vector probe_GE11_ieta; + std::vector probe_GE11_phi; + std::vector probe_GE11_dx; + //GE21 variables + std::vector probe_GE21_region; + std::vector probe_GE21_sta; + std::vector probe_GE21_lay; + std::vector probe_GE21_chamber; + std::vector probe_GE21_pt; + std::vector probe_GE21_eta; + std::vector probe_GE21_ieta; + std::vector probe_GE21_phi; + std::vector probe_GE21_dx; //std::vector probe_GEM_dx_seg; uint8_t GEM_stationMatching = 0; //ME0 variables @@ -520,17 +644,18 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu std::vector probe_ME0_chamber; std::vector probe_ME0_pt; std::vector probe_ME0_eta; + std::vector probe_ME0_ieta; std::vector probe_ME0_phi; std::vector probe_ME0_dx; - uint8_t ME0_stationMatching = 0; bool gem_matched = false; // fill detailed plots only for probes matching GEM for (const auto& chambMatch : (*muons).at(i).matches()) { // look in GEMs + bool hit_matched = false; // true if chambermatch has at least one hit (GE11, GE21) or segment (ME0) if (chambMatch.detector() == MuonSubdetId::GEM) { if (chambMatch.edgeX < m_borderCut && chambMatch.edgeY < m_borderCut) { - gem_matched = true; //fill detailed plots if at least one GEM match + gem_matched = true; //fill detailed plots if at least one GEM probe match GEMDetId chId(chambMatch.id.rawId()); @@ -539,78 +664,94 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu const int station = chId.station(); const int layer = chId.layer(); const int chamber = chId.chamber(); + const int ieta = chId.ieta(); const float pt = (*muons).at(i).pt(); const float eta = (*muons).at(i).eta(); const float phi = (*muons).at(i).phi(); - - reco::MuonGEMHitMatch closest_matchedHit; - double smallestDx = 99999.; - double matched_GEMHit_x = 99999.; - - for (auto& gemHit : chambMatch.gemHitMatches) { - float dx = std::abs(chambMatch.x - gemHit.x); - if (dx < smallestDx) { - smallestDx = dx; - closest_matchedHit = gemHit; - matched_GEMHit_x = gemHit.x; + GEM_stationMatching = GEM_stationMatching | (1 << station); + + if (station == 1 || station == 2) { + reco::MuonGEMHitMatch closest_matchedHit; + double smallestDx = 99999.; + double matched_GEMHit_x = 99999.; + + for (auto& gemHit : chambMatch.gemHitMatches) { + float dx = std::abs(chambMatch.x - gemHit.x); + if (dx < smallestDx) { + smallestDx = dx; + closest_matchedHit = gemHit; + matched_GEMHit_x = gemHit.x; + hit_matched = true; + } } - } - - reco::MuonSegmentMatch closest_matchedSegment; - double smallestDx_seg = 99999.; - for (auto& seg : chambMatch.gemMatches) { - float dx_seg = std::abs(chambMatch.x - seg.x); - if (dx_seg < smallestDx_seg) { - smallestDx_seg = dx_seg; - closest_matchedSegment = seg; + if (station == 1) { + probe_GE11_region.push_back(region); + probe_GE11_sta.push_back(station); + probe_GE11_lay.push_back(layer); + probe_GE11_chamber.push_back(chamber); + probe_GE11_ieta.push_back(ieta); + probe_GE11_pt.push_back(pt); + probe_GE11_eta.push_back(eta); + probe_GE11_phi.push_back(phi); + probe_GE11_dx.push_back(smallestDx); } - } - if (m_detailedAnalysis && gem_matched) { - m_histos.find("GEMhit_dx")->second->Fill(smallestDx); - m_histos.find("GEMhit_x")->second->Fill(matched_GEMHit_x); - m_histos.find("Cham_x")->second->Fill(chambMatch.x); - m_histos.find("GEMseg_dx")->second->Fill(smallestDx_seg); + if (station == 2) { - m_histos.find("GEMhit_dx_GE2")->second->Fill(smallestDx); - m_histos.find("GEMhit_x_GE2")->second->Fill(matched_GEMHit_x); - m_histos.find("Cham_x_GE2")->second->Fill(chambMatch.x); + probe_GE21_region.push_back(region); + probe_GE21_sta.push_back(station); + probe_GE21_lay.push_back(layer); + probe_GE21_chamber.push_back(chamber); + probe_GE21_ieta.push_back(ieta); + probe_GE21_pt.push_back(pt); + probe_GE21_eta.push_back(eta); + probe_GE21_phi.push_back(phi); + probe_GE21_dx.push_back(smallestDx); } - } - - GEM_stationMatching = GEM_stationMatching | (1 << (station - 1)); - probe_GEM_region.push_back(region); - probe_GEM_sta.push_back(station); - probe_GEM_lay.push_back(layer); - probe_GEM_chamber.push_back(chamber); - probe_GEM_pt.push_back(pt); - probe_GEM_eta.push_back(eta); - probe_GEM_phi.push_back(phi); - probe_GEM_dx.push_back(smallestDx); - //probe_GEM_dx.push_back(smallestDx_seg); - //probe_GEM_dx_seg.push_back(smallestDx_seg); + if (m_detailedAnalysis && hit_matched) { + if (station == 1) { + m_histos.find("GEMhit_dx_GE1")->second->Fill(smallestDx); + m_histos.find("GEMhit_x_GE1")->second->Fill(matched_GEMHit_x); + m_histos.find("Cham_x_GE1")->second->Fill(chambMatch.x); + } + if (station == 2) { + m_histos.find("GEMhit_dx_GE2")->second->Fill(smallestDx); + m_histos.find("GEMhit_x_GE2")->second->Fill(matched_GEMHit_x); + m_histos.find("Cham_x_GE2")->second->Fill(chambMatch.x); + } + } + } if (station == 0) { - reco::MuonSegmentMatch closest_matchedSegment_ME0; - double smallestDx_ME0 = 99999.; + reco::MuonSegmentMatch closest_matchedSegment; + double smallestDx_seg = 99999.; + for (auto& seg : chambMatch.gemMatches) { - float dx = std::abs(chambMatch.x - seg.x); - if (dx < smallestDx_ME0) { - smallestDx_ME0 = dx; - closest_matchedSegment_ME0 = seg; + float dx_seg = std::abs(chambMatch.x - seg.x); + if (dx_seg < smallestDx_seg) { + smallestDx_seg = dx_seg; + closest_matchedSegment = seg; + hit_matched = true; } } - ME0_stationMatching = ME0_stationMatching | (1 << (station - 1)); + probe_ME0_region.push_back(region); probe_ME0_roll.push_back(roll); probe_ME0_sta.push_back(station); probe_ME0_lay.push_back(layer); probe_ME0_chamber.push_back(chamber); + probe_ME0_ieta.push_back(ieta); probe_ME0_pt.push_back(pt); probe_ME0_eta.push_back(eta); probe_ME0_phi.push_back(phi); - probe_ME0_dx.push_back(smallestDx_ME0); + probe_ME0_dx.push_back(smallestDx_seg); + + if (m_detailedAnalysis && hit_matched) { + m_histos.find("GEMseg_dx_ME0")->second->Fill(smallestDx_seg); + m_histos.find("GEMseg_x_ME0")->second->Fill(closest_matchedSegment.x); + m_histos.find("Cham_x_ME0")->second->Fill(chambMatch.x); + } } } } else @@ -619,7 +760,7 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu //Fill detailed plots if (m_detailedAnalysis && gem_matched) { - m_histos.find("probeEta")->second->Fill(abs((*muons).at(i).eta())); + m_histos.find("probeEta")->second->Fill((*muons).at(i).eta()); m_histos.find("probePhi")->second->Fill((*muons).at(i).phi()); m_histos.find("probeNumberOfMatchedStations")->second->Fill((*muons).at(i).numberOfMatchedStations()); m_histos.find("probePt")->second->Fill((*muons).at(i).pt()); @@ -631,34 +772,46 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu } //Fill GEM variables - probe_coll_GEM_region.push_back(probe_GEM_region); - probe_coll_GEM_sta.push_back(probe_GEM_sta); - probe_coll_GEM_lay.push_back(probe_GEM_lay); - probe_coll_GEM_chamber.push_back(probe_GEM_chamber); - probe_coll_GEM_pt.push_back(probe_GEM_pt); - probe_coll_GEM_eta.push_back(probe_GEM_eta); - probe_coll_GEM_phi.push_back(probe_GEM_phi); - probe_coll_GEM_dx.push_back(probe_GEM_dx); + probe_coll_GE11_region.push_back(probe_GE11_region); + probe_coll_GE11_sta.push_back(probe_GE11_sta); + probe_coll_GE11_lay.push_back(probe_GE11_lay); + probe_coll_GE11_chamber.push_back(probe_GE11_chamber); + probe_coll_GE11_ieta.push_back(probe_GE11_ieta); + probe_coll_GE11_pt.push_back(probe_GE11_pt); + probe_coll_GE11_eta.push_back(probe_GE11_eta); + probe_coll_GE11_phi.push_back(probe_GE11_phi); + probe_coll_GE11_dx.push_back(probe_GE11_dx); + probe_coll_GEM_staMatch.push_back(GEM_stationMatching); + //Fill GE21 variables + probe_coll_GE21_region.push_back(probe_GE21_region); + probe_coll_GE21_sta.push_back(probe_GE21_sta); + probe_coll_GE21_lay.push_back(probe_GE21_lay); + probe_coll_GE21_chamber.push_back(probe_GE21_chamber); + probe_coll_GE21_ieta.push_back(probe_GE21_ieta); + probe_coll_GE21_pt.push_back(probe_GE21_pt); + probe_coll_GE21_eta.push_back(probe_GE21_eta); + probe_coll_GE21_phi.push_back(probe_GE21_phi); + probe_coll_GE21_dx.push_back(probe_GE21_dx); + //Fill ME0 variables probe_coll_ME0_region.push_back(probe_ME0_region); - probe_coll_ME0_roll.push_back(probe_ME0_roll); + probe_coll_ME0_roll.push_back(probe_ME0_roll); // same as ieta probe_coll_ME0_sta.push_back(probe_ME0_sta); probe_coll_ME0_lay.push_back(probe_ME0_lay); probe_coll_ME0_chamber.push_back(probe_ME0_chamber); + probe_coll_ME0_ieta.push_back(probe_ME0_ieta); probe_coll_ME0_pt.push_back(probe_ME0_pt); probe_coll_ME0_eta.push_back(probe_ME0_eta); probe_coll_ME0_phi.push_back(probe_ME0_phi); probe_coll_ME0_dx.push_back(probe_ME0_dx); - probe_coll_ME0_staMatch.push_back(ME0_stationMatching); } //loop over probe collection //Loop over probes for (unsigned i = 0; i < probe_indices.size(); ++i) { - uint8_t GEM_matchPatt = probe_coll_GEM_staMatch.at(i); - //uint8_t ME0_matchPatt = probe_coll_ME0_staMatch.at(i); + //uint8_t GEM_matchPatt = probe_coll_GEM_staMatch.at(i); // ME0 to 0b0001, GE11 to 0b0010, GE21 to 0b0100 //Loop over ME0 matches unsigned nME0_matches = probe_coll_ME0_region.at(i).size(); @@ -666,7 +819,7 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu //ME0 variables int ME0_region = probe_coll_ME0_region.at(i).at(j); //int ME0_roll = probe_coll_ME0_roll.at(i).at(j); - int ME0_sta = probe_coll_ME0_sta.at(i).at(j); + //int ME0_sta = probe_coll_ME0_sta.at(i).at(j); //int ME0_lay = probe_coll_ME0_lay.at(i).at(j); int ME0_chamber = probe_coll_ME0_chamber.at(i).at(j); //float ME0_pt = probe_coll_ME0_pt.at(i).at(j); @@ -674,164 +827,198 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu //float ME0_eta = probe_coll_ME0_eta.at(i).at(j); //float ME0_phi = probe_coll_ME0_phi.at(i).at(j); - if (ME0_sta == 0) { - if (ME0_dx < m_dxCut) { - m_histos.find("ME0_nPassingProbe_chamber_1D")->second->Fill(ME0_chamber); - if (ME0_region < 0) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber); - else if (ME0_region > 0) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber); - } else { - m_histos.find("ME0_nFailingProbe_chamber_1D")->second->Fill(ME0_chamber); - if (ME0_region < 0) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber); - else if (ME0_region > 0) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber); - } + if (ME0_dx < m_dxCut) { + m_histos.find("ME0_nPassingProbe_chamber_1D")->second->Fill(ME0_chamber); + if (ME0_region < 0) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber); + else if (ME0_region > 0) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber); + } else { + m_histos.find("ME0_nFailingProbe_chamber_1D")->second->Fill(ME0_chamber); + if (ME0_region < 0) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(4, ME0_chamber); + else if (ME0_region > 0) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(5, ME0_chamber); } } // - //Loop over GEM matches - unsigned nGEM_matches = probe_coll_GEM_region.at(i).size(); - for (unsigned j = 0; j < nGEM_matches; ++j) { + //Loop over GE11 matches + unsigned nGE11_matches = probe_coll_GE11_region.at(i).size(); + for (unsigned j = 0; j < nGE11_matches; ++j) { //GEM variables - int GEM_region = probe_coll_GEM_region.at(i).at(j); - int GEM_sta = probe_coll_GEM_sta.at(i).at(j); - int GEM_lay = probe_coll_GEM_lay.at(i).at(j); - int GEM_chamber = probe_coll_GEM_chamber.at(i).at(j); - float GEM_pt = probe_coll_GEM_pt.at(i).at(j); - float GEM_dx = probe_coll_GEM_dx.at(i).at(j); - float GEM_eta = probe_coll_GEM_eta.at(i).at(j); - float GEM_phi = probe_coll_GEM_phi.at(i).at(j); - + int GEM_region = probe_coll_GE11_region.at(i).at(j); + int GEM_sta = probe_coll_GE11_sta.at(i).at(j); + int GEM_lay = probe_coll_GE11_lay.at(i).at(j); + int GEM_chamber = probe_coll_GE11_chamber.at(i).at(j); + int GEM_ieta = probe_coll_GE11_ieta.at(i).at(j); + float GEM_pt = probe_coll_GE11_pt.at(i).at(j); + float GEM_dx = probe_coll_GE11_dx.at(i).at(j); + float GEM_eta = probe_coll_GE11_eta.at(i).at(j); + float GEM_phi = probe_coll_GE11_phi.at(i).at(j); //Fill GEM plots - if (((GEM_matchPatt & (1 << (GEM_sta - 1))) != 0) && GEM_sta != 0) //avoids 0 station matching - { - if (GEM_dx < m_dxCut) { - if (GEM_region == 1 && GEM_lay == 0 && GEM_sta == 2 && GEM_chamber == 16) - continue; //exclude GE2 ch16 of Run3 - m_histos.find("GEM_nPassingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_eta")->second->Fill(abs(GEM_eta), GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); - m_histos.find("GEM_nPassingProbe_allCh_1D")->second->Fill(GEM_region); - m_histos.find("GEM_nPassingProbe_chamber_1D")->second->Fill(GEM_chamber); - if (GEM_region < 0) { - if (GEM_sta == 2 and GEM_lay == 2) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 1) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 2) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 1) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber); - } - if (GEM_region > 0) { - if (GEM_sta == 1 and GEM_lay == 1) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 2) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 1) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 2) - m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber); - } - if (GEM_region == -1 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber); - } else if (GEM_region == 1 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber); - } + if (GEM_dx < m_dxCut) { + m_histos.find("GE11_nPassingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); + m_histos.find("GE11_nPassingProbe_Ch_ieta")->second->Fill(GEM_ieta, GEM_chamber); + m_histos.find("GE11_nPassingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); + m_histos.find("GE11_nPassingProbe_allCh_1D")->second->Fill(GEM_region); + m_histos.find("GE11_nPassingProbe_chamber_1D")->second->Fill(GEM_chamber); + if (GEM_region < 0) { + if (GEM_lay == 2) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber); + else if (GEM_lay == 1) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber); + } + if (GEM_region > 0) { + if (GEM_lay == 1) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber); + else if (GEM_lay == 2) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber); + } + if (GEM_region == -1) { + m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber); + } else if (GEM_region == 1) { + m_histos.find("GEM_nPassingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber); + } - if (GEM_region == 1 && GEM_lay == 1 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_chamber_p1_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber); - m_histos.find("GEM_nPassingProbe_pt_p1_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nPassingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nPassingProbe_phi_p1_1D")->second->Fill(GEM_phi); - } else if (GEM_region == 1 && GEM_lay == 2 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_chamber_p2_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber); - m_histos.find("GEM_nPassingProbe_pt_p2_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nPassingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nPassingProbe_phi_p2_1D")->second->Fill(GEM_phi); - } else if (GEM_region == -1 && GEM_lay == 1 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_chamber_n1_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber); - m_histos.find("GEM_nPassingProbe_pt_n1_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nPassingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nPassingProbe_phi_n1_1D")->second->Fill(GEM_phi); - } else if (GEM_region == -1 && GEM_lay == 2 && GEM_sta == 1) { - m_histos.find("GEM_nPassingProbe_chamber_n2_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber); - m_histos.find("GEM_nPassingProbe_pt_n2_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nPassingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nPassingProbe_phi_n2_1D")->second->Fill(GEM_phi); - } - m_histos.find("GEM_nPassingProbe_pt_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nPassingProbe_eta_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nPassingProbe_phi_1D")->second->Fill(GEM_phi); - } else { - if (GEM_region == 1 && GEM_lay == 0 && GEM_sta == 2 && GEM_chamber == 16) - continue; - m_histos.find("GEM_nFailingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_eta")->second->Fill(abs(GEM_eta), GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); - m_histos.find("GEM_nFailingProbe_allCh_1D")->second->Fill(GEM_region); - m_histos.find("GEM_nFailingProbe_chamber_1D")->second->Fill(GEM_chamber); - if (GEM_region < 0) { - if (GEM_sta == 2 and GEM_lay == 2) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 1) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 2) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 1) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber); - } - if (GEM_region > 0) { - if (GEM_sta == 1 and GEM_lay == 1) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber); - else if (GEM_sta == 1 and GEM_lay == 2) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 1) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber); - else if (GEM_sta == 2 and GEM_lay == 2) - m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber); - } - if (GEM_region == -1 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber); - } else if (GEM_region == 1 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber); - } - // - if (GEM_region == 1 && GEM_lay == 1 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_chamber_p1_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber); - m_histos.find("GEM_nFailingProbe_pt_p1_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nFailingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nFailingProbe_phi_p1_1D")->second->Fill(GEM_phi); - } else if (GEM_region == 1 && GEM_lay == 2 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_chamber_p2_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber); - m_histos.find("GEM_nFailingProbe_pt_p2_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nFailingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nFailingProbe_phi_p2_1D")->second->Fill(GEM_phi); - } else if (GEM_region == -1 && GEM_lay == 1 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_chamber_n1_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber); - m_histos.find("GEM_nFailingProbe_pt_n1_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nFailingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nFailingProbe_phi_n1_1D")->second->Fill(GEM_phi); - } else if (GEM_region == -1 && GEM_lay == 2 && GEM_sta == 1) { - m_histos.find("GEM_nFailingProbe_chamber_n2_1D")->second->Fill(GEM_chamber); - m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber); - m_histos.find("GEM_nFailingProbe_pt_n2_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nFailingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nFailingProbe_phi_n2_1D")->second->Fill(GEM_phi); - } - m_histos.find("GEM_nFailingProbe_pt_1D")->second->Fill(GEM_pt); - m_histos.find("GEM_nFailingProbe_eta_1D")->second->Fill(abs(GEM_eta)); - m_histos.find("GEM_nFailingProbe_phi_1D")->second->Fill(GEM_phi); + if (GEM_region == 1 && GEM_lay == 1) { + m_histos.find("GEM_nPassingProbe_chamber_p1_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber); + m_histos.find("GEM_nPassingProbe_pt_p1_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nPassingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nPassingProbe_phi_p1_1D")->second->Fill(GEM_phi); + } else if (GEM_region == 1 && GEM_lay == 2) { + m_histos.find("GEM_nPassingProbe_chamber_p2_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber); + m_histos.find("GEM_nPassingProbe_pt_p2_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nPassingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nPassingProbe_phi_p2_1D")->second->Fill(GEM_phi); + } else if (GEM_region == -1 && GEM_lay == 1) { + m_histos.find("GEM_nPassingProbe_chamber_n1_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber); + m_histos.find("GEM_nPassingProbe_pt_n1_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nPassingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nPassingProbe_phi_n1_1D")->second->Fill(GEM_phi); + } else if (GEM_region == -1 && GEM_lay == 2) { + m_histos.find("GEM_nPassingProbe_chamber_n2_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nPassingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber); + m_histos.find("GEM_nPassingProbe_pt_n2_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nPassingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nPassingProbe_phi_n2_1D")->second->Fill(GEM_phi); + } + m_histos.find("GEM_nPassingProbe_pt_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nPassingProbe_eta_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nPassingProbe_phi_1D")->second->Fill(GEM_phi); + } else { + m_histos.find("GE11_nFailingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); + m_histos.find("GE11_nFailingProbe_Ch_ieta")->second->Fill(GEM_ieta, GEM_chamber); + m_histos.find("GE11_nFailingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); + m_histos.find("GE11_nFailingProbe_allCh_1D")->second->Fill(GEM_region); + m_histos.find("GE11_nFailingProbe_chamber_1D")->second->Fill(GEM_chamber); + if (GEM_region < 0) { + if (GEM_sta == 2 and GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber); + else if (GEM_sta == 2 and GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber); + else if (GEM_sta == 1 and GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(2, GEM_chamber); + else if (GEM_sta == 1 and GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(3, GEM_chamber); + } + if (GEM_region > 0) { + if (GEM_sta == 1 and GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(6, GEM_chamber); + else if (GEM_sta == 1 and GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(7, GEM_chamber); + else if (GEM_sta == 2 and GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber); + else if (GEM_sta == 2 and GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber); + } + if (GEM_region == -1) { + m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(0, GEM_chamber); + } else if (GEM_region == 1) { + m_histos.find("GEM_nFailingProbe_Ch_region_GE1_NoL")->second->Fill(1, GEM_chamber); + } + // + if (GEM_region == 1 && GEM_lay == 1) { + m_histos.find("GEM_nFailingProbe_chamber_p1_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(2, GEM_chamber); + m_histos.find("GEM_nFailingProbe_pt_p1_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nFailingProbe_eta_p1_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nFailingProbe_phi_p1_1D")->second->Fill(GEM_phi); + } else if (GEM_region == 1 && GEM_lay == 2) { + m_histos.find("GEM_nFailingProbe_chamber_p2_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(3, GEM_chamber); + m_histos.find("GEM_nFailingProbe_pt_p2_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nFailingProbe_eta_p2_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nFailingProbe_phi_p2_1D")->second->Fill(GEM_phi); + } else if (GEM_region == -1 && GEM_lay == 1) { + m_histos.find("GEM_nFailingProbe_chamber_n1_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(1, GEM_chamber); + m_histos.find("GEM_nFailingProbe_pt_n1_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nFailingProbe_eta_n1_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nFailingProbe_phi_n1_1D")->second->Fill(GEM_phi); + } else if (GEM_region == -1 && GEM_lay == 2) { + m_histos.find("GEM_nFailingProbe_chamber_n2_1D")->second->Fill(GEM_chamber); + m_histos.find("GEM_nFailingProbe_Ch_region_GE1")->second->Fill(0, GEM_chamber); + m_histos.find("GEM_nFailingProbe_pt_n2_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nFailingProbe_eta_n2_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nFailingProbe_phi_n2_1D")->second->Fill(GEM_phi); + } + m_histos.find("GEM_nFailingProbe_pt_1D")->second->Fill(GEM_pt); + m_histos.find("GEM_nFailingProbe_eta_1D")->second->Fill(abs(GEM_eta)); + m_histos.find("GEM_nFailingProbe_phi_1D")->second->Fill(GEM_phi); + } + } + + //Loop over GE21 matches + unsigned nGE21_matches = probe_coll_GE21_region.at(i).size(); + for (unsigned j = 0; j < nGE21_matches; ++j) { + //GEM variables + int GEM_region = probe_coll_GE21_region.at(i).at(j); + int GEM_lay = probe_coll_GE21_lay.at(i).at(j); + int GEM_chamber = probe_coll_GE21_chamber.at(i).at(j); + float GEM_ieta = probe_coll_GE21_ieta.at(i).at(j); + float GEM_dx = probe_coll_GE21_dx.at(i).at(j); + float GEM_phi = probe_coll_GE21_phi.at(i).at(j); + + //Fill GEM plots + if (GEM_dx < m_dxCut) { + m_histos.find("GE21_nPassingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); + m_histos.find("GE21_nPassingProbe_Ch_ieta")->second->Fill(GEM_ieta, GEM_chamber); + m_histos.find("GE21_nPassingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); + m_histos.find("GE21_nPassingProbe_allCh_1D")->second->Fill(GEM_region); + m_histos.find("GE21_nPassingProbe_chamber_1D")->second->Fill(GEM_chamber); + if (GEM_region < 0) { + if (GEM_lay == 2) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber); + else if (GEM_lay == 1) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber); + } + if (GEM_region > 0) { + if (GEM_lay == 1) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber); + else if (GEM_lay == 2) + m_histos.find("GEM_nPassingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber); + } + } else { + m_histos.find("GE21_nFailingProbe_Ch_region")->second->Fill(GEM_region, GEM_chamber); + m_histos.find("GE21_nFailingProbe_Ch_ieta")->second->Fill(GEM_ieta, GEM_chamber); + m_histos.find("GE21_nFailingProbe_Ch_phi")->second->Fill(GEM_phi, GEM_chamber); + m_histos.find("GE21_nFailingProbe_allCh_1D")->second->Fill(GEM_region); + m_histos.find("GE21_nFailingProbe_chamber_1D")->second->Fill(GEM_chamber); + if (GEM_region < 0) { + if (GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(0, GEM_chamber); + else if (GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(1, GEM_chamber); + } + if (GEM_region > 0) { + if (GEM_lay == 1) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(8, GEM_chamber); + else if (GEM_lay == 2) + m_histos.find("GEM_nFailingProbe_Ch_region_layer_phase2")->second->Fill(9, GEM_chamber); } } } @@ -840,4 +1027,4 @@ void GEMTnPEfficiencyTask::analyze(const edm::Event& event, const edm::EventSetu std::string GEMTnPEfficiencyTask::topFolder() const { return "GEM/Segment_TnP/"; }; -DEFINE_FWK_MODULE(GEMTnPEfficiencyTask); +DEFINE_FWK_MODULE(GEMTnPEfficiencyTask); \ No newline at end of file diff --git a/TrackingTools/TrackAssociator/src/TrackDetectorAssociator.cc b/TrackingTools/TrackAssociator/src/TrackDetectorAssociator.cc index d164292554f15..b31118fbdba1a 100644 --- a/TrackingTools/TrackAssociator/src/TrackDetectorAssociator.cc +++ b/TrackingTools/TrackAssociator/src/TrackDetectorAssociator.cc @@ -39,6 +39,9 @@ #include "DataFormats/CSCRecHit/interface/CSCSegmentCollection.h" #include "DataFormats/GEMRecHit/interface/GEMSegmentCollection.h" #include "DataFormats/GEMRecHit/interface/ME0SegmentCollection.h" +#include "DataFormats/RPCRecHit/interface/RPCRecHitCollection.h" +#include "DataFormats/GEMRecHit/interface/GEMRecHitCollection.h" +#include "DataFormats/GEMRecHit/interface/ME0RecHitCollection.h" // calorimeter and muon infos #include "Geometry/CommonDetUnit/interface/GeomDet.h" @@ -591,7 +594,8 @@ DetIdAssociator::MapRange TrackDetectorAssociator::getMapRange(const std::pair& matches, - const AssociatorParameters& parameters) { + const AssociatorParameters& parameters, + std::set occupancy) { // Strategy: // Propagate through the whole detector, estimate change in eta and phi // along the trajectory, add this to dRMuon and find DetIds around this @@ -621,6 +625,18 @@ void TrackDetectorAssociator::getTAMuonChamberMatches(std::vector muonIdsInRegion = muonDetIdAssociator_->getDetIdsCloseToAPoint(trajectoryPoint.position(), mapRange); LogTrace("TrackAssociator") << "Number of chambers to check: " << muonIdsInRegion.size(); + + if (parameters.preselectMuonTracks) { + std::set muonIdsInRegionOccupied; + std::set_intersection(muonIdsInRegion.begin(), + muonIdsInRegion.end(), + occupancy.begin(), + occupancy.end(), + std::inserter(muonIdsInRegionOccupied, muonIdsInRegionOccupied.begin())); + if (muonIdsInRegionOccupied.empty()) + return; + } + for (std::set::const_iterator detId = muonIdsInRegion.begin(); detId != muonIdsInRegion.end(); detId++) { const GeomDet* geomDet = muonDetIdAssociator_->getGeomDet(*detId); TrajectoryStateOnSurface stateOnSurface = cachedTrajectory_.propagate(&geomDet->surface()); @@ -673,7 +689,7 @@ void TrackDetectorAssociator::getTAMuonChamberMatches(std::vectorwidthAtHalfLength() - wideWidth; float length = bounds->length(); float tangent = (wideWidth - narrowWidth) / (2.f * length); - float halfWidthAtY = tangent * localPoint.y() + 0.5f * narrowWidth; + float halfWidthAtY = tangent * localPoint.y() + 0.25f * (narrowWidth + wideWidth); distanceX = std::abs(localPoint.x()) - halfWidthAtY; distanceY = std::abs(localPoint.y()) - 0.5f * length; @@ -723,6 +739,55 @@ void TrackDetectorAssociator::fillMuon(const edm::Event& iEvent, if (parameters.useME0) iEvent.getByToken(parameters.me0SegmentsToken, me0Segments); + // Get the hits from the event only if track preselection is activated + // Get the chambers segments/hits in the events + std::set occupancy_set; + if (parameters.preselectMuonTracks) { + edm::Handle rpcRecHits; + iEvent.getByToken(parameters.rpcHitsToken, rpcRecHits); + if (!rpcRecHits.isValid()) + throw cms::Exception("FatalError") << "Unable to find RPCRecHitCollection in event!\n"; + + edm::Handle gemRecHits; + if (parameters.useGEM) + iEvent.getByToken(parameters.gemHitsToken, gemRecHits); + + edm::Handle me0RecHits; + if (parameters.useME0) + iEvent.getByToken(parameters.me0HitsToken, me0RecHits); + + for (const auto& dtSegment : *dtSegments) { + occupancy_set.insert(dtSegment.geographicalId()); + } + for (const auto& cscSegment : *cscSegments) { + occupancy_set.insert(cscSegment.geographicalId()); + } + for (const auto& rpcRecHit : *rpcRecHits) { + occupancy_set.insert(rpcRecHit.geographicalId()); + } + if (parameters.useGEM) { + for (const auto& gemSegment : *gemSegments) { + occupancy_set.insert(gemSegment.geographicalId()); + } + for (const auto& gemRecHit : *gemRecHits) { + occupancy_set.insert(gemRecHit.geographicalId()); + } + } + if (parameters.useME0) { + for (const auto& me0Segment : *me0Segments) { + occupancy_set.insert(me0Segment.geographicalId()); + } + for (const auto& me0RecHit : *me0RecHits) { + occupancy_set.insert(me0RecHit.geographicalId()); + } + } + if (occupancy_set.empty()) { + LogTrace("TrackAssociator") << "No segments or hits were found in the event: aborting track extrapolation" + << std::endl; + return; + } + } + ///// get a set of DetId's in a given direction // check the map of available segments @@ -736,7 +801,7 @@ void TrackDetectorAssociator::fillMuon(const edm::Event& iEvent, // get a set of matches corresponding to muon chambers std::vector matchedChambers; LogTrace("TrackAssociator") << "Trying to Get ChamberMatches" << std::endl; - getTAMuonChamberMatches(matchedChambers, parameters); + getTAMuonChamberMatches(matchedChambers, parameters, occupancy_set); LogTrace("TrackAssociator") << "Chambers matched: " << matchedChambers.size() << "\n"; // Iterate over all chamber matches and fill segment matching