ATLAS Offline Software
AutoconfigurePRW.py
Go to the documentation of this file.
1 # Copyright (C) 2002-2024 CERN for the benefit of the ATLAS collaboration
2 from Campaigns.Utils import Campaign, getMCCampaign
3 from AnalysisAlgorithmsConfig.ConfigAccumulator import DataType
4 
5 
6 def getLumicalcFiles(campaign):
7  """ Returns the list of lumicalc files for a given campaign """
8  ilumical_files = {
9  Campaign.MC16a: [
10  'GoodRunsLists/data15_13TeV/20170619/PHYS_StandardGRL_All_Good_25ns_276262-284484_OflLumi-13TeV-008.root',
11  'GoodRunsLists/data16_13TeV/20180129/PHYS_StandardGRL_All_Good_25ns_297730-311481_OflLumi-13TeV-009.root'
12  ],
13  Campaign.MC16d: [
14  'GoodRunsLists/data17_13TeV/20180619/physics_25ns_Triggerno17e33prim.lumicalc.OflLumi-13TeV-010.root'
15  ],
16  Campaign.MC16e: [
17  'GoodRunsLists/data18_13TeV/20190318/ilumicalc_histograms_None_348885-364292_OflLumi-13TeV-010.root'
18  ],
19  Campaign.MC20a: [
20  'GoodRunsLists/data15_13TeV/20170619/PHYS_StandardGRL_All_Good_25ns_276262-284484_OflLumi-13TeV-008.root',
21  'GoodRunsLists/data16_13TeV/20180129/PHYS_StandardGRL_All_Good_25ns_297730-311481_OflLumi-13TeV-009.root'
22  ],
23  Campaign.MC20d: [
24  'GoodRunsLists/data17_13TeV/20180619/physics_25ns_Triggerno17e33prim.lumicalc.OflLumi-13TeV-010.root'
25  ],
26  Campaign.MC20e: [
27  'GoodRunsLists/data18_13TeV/20190318/ilumicalc_histograms_None_348885-364292_OflLumi-13TeV-010.root'
28  ],
29  Campaign.MC21a: [
30  'GoodRunsLists/data22_13p6TeV/20230207/ilumicalc_histograms_None_431810-440613_OflLumi-Run3-003.root'
31  ],
32  Campaign.MC23a: [
33  'GoodRunsLists/data22_13p6TeV/20230207/ilumicalc_histograms_None_431810-440613_OflLumi-Run3-003.root'
34  ],
35  Campaign.MC23c: [
36  'GoodRunsLists/data23_13p6TeV/20230828/ilumicalc_histograms_None_451587-456749_OflLumi-Run3-003.root'
37  ],
38  Campaign.MC23d: [
39  'GoodRunsLists/data23_13p6TeV/20230828/ilumicalc_histograms_None_451587-456749_OflLumi-Run3-003.root'
40  ]
41  }
42 
43  try:
44  return ilumical_files[campaign]
45  except KeyError:
46  raise ValueError(f'Unsupported campaign {campaign} for lumicalc files')
47 
48 
49 def actualMuFiles(campaign):
50  list = []
51 
52  if campaign in [Campaign.MC16d, Campaign.MC20d]:
53  list.append(
54  'GoodRunsLists/data17_13TeV/20180619/physics_25ns_Triggerno17e33prim.actualMu.OflLumi-13TeV-010.root'
55  )
56  elif campaign in [Campaign.MC16e, Campaign.MC20e]:
57  list.append(
58  'GoodRunsLists/data18_13TeV/20190318/physics_25ns_Triggerno17e33prim.actualMu.OflLumi-13TeV-010.root'
59  )
60  elif campaign in [Campaign.MC21a, Campaign.MC23a]:
61  list.append(
62  'GoodRunsLists/data22_13p6TeV/20230207/purw.actualMu.2022.root'
63  )
64  elif campaign in [Campaign.MC23c, Campaign.MC23d]:
65  list.append(
66  'GoodRunsLists/data23_13p6TeV/20230828/purw.actualMu.2023.root'
67  )
68 
69  if campaign in [Campaign.MC16d, Campaign.MC20d, Campaign.MC16e, Campaign.MC20e, Campaign.MC21a, Campaign.MC23a, Campaign.MC23c, Campaign.MC23d]:
70  assert(len(list) == 1)
71  else:
72  assert(len(list) == 0)
73 
74  return list
75 
76 
77 def defaultConfigFiles(campaign):
78  list = []
79 
80  if campaign in [Campaign.MC20a]:
81  list.append(
82  'PileupReweighting/mc20_common/mc20a.284500.physlite.prw.v1.root'
83  )
84  elif campaign in [Campaign.MC20d]:
85  list.append(
86  'PileupReweighting/mc20_common/mc20d.300000.physlite.prw.v1.root'
87  )
88  elif campaign in [Campaign.MC20e]:
89  list.append(
90  'PileupReweighting/mc20_common/mc20e.310000.physlite.prw.v1.root'
91  )
92  elif campaign in [Campaign.MC21a]:
93  list.append(
94  'PileupReweighting/mc21_common/mc21a.410000.physlite.prw.v1.root'
95  )
96  elif campaign in [Campaign.MC23a]:
97  list.append(
98  'PileupReweighting/mc23_common/mc23a.410000.physlite.prw.v2.root'
99  )
100  elif campaign in [Campaign.MC23c]:
101  list.append(
102  'PileupReweighting/mc23_common/mc23c.450000.physlite.prw.v1.root'
103  )
104  elif campaign in [Campaign.MC23d]:
105  list.append(
106  'PileupReweighting/mc23_common/mc23d.450000.physlite.prw.v1.root'
107  )
108  else:
109  raise ValueError(f'Unsupported campaign {campaign}')
110 
111  assert(len(list) == 1)
112 
113  return list
114 
115 
116 def getConfigurationFiles(campaign=None, dsid=None, data_type=None, files=None, useDefaultConfig=False):
117  # Attempt auto-configuration
118  default_directory = 'dev/PileupReweighting/share'
119  configuration_files = []
120 
121  if files is not None and (campaign is None or dsid is None or data_type is None):
122  if campaign is None:
123  campaign = getMCCampaign(files)
124 
125  if dsid is None or data_type is None:
126  from AthenaConfiguration.AutoConfigFlags import GetFileMD
127  metadata = GetFileMD(files)
128  if dsid is None:
129  dsid = str(metadata.get('mc_channel_number', 0))
130  if data_type is None:
131  simulation_flavour = GetFileMD(files).get('Simulator', '')
132  if not simulation_flavour:
133  simulation_flavour = GetFileMD(files).get('SimulationFlavour', '')
134  data_type = DataType.FullSim if (not simulation_flavour or 'FullG4' in simulation_flavour) else DataType.FastSim
135 
136  # data_type as in pileup analysis sequence: either 'data' or ('fullsim' or 'af3')
137  if data_type is DataType.Data:
138  raise ValueError('Data is not supported')
139 
140  if data_type is DataType.FullSim:
141  simulation_type = 'FS'
142  elif data_type is DataType.FastSim:
143  simulation_type = 'AF3'
144  else:
145  raise ValueError(f'Invalid data_type {data_type}')
146 
147  configuration_files = actualMuFiles(campaign)
148  if useDefaultConfig:
149  configuration_files += defaultConfigFiles(campaign)
150  return configuration_files
151 
152  config = f'{default_directory}/DSID{dsid[:3]}xxx/pileup_{campaign.value}_dsid{dsid}_{simulation_type}.root'
153  from PathResolver import PathResolver
154  if not PathResolver.FindCalibFile(config):
155  return []
156  else:
157  configuration_files.append(config)
158  return configuration_files
PathResolver::FindCalibFile
static std::string FindCalibFile(const std::string &logical_file_name)
Definition: PathResolver.h:108
python.AutoconfigurePRW.actualMuFiles
def actualMuFiles(campaign)
Definition: AutoconfigurePRW.py:49
python.AutoConfigFlags.GetFileMD
def GetFileMD(filenames, allowEmpty=True)
Definition: AutoConfigFlags.py:51
python.AutoconfigurePRW.getConfigurationFiles
def getConfigurationFiles(campaign=None, dsid=None, data_type=None, files=None, useDefaultConfig=False)
Definition: AutoconfigurePRW.py:116
python.AutoconfigurePRW.defaultConfigFiles
def defaultConfigFiles(campaign)
Definition: AutoconfigurePRW.py:77
get
T * get(TKey *tobj)
get a TObject* from a TKey* (why can't a TObject be a TKey?)
Definition: hcg.cxx:127
str
Definition: BTagTrackIpAccessor.cxx:11
python.AutoconfigurePRW.getLumicalcFiles
def getLumicalcFiles(campaign)
Definition: AutoconfigurePRW.py:6
python.Utils.getMCCampaign
def getMCCampaign(files)
Definition: Tools/Campaigns/python/Utils.py:27