297 self.
logger.info(
' |- Booking all histograms')
300 for p
in (
'1P',
'3P'):
304 for p
in (
'0P',
'1P',
'MP'):
313 for p
in (
'1P',
'3P'):
330 self.
logger.info(
' |- Booking all histograms')
331 path = f
'{self.base_path}/OnlineOnlyVars'
333 for p
in (
'0P',
'1P',
'MP'):
352 self.
logger.info(
' |- Booking all histograms')
353 path = f
'{self.base_path}/OfflineGNTau'
356 for p
in (
'1P',
'3P'):
360 for p
in (
'0P',
'1P',
'MP'):
369 for p
in (
'1P',
'3P'):
509 mon_group_name = f
'{trigger}_HLT_Efficiency_{n_prong}'
510 mon_group_path = f
'{base_path}/HLT_Efficiency/{trigger}/HLT_Efficiency_{n_prong}'
511 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
513 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, eff='HLT', high_pt=False, coarse=False):
514 pass_flag = f
'{eff}_pass'
518 pass_flag +=
'_highPt'
520 xlabel +=
' (p_{T} > p_{T}^{thr} + 20 GeV)'
521 elif coarse: sfx =
'_coarse'
523 mon_group.defineHistogram(f
'{pass_flag},{xvariable};Eff{eff}_{xvariable}{sfx}_wrt_Offline',
524 title=f
'{eff} Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
525 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
531 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', 60, 0.0, 300., eff)
532 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], eff, coarse=
True)
533 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, eff)
534 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, eff)
535 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, eff, high_pt=
True)
536 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, eff, high_pt=
True)
537 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80, eff)
540 mon_group.defineTree(
'tauPt,tauEta,tauPhi,averageMu,HLT_pass;HLTEffTree',
541 treedef=
'tauPt/F:tauEta/F:tauPhi/F:averageMu/F:HLT_pass/I')
545 type_str =
'HLT' if online
else 'Offline'
546 mon_group_name = f
'{trigger}_ID_{type_str}_InputScalar_{n_prong}'
547 mon_group_path = f
'{base_path}/TauIDVars/InputScalar_{n_prong}/{trigger}/{type_str}'
548 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
550 mon_group.defineHistogram(
'centFrac', title=f
'Centrality Fraction ({n_prong}); centFrac; Events', xbins=50, xmin=-0.05, xmax=1.2, opt=
'kAlwaysCreate')
551 mon_group.defineHistogram(
'etOverPtLeadTrk', title=f
'etOverPtLeadTrk log ({n_prong}); etOverPtLeadTrk_log; Events', xbins=60, xmin=-3, xmax=3, opt=
'kAlwaysCreate')
552 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')
553 mon_group.defineHistogram(
'absipSigLeadTrk', title=f
'AbsIpSigLeadTrk ({n_prong}); absipSigLeadTrk; Events', xbins=25, xmin=0.0, xmax=20.0, opt=
'kAlwaysCreate')
554 mon_group.defineHistogram(
'sumPtTrkFrac', title=f
'SumPtTrkFrac ({n_prong}); SumPtTrkFrac; Events', xbins=50, xmin=-0.5, xmax=1.1, opt=
'kAlwaysCreate')
555 mon_group.defineHistogram(
'emPOverTrkSysP', title=f
'EMPOverTrkSysP log ({n_prong}); EMPOverTrkSysP_log; Events', xbins=50, xmin=-5, xmax=3, opt=
'kAlwaysCreate')
556 mon_group.defineHistogram(
'ptRatioEflowApprox', title=f
'ptRatioEflowApprox ({n_prong}); ptRatioEflowApprox; Events', xbins=50, xmin=0.0, xmax=2.0, opt=
'kAlwaysCreate')
557 mon_group.defineHistogram(
'mEflowApprox', title=f
'mEflowApprox log ({n_prong}); mEflowApprox_log; Events', xbins=50, xmin=0, xmax=5, opt=
'kAlwaysCreate')
558 mon_group.defineHistogram(
'ptDetectorAxis', title=f
'ptDetectorAxis log ({n_prong}); ptDetectorAxis_log; Events', xbins=50, xmin=0, xmax=5, opt=
'kAlwaysCreate')
559 if n_prong ==
'MP' or n_prong ==
'3P':
560 mon_group.defineHistogram(
'massTrkSys', title=f
'massTrkSys log ({n_prong}); massTrkSys_log; Events', xbins=50, xmin=0, xmax=3, opt=
'kAlwaysCreate')
561 mon_group.defineHistogram(
'trFlightPathSig', title=f
'trFlightPathSig ({n_prong}); trFlightPathSig; Events', xbins=100, xmin=-20, xmax=40, opt=
'kAlwaysCreate')
565 type_str =
'HLT' if online
else 'Offline'
566 mon_group_name = f
'{trigger}_ID_{type_str}_InputTrack'
567 mon_group_path = f
'{base_path}/TauIDVars/InputTrack/{trigger}/{type_str}'
568 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
570 mon_group.defineHistogram(
'n_track', title=
'Number of tracks; N_{track}; Events', xbins=15, xmin=0, xmax=15, opt=
'kAlwaysCreate')
571 mon_group.defineHistogram(
'track_pt_log', title=
'track_pt_log; track_pt_log; Events', xbins=20, xmin=2, xmax=7, opt=
'kAlwaysCreate')
572 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')
573 mon_group.defineHistogram(
'track_eta', title=
'Track #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
574 mon_group.defineHistogram(
'track_phi', title=
'Track #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
575 mon_group.defineHistogram(
'track_dEta', title=
'Track #Delta#eta; #Delta#eta; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
576 mon_group.defineHistogram(
'track_dPhi', title=
'Track #Delta#phi; #Delta#phi; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
577 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')
578 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')
579 mon_group.defineHistogram(
'track_nIBLHitsAndExp', title=
'track_nIBLHitsAndExp; track_nIBLHitsAndExp; Events', xbins=3, xmin=0, xmax=3, opt=
'kAlwaysCreate')
580 mon_group.defineHistogram(
'track_nPixelHitsPlusDeadSensors', title=
'track_nPixelHitsPlusDeadSensors; track_nPixelHitsPlusDeadSensors; Events', xbins=11, xmin=0, xmax=11, opt=
'kAlwaysCreate')
581 mon_group.defineHistogram(
'track_nSCTHitsPlusDeadSensors', title=
'track_nSCTHitsPlusDeadSensors; track_nSCTHitsPlusDeadSensors; Events', xbins=20, xmin=0, xmax=20, opt=
'kAlwaysCreate')
582 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')
583 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')
587 type_str =
'HLT' if online
else 'Offline'
588 mon_group_name = f
'{trigger}_ID_{type_str}_InputCluster'
589 mon_group_path = f
'{base_path}/TauIDVars/InputCluster/{trigger}/{type_str}'
590 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
592 mon_group.defineHistogram(
'n_cluster', title=
'Number of clusters; N_{cluster}; Events', xbins=30, xmin=0, xmax=30, opt=
'kAlwaysCreate')
593 mon_group.defineHistogram(
'cluster_et_log', title=
'cluster_et_log; cluster_et_log; Events', xbins=30, xmin=0, xmax=6, opt=
'kAlwaysCreate')
594 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')
595 mon_group.defineHistogram(
'cluster_eta', title=
'Cluster #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
596 mon_group.defineHistogram(
'cluster_phi', title=
'Cluster #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
597 mon_group.defineHistogram(
'cluster_dEta', title=
'Cluster #Delta#eta; #Delta#eta; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
598 mon_group.defineHistogram(
'cluster_dPhi', title=
'Cluster #Delta#phi; #Delta#phi; Events', xbins=100, xmin=-0.5, xmax=0.5, opt=
'kAlwaysCreate')
599 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')
600 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')
601 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')
602 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')
603 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')
612 store_all = info.getHLTTauID()
in [
'idperf',
'perf']
615 for tau_id, p
in self.
hlt_tauid_scores[info.getHLTTauLegContainerSfx()].items()
616 if tau_id == info.getHLTTauID()
or store_all
619 store_all = info.getHLTTauCaloHitsPreselectionID()
in [
'',
'idperfCHP']
623 if tau_id == info.getHLTTauCaloHitsPreselectionID()
or store_all
629 if not variables:
return
631 type_str =
'HLT' if online
else 'Offline'
632 mon_group_name = f
'{trigger}_{type_str}_IDScores_{n_prong}'
633 mon_group_path = f
'{base_path}/basicVars/{trigger}/{type_str}_{n_prong}'
634 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
636 for tau_id, (score, score_sig_trans)
in variables.items():
637 if online
and tau_id
in [
'RNN',
'DeepSet',
'RNNLLP',
'GNTau',
'GNTauDev1']
or not online
and tau_id
in [
'RNN']: xbins, xmax = 20, 1
638 else: xbins, xmax = 100, 7
640 mon_group.defineHistogram(f
'{tau_id}_TauIDScore', title=f
'{type_str} {tau_id} TauID score; TauID score; Events', xbins=xbins, xmin=0, xmax=xmax, opt=
'kAlwaysCreate')
641 mon_group.defineHistogram(f
'{tau_id}_TauIDScoreSigTrans', title=f
'{type_str} {tau_id} TauID score sig. transformed; TauID score sig. transformed; Events', xbins=xbins, xmin=0, xmax=1, opt=
'kAlwaysCreate')
648 if not info.getHLTTauHitZAlg()
and not info.getHLTTauCaloHitsPreselectionID():
return
650 mon_group_name = f
'{trigger}_HLT_HitZ_{n_prong}'
651 mon_group_path = f
'{base_path}/basicVars/{trigger}/HLT_{n_prong}'
652 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
654 for alg, (z0, z0_sigma)
in self.
hlt_hitz_variables[info.getHLTTauLegContainerSfx()].items():
655 mon_group.defineHistogram(f
'{alg}_z0', title=f
'{alg} z_{{0}}; z_{{0}} [mm]; Events', xbins=100, xmin=-185, xmax=185, opt=
'kAlwaysCreate')
656 mon_group.defineHistogram(f
'{alg}_z0_sigma', title=f
'{alg} #sigma_{{z_{{0}}}}; #sigma_{{z_{{0}}}} [mm]; Events', xbins=100, xmin=0, xmax=100, opt=
'kAlwaysCreate')
657 mon_group.defineHistogram(f
'{alg}_z0_delta', title=f
'{alg} z_{{0}} - z_{{#tau}}; z_{{0}} - z_{{#tau}} [mm]; Events', xbins=100, xmin=-185, xmax=185, opt=
'kAlwaysCreate')
658 mon_group.defineHistogram(f
'{alg}_z0_delta_sig', title=f
'{alg} (z_{{0}} - z_{{#tau}}) / #sigma_{{z_{{0}}}}; (z_{{0}} - z_{{#tau}}) / #sigma_{{z_{{0}}}}; Events', xbins=100, xmin=-10, xmax=10, opt=
'kAlwaysCreate')
662 type_str =
'HLT' if online
else 'Offline'
663 mon_group_name = f
'{trigger}_{type_str}_basicVars_{n_prong}'
664 mon_group_path = f
'{base_path}/basicVars/{trigger}/{type_str}_{n_prong}'
665 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
669 mon_group.defineHistogram(
'Pt', title=f
'{type_str} p_{{T}}; p_{{T}} [GeV]; Events', xbins=binning, opt=
'kAlwaysCreate')
670 mon_group.defineHistogram(
'Eta', title=f
'{type_str} #eta; #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
671 mon_group.defineHistogram(
'Phi', title=f
'{type_str} #phi; #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
672 mon_group.defineHistogram(
'nTrack', title=f
'{type_str} Number of tracks; N_{{track}}; Events', xbins=10, xmin=0, xmax=10, opt=
'kAlwaysCreate')
673 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')
674 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')
675 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')
676 mon_group.defineHistogram(
'nIsoTrack', title=f
'{type_str} Number of isolation tracks; N_{{track}}^{{iso}}; Events', xbins=10, xmin=0, xmax=10, opt=
'kAlwaysCreate')
677 mon_group.defineHistogram(
'averageMu', title=f
'{type_str} Average #mu; #LT#mu$GT; Events', xbins=20, xmin=0, xmax=80, opt=
'kAlwaysCreate')
678 mon_group.defineHistogram(
'TauVertexX', title=f
'{type_str} Tau Vertex X; x [mm]; Events', xbins=100, xmin=-1, xmax=1, opt=
'kAlwaysCreate')
679 mon_group.defineHistogram(
'TauVertexY', title=f
'{type_str} Tau Vertex Y; y [mm]; Events', xbins=100, xmin=-2, xmax=0, opt=
'kAlwaysCreate')
680 mon_group.defineHistogram(
'TauVertexZ', title=f
'{type_str} Tau Vertex Z; z [mm]; Events', xbins=120, xmin=-120, xmax=120, opt=
'kAlwaysCreate')
684 mon_group_name = f
'{trigger}_DiTauHLT_Efficiency'
685 mon_group_path = f
'{base_path}/DiTauHLT_Efficiency/{trigger}/DiTauHLT_Efficiency'
686 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
688 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, eff='HLT', high_pt=False):
689 pass_flag = f
'{eff}_pass'
693 pass_flag +=
'_highPt'
695 xlabel +=
' (p_{T}^{1,2} > p_{T}^{thr 1,2} + 20 GeV)'
697 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffDiTau{eff}_{xvariable}{sfx}_wrt_Offline',
698 title=f
'DiTau {eff} Efficiency {trigger};{xlabel};Efficiency',
699 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
703 defineEachStepHistograms(
'dR',
'#Delta R(#tau,#tau)', 20, 0, 4, eff)
704 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,#tau)', 20, 0, 4, eff)
705 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,#tau)', 8, -3.2, 3.2, eff)
707 defineEachStepHistograms(
'dR',
'#Delta R(#tau,#tau)', 20, 0, 4, eff, high_pt=
True)
708 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,#tau)', 20, 0, 4, eff, high_pt=
True)
709 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,#tau)', 8, -3.2, 3.2, eff, high_pt=
True)
710 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80, eff)
713 mon_group.defineTree(
'dR,dEta,dPhi,averageMu,HLT_pass;DiTauHLTEffTree',
714 treedef=
'dR/F:dEta/F:dPhi/F:averageMu/F:HLT_pass/I')
718 mon_group_name = f
'{trigger}_DiTauVars'
719 mon_group_path = f
'{base_path}/DiTauVars/{trigger}'
720 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
722 mon_group.defineHistogram(
'leadHLTEt,subleadHLTEt', type=
'TH2F', title=
'p_{T}^{lead} vs p_{T}^{sublead}; p_{T}^{lead} [GeV]; p_{T}^{sublead} [GeV]',
723 xbins=50, xmin=0, xmax=250, ybins=50, ymin=0, ymax=250, opt=
'kAlwaysCreate')
724 mon_group.defineHistogram(
'leadHLTEta,subleadHLTEta', type=
'TH2F', title=
'#eta_{lead} vs #eta_{sublead}; #eta_{lead}; #eta_{sublead}',
725 xbins=26, xmin=-2.6, xmax=2.6, ybins=26, ymin=-2.6, ymax=2.6, opt=
'kAlwaysCreate')
726 mon_group.defineHistogram(
'leadHLTPhi,subleadHLTPhi', type=
'TH2F', title=
'#phi_{lead} vs #phi_{sublead}; #phi_{lead}; #phi_{sublead}',
727 xbins=16, xmin=-3.2, xmax=3.2, ybins=16, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
728 mon_group.defineHistogram(
'dR', title=
'#Delta R(#tau,#tau); #Delta R(#tau,#tau); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
729 mon_group.defineHistogram(
'dEta', title=
'#Delta#eta(#tau,#tau); #Delta#eta(#tau,#tau); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
730 mon_group.defineHistogram(
'dPhi', title=
'#Delta#phi(#tau,#tau); #Delta#phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
732 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,#tau); p_{T} [GeV]; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
733 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,#tau); #eta(#tau,#tau); Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
734 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,#tau); #phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
735 mon_group.defineHistogram(
'M', title=
'm(#tau,#tau); m_{#tau,#tau}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
736 mon_group.defineHistogram(
'dPt', title=
'#Delta p_{T}(#tau, #tau); p_{T} [GeV]; Events', xbins=20, xmin=0, xmax=200, opt=
'kAlwaysCreate')
738 mon_group.defineTree(
'leadHLTEt,subleadHLTEt,leadHLTEta,subleadHLTEta,leadHLTPhi,subleadHLTPhi,dR,dEta,dPhi,Pt,Eta,Phi,M,dPt;DiTauVarsTree',
739 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')
748 mon_group_name = f
'{trigger}_BoostedDiTauVars'
749 mon_group_path = f
'{base_path}/BoostedDiTauVars/{trigger}'
750 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
752 mon_group.defineHistogram(
'omni_score', title=
'omni_score; omni_score; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
753 mon_group.defineHistogram(
'R_tracks_lead', title=
'R_tracks_lead; R_tracks_lead; Events', xbins=50, xmin=0, xmax=0.2, opt=
'kAlwaysCreate')
754 mon_group.defineHistogram(
'R_tracks_subl', title=
'R_tracks_subl; R_tracks_subl; Events', xbins=50, xmin=0, xmax=0.2, opt=
'kAlwaysCreate')
755 mon_group.defineHistogram(
'f_core_lead', title=
'f_core_lead; f_core_lead; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
756 mon_group.defineHistogram(
'f_core_subl', title=
'f_core_subl; f_core_subl; Events', xbins=50, xmin=0, xmax=1, opt=
'kAlwaysCreate')
757 mon_group.defineHistogram(
'n_track', title=
'Number of tracks; n_tracks; Events', xbins=51, xmin=-0.5, xmax=50.5, opt=
'kAlwaysCreate')
758 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')
759 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')
760 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,#tau); p_{T} [GeV]; Events', xbins=50, xmin=160, xmax=1300, opt=
'kAlwaysCreate')
761 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,#tau); #eta(#tau,#tau); Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
762 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,#tau); #phi(#tau,#tau); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
763 mon_group.defineHistogram(
'M', title=
'm(#tau,#tau); m_{#tau,#tau}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
766 mon_group_name = f
'{trigger}_TAndPHLT_Efficiency'
767 mon_group_path = f
'{base_path}/TAndPHLT_Efficiency/{trigger}/TAndPHLT_Efficiency'
768 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
770 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
771 pass_flag =
'HLT_pass'
775 pass_flag +=
'_highPt'
777 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
781 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffTAndPHLT_{xvariable}{sfx}_wrt_Offline',
782 title=f
'TAndP HLT Efficiency {trigger}; {xlabel}; Efficiency',
783 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
787 defineEachStepHistograms(
'tauPt',
'p_{T}^{#tau} [GeV]', 60, 0.0, 300)
788 defineEachStepHistograms(
'tauPt',
'p_{T}^{#tau} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
789 defineEachStepHistograms(
'tauEta',
'#eta_{#tau}', 13, -2.6, 2.6)
790 defineEachStepHistograms(
'tauPhi',
'#phi_{#tau}', 16, -3.2, 3.2)
791 defineEachStepHistograms(
'tauEta',
'#eta_{#tau}', 13, -2.6, 2.6, high_pt=
True)
792 defineEachStepHistograms(
'tauPhi',
'#phi_{#tau}', 16, -3.2, 3.2, high_pt=
True)
793 defineEachStepHistograms(
'dR',
'#Delta R(#tau,lep)', 20, 0, 4)
794 defineEachStepHistograms(
'dEta',
'#Delta#eta(#tau,lep)', 20, 0,4)
795 defineEachStepHistograms(
'dPhi',
'#Delta#phi(#tau,lep)', 8, -3.2, 3.2)
796 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80)
799 mon_group.defineTree(
'tauPt,tauEta,tauPhi,dR,dEta,dPhi,averageMu,HLT_pass;TAndPHLTEffTree',
800 treedef=
'tauPt/F:tauEta/F:tauPhi/F:dR/F:dEta/F:dPhi/F:averageMu/F:HLT_pass/I')
804 mon_group_name = f
'{trigger}_TAndPVars'
805 mon_group_path = f
'{base_path}/TAndPVars/{trigger}'
806 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
808 mon_group.defineHistogram(
'dR', title=
'#Delta R(#tau,lep); #Delta R(#tau,lep); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
809 mon_group.defineHistogram(
'dEta', title=
'#Delta#eta(#tau,lep); #Delta#eta(#tau,lep); Events', xbins=40, xmin=0, xmax=4, opt=
'kAlwaysCreate')
810 mon_group.defineHistogram(
'dPhi', title=
'#Delta#phi(#tau,lep); #Delta#phi(#tau,lep); Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
812 mon_group.defineHistogram(
'Pt', title=
'p_{T}(#tau,lep); p_{T} [GeV]; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
813 mon_group.defineHistogram(
'Eta', title=
'#eta(#tau,lep); #eta; Events', xbins=26, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
814 mon_group.defineHistogram(
'Phi', title=
'#phi(#tau,lep); #phi; Events', xbins=16, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
815 mon_group.defineHistogram(
'M', title=
'm(#tau,lep); m_{#tau,lep}; Events', xbins=50, xmin=0, xmax=250, opt=
'kAlwaysCreate')
816 mon_group.defineHistogram(
'dPt', title=
'#Delta p_{T}(#tau,lep); p_{T} [GeV]; Events', xbins=20, xmin=0, xmax=200, opt=
'kAlwaysCreate')
820 mon_group_name = f
'{trigger}_Truth_Efficiency_{n_prong}'
821 mon_group_path = f
'{base_path}/Truth_Efficiency/{trigger}/Truth_Efficiency_{n_prong}'
822 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
826 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
827 pass_flag =
'HLT_pass'
831 pass_flag +=
'_highPt'
833 if info.isHLTDiTau():
834 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau min thr} + 20 GeV)'
836 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
840 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffHLT_{xvariable}{sfx}_wrt_Truth',
841 title=f
'HLT Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
842 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax)
846 defineEachStepHistograms(
'pt_vis',
'p_{T, vis} [GeV]', 60, 0.0, 300)
847 if info.isHLTSingleTau()
or info.isHLTTandP(): defineEachStepHistograms(
'pt_vis',
'p_{T, vis} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
848 defineEachStepHistograms(
'eta_vis',
'#eta_{vis}', 13, -2.6, 2.6)
849 defineEachStepHistograms(
'phi_vis',
'#phi_{vis}', 16, -3.2, 3.2)
850 defineEachStepHistograms(
'eta_vis',
'#eta_{vis}', 13, -2.6, 2.6, high_pt=
True)
851 defineEachStepHistograms(
'phi_vis',
'#phi_{vis}', 16, -3.2, 3.2, high_pt=
True)
855 mon_group_name = f
'{trigger}_TruthVars_{n_prong}'
856 mon_group_path = f
'{base_path}/TruthVars/{trigger}/TruthVars_{n_prong}'
857 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
859 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)
860 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)
861 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)
863 mon_group.defineHistogram(
'pt_vis', title=
'p_{T, vis}; p_{T, vis}; Events', xbins=50, xmin=0, xmax=250)
864 mon_group.defineHistogram(
'eta_vis', title=
'#eta_{vis}; #eta_{vis}; Events', xbins=26, xmin=-2.6, xmax=2.6)
865 mon_group.defineHistogram(
'phi_vis', title=
'#phi_{vis}; #phi_{vis}; Events', xbins=16, xmin=-3.2, xmax=3.2)
869 mon_group_name = f
'{trigger}_L1_Efficiency_{n_prong}'
870 mon_group_path = f
'{base_path}/L1_Efficiency/{trigger}/L1_Efficiency_{n_prong}'
871 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
873 def defineEachStepHistograms(xvariable, xlabel, xbins, xmin, xmax, high_pt=False, coarse=False):
874 pass_flag =
'L1_pass'
878 pass_flag +=
'_highPt'
880 xlabel +=
' (p_{T}^{#tau} > p_{T}^{#tau thr} + 20 GeV)'
884 mon_group.defineHistogram(f
'{pass_flag},{xvariable};EffL1_{xvariable}{sfx}_wrt_Offline',
885 title=f
'L1 Efficiency {trigger} {n_prong}; {xlabel}; Efficiency',
886 type=
'TEfficiency', xbins=xbins, xmin=xmin, xmax=xmax, opt=
'kAlwaysCreate')
890 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', 60, 0, 300)
891 defineEachStepHistograms(
'tauPt',
'p_{T} [GeV]', coarse_binning, coarse_binning[0], coarse_binning[-1], coarse=
True)
892 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6)
893 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2)
894 defineEachStepHistograms(
'tauEta',
'#eta', 13, -2.6, 2.6, high_pt=
True)
895 defineEachStepHistograms(
'tauPhi',
'#phi', 16, -3.2, 3.2, high_pt=
True)
896 defineEachStepHistograms(
'averageMu',
'#LT#mu#GT', 10, 0, 80)
900 mon_group_name = f
'{trigger}_L1Vars'
901 mon_group_path = f
'{base_path}/L1Vars/{trigger}'
902 mon_group = self.
helper.addGroup(mon_alg, mon_group_name, mon_group_path)
904 mon_group.defineHistogram(
'L1RoIEt,L1RoIEta', type=
'TH2F', title=
'L1 RoI E_{T} vs #eta; E_{T} [GeV]; #eta',
905 xbins=60, xmin=0, xmax=300,
906 ybins=60, ymin=-2.6, ymax=2.6, opt=
'kAlwaysCreate')
907 mon_group.defineHistogram(
'L1RoIEt,L1RoIPhi', type=
'TH2F', title=
'L1 RoI E_{T} vs #phi; E_{T} [GeV]; #phi',
908 xbins=60, xmin=0, xmax=300,
909 ybins=60, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
910 mon_group.defineHistogram(
'L1RoIEta,L1RoIPhi', type=
'TH2F', title=
'L1 RoI #eta vs #phi; #eta; #phi',
911 xbins=60, xmin=-2.6, xmax=2.6,
912 ybins=60, ymin=-3.2, ymax=3.2, opt=
'kAlwaysCreate')
913 mon_group.defineHistogram(
'L1RoIEta', title=
'L1 RoI #eta; #eta; RoIs', xbins=60, xmin=-2.6, xmax=2.6, opt=
'kAlwaysCreate')
914 mon_group.defineHistogram(
'L1RoIPhi', title=
'L1 RoI #phi; #phi; RoIs', xbins=60, xmin=-3.2, xmax=3.2, opt=
'kAlwaysCreate')
915 mon_group.defineHistogram(
'L1RoIEt', title=
'L1 RoI E_{T}; E_{T} [GeV]; RoIs', xbins=60, xmin=0, xmax=300, opt=
'kAlwaysCreate')
917 if 'eTAU' in trigger:
918 mon_group.defineHistogram(
'L1eFexRoIRCore', title=
'L1 eTAU RoI rCore Isolation; rCore Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
919 mon_group.defineHistogram(
'L1eFexRoIRHad' , title=
'L1 eTAU RoI rHad Isolation; rHad Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
920 mon_group.defineHistogram(
'L1eFexRoIBDTScore' , title=
'L1 eTAU RoI BDT score; BDT Score; RoIs', xbins=128, xmin=512, xmax=1024, opt=
'kAlwaysCreate')
922 elif 'cTAU' in trigger:
923 mon_group.defineHistogram(
'L1eFexRoIRCore', title=
'L1 eTAU RoI rCore Isolation; eTAU rCore Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
924 mon_group.defineHistogram(
'L1eFexRoIRHad', title=
'L1 eTAU RoI rHad Isolation; eTAU rHad Isolation; RoIs', xbins=250, xmin=0, xmax=1, opt=
'kAlwaysCreate')
925 mon_group.defineHistogram(
'L1cTauRoITopoMatch', title=
'L1Topo match between eTAU and jTAU RoI; Match; RoIs', xbins=2, xmin=0, xmax=2, opt=
'kAlwaysCreate')
926 mon_group.defineHistogram(
'L1jFexRoIIso', title=
'L1 jTAU RoI Isolation; E_{T}^{jTAU Iso} [GeV]; RoIs', xbins=25, xmin=0, xmax=50, opt=
'kAlwaysCreate')
927 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')
928 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')
929 mon_group.defineHistogram(
'L1eFexRoIBDTScore' , title=
'L1 eTAU RoI BDT score; BDT Score; RoIs', xbins=128, xmin=512, xmax=1024, opt=
'kAlwaysCreate')
931 elif 'jTAU' in trigger:
932 mon_group.defineHistogram(
'L1jFexRoIIso', title=
'L1 jTAU RoI Isolation; jTAU Isolation [GeV]; N RoI', xbins=25, xmin=0, xmax=50, opt=
'kAlwaysCreate')
937 def getList(ranges, others=[250]):
938 ret =
set(others + [500])
939 for jump, interval
in ranges.items():
940 ret.update(range(interval[0], interval[1], jump), interval)
941 return sorted(list(ret))
943 if info.isL1TauOnly():
944 thr = info.getL1TauThreshold()
946 if thr <= 8:
return getList({5:(0, 30), 50:(50, 150)})
947 elif thr <= 12:
return getList({5:(0, 30), 50:(50, 150)})
948 elif thr <= 20:
return getList({5:(5, 40), 10:(40, 70), 50:(100, 150)})
949 elif thr <= 30:
return getList({5:(15, 50), 10:(50, 70), 50:(100, 150)})
950 elif thr <= 35:
return getList({5:(20, 55), 10:(60, 80), 50:(100, 150)})
951 elif thr <= 40:
return getList({5:(25, 60), 10:(60, 80), 50:(100, 150)})
952 elif thr <= 60:
return getList({5:(45, 80), 10:(80, 100), 50:(100, 150)})
953 elif thr <= 100:
return getList({5:(85, 120), 10:(120, 140), 20:(140, 180), 50:(200, 250)})
954 else:
return getList({50:(0, 200)})
957 thr = info.getHLTTauThreshold()
960 if thr == 0:
return getList({5:(0, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
961 elif thr <= 20:
return getList({5:(15, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
962 elif thr <= 25:
return getList({5:(20, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
963 elif thr <= 30:
return getList({5:(25, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
964 elif thr <= 35:
return getList({5:(30, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
965 elif thr <= 60:
return getList({5:(55, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
966 elif thr <= 80:
return getList({5:(75, 80), 10:(80, 120), 20:(120, 160), 40:(160, 240), 60:(240, 420)}, [])
967 elif thr <= 160:
return getList({5:(155, 160), 40:(160, 240), 60:(240, 420)}, [])
968 elif thr <= 180:
return getList({5:(175, 180), 40:(180, 260), 60:(260, 380)}, [])
969 else:
return getList({5:(195, 200), 40:(200, 240), 60:(240, 420)}, [])
974 else:
return getList({5:(0, 30), 50:(50, 150)})
975 elif thr <= 20:
return getList({5:(10, 40), 10:(40, 60), 20:(60, 80)}, [150, 250])
976 elif thr <= 25:
return getList({5:(15, 40), 10:(40, 60), 20:(60, 80)}, [150, 250])
977 elif thr <= 30:
return getList({5:(20, 50), 10:(50, 60), 20:(60, 80)}, [150, 250])
978 elif thr <= 35:
return getList({5:(25, 50), 10:(50, 60), 20:(60, 80)}, [150, 250])
979 elif thr <= 60:
return getList({5:(50, 70), 10:(70, 80)}, [110, 150, 250])
980 elif thr <= 80:
return getList({5:(70, 90)}, [110, 150, 250])
981 elif thr <= 160:
return getList({5:(150, 170), 10:(170, 180), 20:(180, 200)}, [240, 300])
982 elif thr <= 180:
return getList({5:(170, 180), 10:(180, 200)}, [240, 300])
983 else:
return getList({5:(190, 200), 10:(200, 210)}, [240, 300])