283 self.
logger.info(
' |- Booking all histograms')
286 for p
in (
'1P',
'3P'):
290 for p
in (
'0P',
'1P',
'MP'):
298 for p
in (
'1P',
'3P'):
313 self.
logger.info(
' |- Booking all histograms')
314 path = f
'{self.base_path}/OnlineOnlyVars'
316 for p
in (
'0P',
'1P',
'MP'):
332 self.
logger.info(
' |- Booking all histograms')
333 path = f
'{self.base_path}/OfflineGNTau'
336 for p
in (
'1P',
'3P'):
340 for p
in (
'0P',
'1P',
'MP'):
348 for p
in (
'1P',
'3P'):
488 mon_group_name = f
'{trigger}_HLT_Efficiency_{n_prong}'
489 mon_group_path = f
'{base_path}/HLT_Efficiency/{trigger}/HLT_Efficiency_{n_prong}'
490 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
492 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, eff='HLT', high_pt=False, coarse=False):
493 pass_flag = f
'{eff}_pass'
497 pass_flag +=
'_highPt'
499 xlabel +=
' (p_{T} > p_{T}^{thr} + 20 GeV)'
500 elif coarse: sfx =
'_coarse'
502 mon_group.defineHistogram(f
'{pass_flag},{xvariable};Eff{eff}_{xvariable}{sfx}_wrt_Offline',
503 title=f
'{eff} Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
504 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
510 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', 60, 0.0, 300., eff)
511 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], eff, coarse=
True)
512 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, eff)
513 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, eff)
514 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, eff, high_pt=
True)
515 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, eff, high_pt=
True)
516 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80, eff)
519 mon_group.defineTree(
'tauPt,tauEta,tauPhi,averageMu,HLT_pass;HLTEffTree',
520 treedef=
'tauPt/F:tauEta/F:tauPhi/F:averageMu/F:HLT_pass/I')
524 type_str =
'HLT' if online
else 'Offline'
525 mon_group_name = f
'{trigger}_ID_{type_str}_InputScalar_{n_prong}'
526 mon_group_path = f
'{base_path}/TauIDVars/InputScalar_{n_prong}/{trigger}/{type_str}'
527 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
529 mon_group.defineHistogram(
'centFrac', title=f
'Centrality Fraction ({n_prong}); centFrac; Events', xbins=50, xmin=-0.05, xmax=1.2, opt=
'kAlwaysCreate')
530 mon_group.defineHistogram(
'etOverPtLeadTrk', title=f
'etOverPtLeadTrk log ({n_prong}); etOverPtLeadTrk_log; Events', xbins=60, xmin=-3, xmax=3, opt=
'kAlwaysCreate')
531 mon_group.defineHistogram(
'dRmax', title=f
'max dR of associated tracks ({n_prong}); dRmax; Events', xbins=50, xmin=-0.1, xmax=0.3, opt=
'kAlwaysCreate')
532 mon_group.defineHistogram(
'absipSigLeadTrk', title=f
'AbsIpSigLeadTrk ({n_prong}); absipSigLeadTrk; Events', xbins=25, xmin=0.0, xmax=20.0, opt=
'kAlwaysCreate')
533 mon_group.defineHistogram(
'sumPtTrkFrac', title=f
'SumPtTrkFrac ({n_prong}); SumPtTrkFrac; Events', xbins=50, xmin=-0.5, xmax=1.1, opt=
'kAlwaysCreate')
534 mon_group.defineHistogram(
'emPOverTrkSysP', title=f
'EMPOverTrkSysP log ({n_prong}); EMPOverTrkSysP_log; Events', xbins=50, xmin=-5, xmax=3, opt=
'kAlwaysCreate')
535 mon_group.defineHistogram(
'ptRatioEflowApprox', title=f
'ptRatioEflowApprox ({n_prong}); ptRatioEflowApprox; Events', xbins=50, xmin=0.0, xmax=2.0, opt=
'kAlwaysCreate')
536 mon_group.defineHistogram(
'mEflowApprox', title=f
'mEflowApprox log ({n_prong}); mEflowApprox_log; Events', xbins=50, xmin=0, xmax=5, opt=
'kAlwaysCreate')
537 mon_group.defineHistogram(
'ptDetectorAxis', title=f
'ptDetectorAxis log ({n_prong}); ptDetectorAxis_log; Events', xbins=50, xmin=0, xmax=5, opt=
'kAlwaysCreate')
538 if n_prong ==
'MP' or n_prong ==
'3P':
539 mon_group.defineHistogram(
'massTrkSys', title=f
'massTrkSys log ({n_prong}); massTrkSys_log; Events', xbins=50, xmin=0, xmax=3, opt=
'kAlwaysCreate')
540 mon_group.defineHistogram(
'trFlightPathSig', title=f
'trFlightPathSig ({n_prong}); trFlightPathSig; Events', xbins=100, xmin=-20, xmax=40, opt=
'kAlwaysCreate')
544 type_str =
'HLT' if online
else 'Offline'
545 mon_group_name = f
'{trigger}_ID_{type_str}_InputTrack'
546 mon_group_path = f
'{base_path}/TauIDVars/InputTrack/{trigger}/{type_str}'
547 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
549 mon_group.defineHistogram(
'n_track', title=
'Number of tracks; N_{track}; Events', xbins=15, xmin=0, xmax=15, opt=
'kAlwaysCreate')
550 mon_group.defineHistogram(
'track_pt_log', title=
'track_pt_log; track_pt_log; Events', xbins=20, xmin=2, xmax=7, opt=
'kAlwaysCreate')
551 mon_group.defineHistogram(
'track_pt_jetseed_log', title=
'track_pt_jetseed_log; track_pt_jetseed_log; Events', xbins=50, xmin=2, xmax=7, opt=
'kAlwaysCreate')
552 mon_group.defineHistogram(
'track_eta', title=
'Track #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
553 mon_group.defineHistogram(
'track_phi', title=
'Track #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
554 mon_group.defineHistogram(
'track_dEta', title=
'Track #Delta#eta; #Delta#eta; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
555 mon_group.defineHistogram(
'track_dPhi', title=
'Track #Delta#phi; #Delta#phi; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
556 mon_group.defineHistogram(
'track_d0_abs_log', title=
'track_d0_abs_log; track_d0_abs_log; Events', xbins=50, xmin=-7, xmax=2, opt=
'kAlwaysCreate')
557 mon_group.defineHistogram(
'track_z0sinthetaTJVA_abs_log', title=
'track_z0sinthetaTJVA_abs_log; track_z0sinthetaTJVA_abs_log; Events', xbins=50, xmin=-10, xmax=4, opt=
'kAlwaysCreate')
558 mon_group.defineHistogram(
'track_nIBLHitsAndExp', title=
'track_nIBLHitsAndExp; track_nIBLHitsAndExp; Events', xbins=3, xmin=0, xmax=3, opt=
'kAlwaysCreate')
559 mon_group.defineHistogram(
'track_nPixelHitsPlusDeadSensors', title=
'track_nPixelHitsPlusDeadSensors; track_nPixelHitsPlusDeadSensors; Events', xbins=11, xmin=0, xmax=11, opt=
'kAlwaysCreate')
560 mon_group.defineHistogram(
'track_nSCTHitsPlusDeadSensors', title=
'track_nSCTHitsPlusDeadSensors; track_nSCTHitsPlusDeadSensors; Events', xbins=20, xmin=0, xmax=20, opt=
'kAlwaysCreate')
561 mon_group.defineHistogram(
'track_eta,track_phi', type=
'TH2F', title=
'Track #eta vs #phi; #eta; #phi', xbins=26, xmin=-2.6, xmax=2.6, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
562 mon_group.defineHistogram(
'track_dEta,track_dPhi', type=
'TH2F', title=
'Track #Delta#eta vs #Delta#phi; #Delta#eta; #Delta#phi', xbins=100, xmin=-0.5, xmax=0.5, ybins=100, ymin=-0.5, ymax=0.5, opt=
'kAlwaysCreate')
566 type_str =
'HLT' if online
else 'Offline'
567 mon_group_name = f
'{trigger}_ID_{type_str}_InputCluster'
568 mon_group_path = f
'{base_path}/TauIDVars/InputCluster/{trigger}/{type_str}'
569 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
571 mon_group.defineHistogram(
'n_cluster', title=
'Number of clusters; N_{cluster}; Events', xbins=30, xmin=0, xmax=30, opt=
'kAlwaysCreate')
572 mon_group.defineHistogram(
'cluster_et_log', title=
'cluster_et_log; cluster_et_log; Events', xbins=30, xmin=0, xmax=6, opt=
'kAlwaysCreate')
573 mon_group.defineHistogram(
'cluster_pt_jetseed_log', title=
'cluster_pt_jetseed_log; cluster_pt_jetseed_log; Events', xbins=50, xmin=2, xmax=7, opt=
'kAlwaysCreate')
574 mon_group.defineHistogram(
'cluster_eta', title=
'Cluster #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
575 mon_group.defineHistogram(
'cluster_phi', title=
'Cluster #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
576 mon_group.defineHistogram(
'cluster_dEta', title=
'Cluster #Delta#eta; #Delta#eta; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
577 mon_group.defineHistogram(
'cluster_dPhi', title=
'Cluster #Delta#phi; #Delta#phi; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
578 mon_group.defineHistogram(
'cluster_SECOND_R_log10', title=
'cluster_SECOND_R_log10; cluster_SECOND_R_log10; Events', xbins=50, xmin=-3, xmax=7, opt=
'kAlwaysCreate')
579 mon_group.defineHistogram(
'cluster_SECOND_LAMBDA_log10', title=
'cluster_SECOND_LAMBDA_log10; cluster_SECOND_LAMBDA_log10; Events', xbins=50, xmin=-3, xmax=7, opt=
'kAlwaysCreate')
580 mon_group.defineHistogram(
'cluster_CENTER_LAMBDA_log10', title=
'cluster_CENTER_LAMBDA_log10; cluster_CENTER_LAMBDA_log10; Events', xbins=50, xmin=-2, xmax=5, opt=
'kAlwaysCreate')
581 mon_group.defineHistogram(
'cluster_eta,cluster_phi', type=
'TH2F', title=
'Cluster #eta vs #phi; #eta; #phi', xbins=26, xmin=-2.6, xmax=2.6, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
582 mon_group.defineHistogram(
'cluster_dEta,cluster_dPhi', type=
'TH2F', title=
'Cluster #Delta#eta vs #Delta#phi; #Delta#eta; #Delta#phi', xbins=100, xmin=-0.5, xmax=0.5, ybins=100, ymin=-0.5, ymax=0.5, opt=
'kAlwaysCreate')
613 type_str =
'HLT' if online
else 'Offline'
614 mon_group_name = f
'{trigger}_{type_str}_basicVars_{n_prong}'
615 mon_group_path = f
'{base_path}/basicVars/{trigger}/{type_str}_{n_prong}'
616 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
620 mon_group.defineHistogram(
'Pt', title=f
'{type_str} p_{{T}}; p_{{T}} [GeV]; Events', xbins=binning, opt=
'kAlwaysCreate')
621 mon_group.defineHistogram(
'Eta', title=f
'{type_str} #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
622 mon_group.defineHistogram(
'Phi', title=f
'{type_str} #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
623 mon_group.defineHistogram(
'nTrack', title=f
'{type_str} Number of tracks; N_{{track}}; Events', xbins=10, xmin=0, xmax=10, opt=
'kAlwaysCreate')
624 mon_group.defineHistogram(
'Eta,Phi', type=
'TH2F', title=f
'{type_str} #eta vs #phi; #eta; #phi', xbins=26, xmin=-2.6, xmax=2.6, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
625 mon_group.defineHistogram(
'Pt,Phi', type=
'TH2F', title=f
'{type_str} p_{{T}} vs #phi; p_{{T}} [GeV]; #phi', xbins=binning, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
626 mon_group.defineHistogram(
'Pt,Eta', type=
'TH2F', title=f
'{type_str} p_{{T}} vs #eta; p_{{T}} [GeV]; #eta', xbins=binning, ybins=26, ymin=-2.6, ymax=2.6, opt=
'kAlwaysCreate')
627 mon_group.defineHistogram(
'nIsoTrack', title=f
'{type_str} Number of isolation tracks; N_{{track}}^{{iso}}; Events', xbins=10, xmin=0, xmax=10, opt=
'kAlwaysCreate')
628 mon_group.defineHistogram(
'averageMu', title=f
'{type_str} Average #mu; #LT#mu$GT; Events', xbins=20, xmin=0, xmax=80, opt=
'kAlwaysCreate')
629 mon_group.defineHistogram(
'TauVertexX', title=f
'{type_str} Tau Vertex X; x [mm]; Events', xbins=100, xmin=-1, xmax=1, opt=
'kAlwaysCreate')
630 mon_group.defineHistogram(
'TauVertexY', title=f
'{type_str} Tau Vertex Y; y [mm]; Events', xbins=100, xmin=-2, xmax=0, opt=
'kAlwaysCreate')
631 mon_group.defineHistogram(
'TauVertexZ', title=f
'{type_str} Tau Vertex Z; z [mm]; Events', xbins=120, xmin=-120, xmax=120, opt=
'kAlwaysCreate')
635 mon_group_name = f
'{trigger}_DiTauHLT_Efficiency'
636 mon_group_path = f
'{base_path}/DiTauHLT_Efficiency/{trigger}/DiTauHLT_Efficiency'
637 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
639 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, eff='HLT', high_pt=False):
640 pass_flag = f
'{eff}_pass'
644 pass_flag +=
'_highPt'
646 xlabel +=
' (p_{T}^{1,2} > p_{T}^{thr 1,2} + 20 GeV)'
648 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffDiTau{eff}_{xvariable}{sfx}_wrt_Offline',
649 title=f
'DiTau {eff} Efficiency {trigger};{xlabel};Efficiency',
650 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
654 defineEachStepHistograms(
'dR',
'#Delta R(#tau,#tau)', 20, 0, 4, eff)
655 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,#tau)', 20, 0, 4, eff)
656 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,#tau)', 8, -3.2, 3.2, eff)
658 defineEachStepHistograms(
'dR',
'#Delta R(#tau,#tau)', 20, 0, 4, eff, high_pt=
True)
659 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,#tau)', 20, 0, 4, eff, high_pt=
True)
660 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,#tau)', 8, -3.2, 3.2, eff, high_pt=
True)
661 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80, eff)
664 mon_group.defineTree(
'dR,dEta,dPhi,averageMu,HLT_pass;DiTauHLTEffTree',
665 treedef=
'dR/F:dEta/F:dPhi/F:averageMu/F:HLT_pass/I')
669 mon_group_name = f
'{trigger}_DiTauVars'
670 mon_group_path = f
'{base_path}/DiTauVars/{trigger}'
671 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
673 mon_group.defineHistogram(
'leadHLTEt,subleadHLTEt', type=
'TH2F', title=
'p_{T}^{lead} vs p_{T}^{sublead}; p_{T}^{lead} [GeV]; p_{T}^{sublead} [GeV]',
674 xbins=50, xmin=0, xmax=250, ybins=50, ymin=0, ymax=250, opt=
'kAlwaysCreate')
675 mon_group.defineHistogram(
'leadHLTEta,subleadHLTEta', type=
'TH2F', title=
'#eta_{lead} vs #eta_{sublead}; #eta_{lead}; #eta_{sublead}',
676 xbins=26, xmin=-2.6, xmax=2.6, ybins=26, ymin=-2.6, ymax=2.6, opt=
'kAlwaysCreate')
677 mon_group.defineHistogram(
'leadHLTPhi,subleadHLTPhi', type=
'TH2F', title=
'#phi_{lead} vs #phi_{sublead}; #phi_{lead}; #phi_{sublead}',
678 xbins=16, xmin=-3.2, xmax=3.2, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
679 mon_group.defineHistogram(
'dR', title=
'#Delta R(#tau,#tau); #Delta R(#tau,#tau); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
680 mon_group.defineHistogram(
'dEta', title=
'#Delta#eta(#tau,#tau); #Delta#eta(#tau,#tau); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
681 mon_group.defineHistogram(
'dPhi', title=
'#Delta#phi(#tau,#tau); #Delta#phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
683 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,#tau); p_{T} [GeV]; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
684 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,#tau); #eta(#tau,#tau); Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
685 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,#tau); #phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
686 mon_group.defineHistogram(
'M', title=
'm(#tau,#tau); m_{#tau,#tau}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
687 mon_group.defineHistogram(
'dPt', title=
'#Delta p_{T}(#tau, #tau); p_{T} [GeV]; Events', xbins=20, xmin=0, xmax=200, opt=
'kAlwaysCreate')
689 mon_group.defineTree(
'leadHLTEt,subleadHLTEt,leadHLTEta,subleadHLTEta,leadHLTPhi,subleadHLTPhi,dR,dEta,dPhi,Pt,Eta,Phi,M,dPt;DiTauVarsTree',
690 treedef=
'leadHLTEt/F:subleadHLTEt/F:leadHLTEta/F:subleadHLTEta/F:leadHLTPhi/F:subleadHLTPhi/F:dR/F:dEta/F:dPhi/F:Pt/F:Eta/F:Phi/F:M/F:dPt/F')
699 mon_group_name = f
'{trigger}_BoostedDiTauVars'
700 mon_group_path = f
'{base_path}/BoostedDiTauVars/{trigger}'
701 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
703 mon_group.defineHistogram(
'omni_score', title=
'omni_score; omni_score; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
704 mon_group.defineHistogram(
'R_tracks_lead', title=
'R_tracks_lead; R_tracks_lead; Events', xbins=50, xmin=0, xmax=0.2, opt=
'kAlwaysCreate')
705 mon_group.defineHistogram(
'R_tracks_subl', title=
'R_tracks_subl; R_tracks_subl; Events', xbins=50, xmin=0, xmax=0.2, opt=
'kAlwaysCreate')
706 mon_group.defineHistogram(
'f_core_lead', title=
'f_core_lead; f_core_lead; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
707 mon_group.defineHistogram(
'f_core_subl', title=
'f_core_subl; f_core_subl; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
708 mon_group.defineHistogram(
'n_track', title=
'Number of tracks; n_tracks; Events', xbins=51, xmin=-0.5, xmax=50.5, opt=
'kAlwaysCreate')
709 mon_group.defineHistogram(
'n_tracks_lead', title=
'Number of Lead tracks; n_tracks_lead; Events', xbins=11, xmin=-0.5, xmax=10.5, opt=
'kAlwaysCreate')
710 mon_group.defineHistogram(
'n_tracks_subl', title=
'Number of Sub-Lead tracks; n_tracks_subl; Events', xbins=11, xmin=-0.5, xmax=10.5, opt=
'kAlwaysCreate')
711 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,#tau); p_{T} [GeV]; Events', xbins=50, xmin=160, xmax=1300, opt=
'kAlwaysCreate')
712 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,#tau); #eta(#tau,#tau); Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
713 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,#tau); #phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
714 mon_group.defineHistogram(
'M', title=
'm(#tau,#tau); m_{#tau,#tau}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
717 mon_group_name = f
'{trigger}_TAndPHLT_Efficiency'
718 mon_group_path = f
'{base_path}/TAndPHLT_Efficiency/{trigger}/TAndPHLT_Efficiency'
719 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
721 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
722 pass_flag =
'HLT_pass'
726 pass_flag +=
'_highPt'
728 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
732 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffTAndPHLT_{xvariable}{sfx}_wrt_Offline',
733 title=f
'TAndP HLT Efficiency {trigger}; {xlabel}; Efficiency',
734 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
738 defineEachStepHistograms(
'tauPt',
'p_{T}^{#tau} [GeV]', 60, 0.0, 300)
739 defineEachStepHistograms(
'tauPt',
'p_{T}^{#tau} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
740 defineEachStepHistograms(
'tauEta',
'#eta_{#tau}', 13, -2.6, 2.6)
741 defineEachStepHistograms(
'tauPhi',
'#phi_{#tau}', 16, -3.2, 3.2)
742 defineEachStepHistograms(
'tauEta',
'#eta_{#tau}', 13, -2.6, 2.6, high_pt=
True)
743 defineEachStepHistograms(
'tauPhi',
'#phi_{#tau}', 16, -3.2, 3.2, high_pt=
True)
744 defineEachStepHistograms(
'dR',
'#Delta R(#tau,lep)', 20, 0, 4)
745 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,lep)', 20, 0,4)
746 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,lep)', 8, -3.2, 3.2)
747 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80)
750 mon_group.defineTree(
'tauPt,tauEta,tauPhi,dR,dEta,dPhi,averageMu,HLT_pass;TAndPHLTEffTree',
751 treedef=
'tauPt/F:tauEta/F:tauPhi/F:dR/F:dEta/F:dPhi/F:averageMu/F:HLT_pass/I')
755 mon_group_name = f
'{trigger}_TAndPVars'
756 mon_group_path = f
'{base_path}/TAndPVars/{trigger}'
757 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
759 mon_group.defineHistogram(
'dR', title=
'#Delta R(#tau,lep); #Delta R(#tau,lep); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
760 mon_group.defineHistogram(
'dEta', title=
'#Delta#eta(#tau,lep); #Delta#eta(#tau,lep); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
761 mon_group.defineHistogram(
'dPhi', title=
'#Delta#phi(#tau,lep); #Delta#phi(#tau,lep); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
763 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,lep); p_{T} [GeV]; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
764 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,lep); #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
765 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,lep); #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
766 mon_group.defineHistogram(
'M', title=
'm(#tau,lep); m_{#tau,lep}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
767 mon_group.defineHistogram(
'dPt', title=
'#Delta p_{T}(#tau,lep); p_{T} [GeV]; Events', xbins=20, xmin=0, xmax=200, opt=
'kAlwaysCreate')
771 mon_group_name = f
'{trigger}_Truth_Efficiency_{n_prong}'
772 mon_group_path = f
'{base_path}/Truth_Efficiency/{trigger}/Truth_Efficiency_{n_prong}'
773 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
777 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
778 pass_flag =
'HLT_pass'
782 pass_flag +=
'_highPt'
784 if info.isHLTDiTau():
785 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau min thr} + 20 GeV)'
787 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
791 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffHLT_{xvariable}{sfx}_wrt_Truth',
792 title=f
'HLT Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
793 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax)
797 defineEachStepHistograms(
'pt_vis',
'p_{T, vis} [GeV]', 60, 0.0, 300)
798 if info.isHLTSingleTau()
or info.isHLTTandP(): defineEachStepHistograms(
'pt_vis',
'p_{T, vis} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
799 defineEachStepHistograms(
'eta_vis',
'#eta_{vis}', 13, -2.6, 2.6)
800 defineEachStepHistograms(
'phi_vis',
'#phi_{vis}', 16, -3.2, 3.2)
801 defineEachStepHistograms(
'eta_vis',
'#eta_{vis}', 13, -2.6, 2.6, high_pt=
True)
802 defineEachStepHistograms(
'phi_vis',
'#phi_{vis}', 16, -3.2, 3.2, high_pt=
True)
806 mon_group_name = f
'{trigger}_TruthVars_{n_prong}'
807 mon_group_path = f
'{base_path}/TruthVars/{trigger}/TruthVars_{n_prong}'
808 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
810 mon_group.defineHistogram(
'pt_vis,PtRatio', title=
'p_{T} ratio vs p_{T, vis}; p_{T, vis} [GeV]; (p_{T}^{reco} - p_{T, vis}^{truth})/p_{T, vis}^{truth}', type=
'TProfile', xbins=21, xmin=20, xmax=250)
811 mon_group.defineHistogram(
'eta_vis,PtRatio', title=
'p_{T} ratio vs #eta_{vis}; #eta_{vis}; (p_{T}^{reco} - p_{T, vis}^{truth})/p_{T, vis}^{truth}', type=
'TProfile', xbins=21, xmin=-3, xmax=3)
812 mon_group.defineHistogram(
'phi_vis,PtRatio', title=
'p_{T} ratio vs #phi_{vis}; #phi_{vis}; (p_{T}^{reco} - p_{T, vis}^{truth})/p_{T, vis}^{truth}', type=
'TProfile', xbins=21, xmin=-3, xmax=3)
814 mon_group.defineHistogram(
'pt_vis', title=
'p_{T, vis}; p_{T, vis}; Events', xbins=50, xmin=0, xmax=250)
815 mon_group.defineHistogram(
'eta_vis', title=
'#eta_{vis}; #eta_{vis}; Events', xbins=26, xmin=-2.6, xmax=2.6)
816 mon_group.defineHistogram(
'phi_vis', title=
'#phi_{vis}; #phi_{vis}; Events', xbins=16, xmin=-3.2, xmax=3.2)
820 mon_group_name = f
'{trigger}_L1_Efficiency_{n_prong}'
821 mon_group_path = f
'{base_path}/L1_Efficiency/{trigger}/L1_Efficiency_{n_prong}'
822 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
824 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
825 pass_flag =
'L1_pass'
829 pass_flag +=
'_highPt'
831 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
835 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffL1_{xvariable}{sfx}_wrt_Offline',
836 title=f
'L1 Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
837 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
841 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', 60, 0, 300)
842 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
843 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6)
844 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2)
845 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, high_pt=
True)
846 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, high_pt=
True)
847 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80)
851 mon_group_name = f
'{trigger}_L1Vars'
852 mon_group_path = f
'{base_path}/L1Vars/{trigger}'
853 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
855 mon_group.defineHistogram(
'L1RoIEt,L1RoIEta', type=
'TH2F', title=
'L1 RoI E_{T} vs #eta; E_{T} [GeV]; #eta',
856 xbins=60, xmin=0, xmax=300,
857 ybins=60, ymin=-2.6, ymax=2.6, opt=
'kAlwaysCreate')
858 mon_group.defineHistogram(
'L1RoIEt,L1RoIPhi', type=
'TH2F', title=
'L1 RoI E_{T} vs #phi; E_{T} [GeV]; #phi',
859 xbins=60, xmin=0, xmax=300,
860 ybins=60, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
861 mon_group.defineHistogram(
'L1RoIEta,L1RoIPhi', type=
'TH2F', title=
'L1 RoI #eta vs #phi; #eta; #phi',
862 xbins=60, xmin=-2.6, xmax=2.6,
863 ybins=60, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
864 mon_group.defineHistogram(
'L1RoIEta', title=
'L1 RoI #eta; #eta; RoIs', xbins=60, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
865 mon_group.defineHistogram(
'L1RoIPhi', title=
'L1 RoI #phi; #phi; RoIs', xbins=60, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
866 mon_group.defineHistogram(
'L1RoIEt', title=
'L1 RoI E_{T}; E_{T} [GeV]; RoIs', xbins=60, xmin=0, xmax=300, opt=
'kAlwaysCreate')
868 if 'eTAU' in trigger:
869 mon_group.defineHistogram(
'L1eFexRoIRCore', title=
'L1 eTAU RoI rCore Isolation; rCore Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
870 mon_group.defineHistogram(
'L1eFexRoIRHad' , title=
'L1 eTAU RoI rHad Isolation; rHad Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
871 mon_group.defineHistogram(
'L1eFexRoIBDTScore' , title=
'L1 eTAU RoI BDT score; BDT Score; RoIs', xbins=128, xmin=512, xmax=1024, opt=
'kAlwaysCreate')
873 elif 'cTAU' in trigger:
874 mon_group.defineHistogram(
'L1eFexRoIRCore', title=
'L1 eTAU RoI rCore Isolation; eTAU rCore Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
875 mon_group.defineHistogram(
'L1eFexRoIRHad', title=
'L1 eTAU RoI rHad Isolation; eTAU rHad Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
876 mon_group.defineHistogram(
'L1cTauRoITopoMatch', title=
'L1Topo match between eTAU and jTAU RoI; Match; RoIs', xbins=2, xmin=0, xmax=2, opt=
'kAlwaysCreate')
877 mon_group.defineHistogram(
'L1jFexRoIIso', title=
'L1 jTAU RoI Isolation; E_{T}^{jTAU Iso} [GeV]; RoIs', xbins=25, xmin=0, xmax=50, opt=
'kAlwaysCreate')
878 mon_group.defineHistogram(
'L1cTauMatchedRoIIso', title=
'L1 cTAU Isolation score; E_{T}^{jTAU Iso}/E_{T}^{eTAU}; RoIs', xbins=50, xmin=0, xmax=5, opt=
'kAlwaysCreate')
879 mon_group.defineHistogram(
'L1RoIcTauMatchedEtRatio', title=
'Et ratio between matched eTAU and jTAU RoIs; E_{T}^{jTAU}/E_{T}^{eTAU}; RoIs', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
880 mon_group.defineHistogram(
'L1eFexRoIBDTScore' , title=
'L1 eTAU RoI BDT score; BDT Score; RoIs', xbins=128, xmin=512, xmax=1024, opt=
'kAlwaysCreate')
882 elif 'jTAU' in trigger:
883 mon_group.defineHistogram(
'L1jFexRoIIso', title=
'L1 jTAU RoI Isolation; jTAU Isolation [GeV]; N RoI', xbins=25, xmin=0, xmax=50, opt=
'kAlwaysCreate')
888 def getList(ranges, others=[250]):
889 ret =
set(others + [500])
890 for jump, interval
in ranges.items():
891 ret.update(range(interval[0], interval[1], jump), interval)
892 return sorted(list(ret))
894 if info.isL1TauOnly():
895 thr = info.getL1TauThreshold()
897 if thr <= 8:
return getList({5:(0, 30), 50:(50, 150)})
898 elif thr <= 12:
return getList({5:(0, 30), 50:(50, 150)})
899 elif thr <= 20:
return getList({5:(5, 40), 10:(40, 70), 50:(100, 150)})
900 elif thr <= 30:
return getList({5:(15, 50), 10:(50, 70), 50:(100, 150)})
901 elif thr <= 35:
return getList({5:(20, 55), 10:(60, 80), 50:(100, 150)})
902 elif thr <= 40:
return getList({5:(25, 60), 10:(60, 80), 50:(100, 150)})
903 elif thr <= 60:
return getList({5:(45, 80), 10:(80, 100), 50:(100, 150)})
904 elif thr <= 100:
return getList({5:(85, 120), 10:(120, 140), 20:(140, 180), 50:(200, 250)})
905 else:
return getList({50:(0, 200)})
908 thr = info.getHLTTauThreshold()
911 if thr == 0:
return getList({5:(0, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
912 elif thr <= 20:
return getList({5:(15, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
913 elif thr <= 25:
return getList({5:(20, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
914 elif thr <= 30:
return getList({5:(25, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
915 elif thr <= 35:
return getList({5:(30, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
916 elif thr <= 60:
return getList({5:(55, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
917 elif thr <= 80:
return getList({5:(75, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
918 elif thr <= 160:
return getList({5:(155, 160), 40:(160, 240), 60:(240, 420)}, [])
919 elif thr <= 180:
return getList({5:(175, 180), 40:(180, 260), 60:(260, 380)}, [])
920 else:
return getList({5:(195, 200), 40:(200, 240), 60:(240, 420)}, [])
925 else:
return getList({5:(0, 30), 50:(50, 150)})
926 elif thr <= 20:
return getList({5:(10, 40), 10:(40, 60), 20:(60, 80)}, [150, 250])
927 elif thr <= 25:
return getList({5:(15, 40), 10:(40, 60), 20:(60, 80)}, [150, 250])
928 elif thr <= 30:
return getList({5:(20, 50), 10:(50, 60), 20:(60, 80)}, [150, 250])
929 elif thr <= 35:
return getList({5:(25, 50), 10:(50, 60), 20:(60, 80)}, [150, 250])
930 elif thr <= 60:
return getList({5:(50, 70), 10:(70, 80)}, [110, 150, 250])
931 elif thr <= 80:
return getList({5:(70, 90)}, [110, 150, 250])
932 elif thr <= 160:
return getList({5:(150, 170), 10:(170, 180), 20:(180, 200)}, [240, 300])
933 elif thr <= 180:
return getList({5:(170, 180), 10:(180, 200)}, [240, 300])
934 else:
return getList({5:(190, 200), 10:(200, 210)}, [240, 300])