526 def makeAlgs (self, config) :
527
528 if config.dataType() is not DataType.Data:
529
530
531
532
533 triggerDict = TriggerDict()
534
535 if self.includeAllYearsPerRun:
536 years = [int(year) for year in self.triggerChainsPerYear.keys()]
537 else:
538 from TriggerAnalysisAlgorithms.TriggerAnalysisSFConfig import (
539 get_input_years)
540 years = get_input_years(config)
541
542 triggerYearStartBoundaries = {
543 2015: 260000,
544 2016: 290000,
545 2017: 324000,
546 2018: 348000,
547 2022: 410000,
548 2023: 450000,
549 2024: 470000,
550 }
551
552 triggerConfigs = {}
553 triggerConfigYears = {}
554 from TriggerAnalysisAlgorithms.TriggerAnalysisConfig import is_year_in_current_period
555 for year in years:
556 if not is_year_in_current_period(config, year):
557 continue
558
559 triggerChains = self.triggerChainsPerYear.
get(int(year), self.triggerChainsPerYear.
get(
str(year), []))
560 for chain in triggerChains:
561 chain = chain.replace(" || ", "_OR_")
562 chain_noHLT = chain.replace("HLT_", "")
563 chain_out = chain_noHLT if self.removeHLTPrefix else chain
564 legs = triggerDict[chain_noHLT]
565 if not legs:
566 if chain_noHLT.startswith('mu') and chain_noHLT[2].isdigit:
567
568 triggerConfigs[chain_out] = chain
569 if chain_out in triggerConfigYears.keys():
570 triggerConfigYears[chain_out].append(year)
571 else:
572 triggerConfigYears[chain_out] = [year]
573 else:
574 for leg in legs:
575 if leg.startswith('mu') and leg[2].isdigit:
576
577 leg_out = leg if self.removeHLTPrefix else f"HLT_{leg}"
578 triggerConfigs[leg_out] = f"HLT_{leg}"
579 if leg_out in triggerConfigYears.keys():
580 triggerConfigYears[leg_out].append(year)
581 else:
582 triggerConfigYears[leg_out] = [year]
583
584 if not triggerConfigs:
585 return
586
587
588 sfTool = config.createPublicTool("CP::MuonTriggerScaleFactors", f"{self.instanceName()}_SFTool{self.customToolSuffix}")
589
590 sfTool.MuonQuality = self.muonID
591 sfTool.AllowZeroSF = True
592 sfTool.CustomInputFolder = self.customInputFolder
593 sfTool.CustomInputFilePerYear = self.customInputFilePerYear
594 sfTool.Campaign = config.campaign().value
595
596 for trig_short, trig in triggerConfigs.items():
597 alg = config.createAlgorithm('CP::MuonTriggerEfficiencyScaleFactorAlg',
598 'MuonTrigEfficiencyCorrectionsAlg_' + trig_short)
599 alg.efficiencyScaleFactorTool = f"{sfTool.getType()}/{sfTool.getName()}"
600
601
602 if self.includeAllYearsPerRun:
603 alg.minRunNumber = 0
604 alg.maxRunNumber = 999999
605
606 if triggerConfigYears[trig_short][0] != years[0]:
607 alg.minRunNumber = triggerYearStartBoundaries.get(triggerConfigYears[trig_short][0], 999999)
608 if triggerConfigYears[trig_short][-1] != years[-1]:
609 alg.maxRunNumber = triggerYearStartBoundaries.get(triggerConfigYears[trig_short][-1] + 1, 999999)
610 elif config.campaign() is Campaign.MC20a:
611 if triggerConfigYears[trig_short] == [2015]:
612 alg.maxRunNumber = 290000
613 elif triggerConfigYears[trig_short] == [2016]:
614 alg.minRunNumber = 290000
615
616 alg.trigger = trig
617
618
619 if config.campaign() is Campaign.MC23a and (trig_short == "HLT_mu8noL1_FSNOSEED" or trig_short == "HLT_mu22_L1MU14FCH"):
620 alg.minRunNumber = 435816
621
622 if self.saveSF:
623 alg.scaleFactorDecoration = f"muon_{self.prefixSF}_{trig_short}_%SYS%"
624 if self.saveEff:
625 alg.mcEfficiencyDecoration = f"muon_{self.prefixEff}_{trig_short}_%SYS%"
626 if self.saveEffData:
627 alg.dataEfficiencyDecoration = f"muon_{self.prefixEffData}_{trig_short}_%SYS%"
628 alg.outOfValidity = 2
629 alg.outOfValidityDeco = f"bad_eff_muontrig_{trig_short}"
630 alg.muons = config.readName (self.containerName)
631 alg.preselection = config.getPreselection (self.containerName, '')
632 if self.saveSF:
633 config.addOutputVar (self.containerName, alg.scaleFactorDecoration, f"{self.prefixSF}_{trig_short}")
634 if self.saveEff:
635 config.addOutputVar (self.containerName, alg.mcEfficiencyDecoration, f"{self.prefixEff}_{trig_short}")
636 if self.saveEffData:
637 config.addOutputVar (self.containerName, alg.dataEfficiencyDecoration, f"{self.prefixEffData}_{trig_short}")
638
639
T * get(TKey *tobj)
get a TObject* from a TKey* (why can't a TObject be a TKey?)