|
1 | 1 | # import the definition of the steps and input files: |
2 | 2 | from Configuration.PyReleaseValidation.relval_steps import * |
| 3 | +from functools import partial |
3 | 4 |
|
4 | 5 | # here only define the workflows as a combination of the steps defined above: |
5 | 6 | workflows = Matrix() |
6 | 7 |
|
7 | 8 | ## Here we define fixed high stats data workflows |
8 | 9 | ## not to be run as default. 10k, 50k, 150k, 250k, 500k or 1M events each |
9 | 10 |
|
10 | | -offset_era = 0.1 # less than 10 eras per year (hopefully!) |
11 | | -offset_pd = 0.001 # less than 100 pds per year |
12 | | -offset_events = 0.0001 # less than 10 event setups (10k,50k,150k,250k,500k,1M) |
13 | | - |
14 | | -## 2025 |
15 | | -base_wf = 2025.0 |
16 | | -for e_n,era in enumerate(eras_2025): |
17 | | - for p_n,pd in enumerate(pds_2025): |
18 | | - for e_key,evs in event_steps_dict.items(): |
19 | | - wf_number = base_wf |
20 | | - wf_number = wf_number + offset_era * e_n |
21 | | - wf_number = wf_number + offset_pd * p_n |
22 | | - wf_number = wf_number + offset_events * evs |
23 | | - wf_number = round(wf_number,6) |
24 | | - |
25 | | - ## ZeroBias has its own RECO and HARVESTING setup |
26 | | - ## ScoutingPFMonitor has its own HLT, RECO and HARVESTING setup |
27 | | - recoharv = hlt = '' |
28 | | - if 'ZeroBias' in pd: |
29 | | - recoharv = 'ZB_' |
30 | | - elif 'ScoutingPFMonitor' in pd: |
31 | | - hlt = recoharv = 'ScoutingPFMonitor_' |
32 | | - |
33 | | - recosetup = 'RECONANORUN3_' + recoharv + 'reHLT_2025' |
34 | | - |
35 | | - y = str(int(base_wf)) |
36 | | - |
37 | | - ## this is because ParkingDouble* PDs would end up with a too long name for the submission infrastructure |
38 | | - step_name = 'Run' + pd.replace('ParkingDouble','Park2') + era.split('Run')[1] + '_' + e_key |
39 | | - |
40 | | - workflows[wf_number] = ['',[step_name,'HLTDR3_' + hlt + y,'RECONANORUN3_' + recoharv + 'reHLT_'+y,'HARVESTRUN3_' + recoharv + y]] |
41 | | - |
42 | | -## 2024 |
43 | | -base_wf = 2024.0 |
44 | | -for e_n,era in enumerate(eras_2024): |
45 | | - for p_n,pd in enumerate(pds_2024): |
46 | | - for e_key,evs in event_steps_dict.items(): |
47 | | - wf_number = base_wf |
48 | | - wf_number = wf_number + offset_era * e_n |
49 | | - wf_number = wf_number + offset_pd * p_n |
50 | | - wf_number = wf_number + offset_events * evs |
51 | | - wf_number = round(wf_number,6) |
52 | | - |
53 | | - ## Here we use JetMET1 PD to run the TeVJet skims |
54 | | - skim = 'TeVJet' if pd == 'JetMET1' else '' |
55 | | - |
56 | | - ## ZeroBias has its own RECO and HARVESTING setup |
57 | | - suff = 'ZB_' if 'ZeroBias' in pd else '' |
58 | | - |
59 | | - # Running C,D,E with the offline GT. |
60 | | - # Could be removed once 2025 wfs are in and we'll test the online GT with them |
61 | | - recosetup = 'RECONANORUN3_' + suff + 'reHLT_2024' |
62 | | - recosetup = recosetup if era[-1] > 'E' else recosetup + '_Offline' |
63 | | - |
64 | | - y = str(int(base_wf)) |
65 | | - |
66 | | - ## this is because ParkingDouble* PDs would end up with a too long name for the submission infrastructure |
67 | | - step_name = 'Run' + pd.replace('ParkingDouble','Park2') + era.split('Run')[1] + skim + '_' + e_key |
68 | | - |
69 | | - workflows[wf_number] = ['',[step_name,'HLTDR3_' + y,'RECONANORUN3_' + suff + 'reHLT_'+y,'HARVESTRUN3_' + suff + y]] |
70 | | - |
71 | | -## 2023 |
72 | | -base_wf = 2023.0 |
73 | | -for e_n,era in enumerate(eras_2023): |
74 | | - for p_n,pd in enumerate(pds_2023): |
75 | | - for e_key,evs in event_steps_dict.items(): |
76 | | - wf_number = base_wf |
77 | | - wf_number = wf_number + offset_era * e_n |
78 | | - wf_number = wf_number + offset_pd * p_n |
79 | | - wf_number = wf_number + offset_events * evs |
80 | | - wf_number = round(wf_number,6) |
81 | | - |
82 | | - ## this is because ParkingDouble* PDs would end up with a too long name for the submission infrastructure |
83 | | - step_name = 'Run' + pd.replace('ParkingDouble','Park2') + era.split('Run')[1] + '_' + e_key |
84 | | - |
85 | | - y = str(int(base_wf)) + 'B' if '2023B' in era else str(int(base_wf)) |
86 | | - suff = 'ZB_' if 'ZeroBias' in step_name else '' |
87 | | - workflows[wf_number] = ['',[step_name,'HLTDR3_' + y,'RECONANORUN3_' + suff + 'reHLT_'+y,'HARVESTRUN3_' + suff + y]] |
88 | | - |
89 | | -## 2022 |
90 | | -base_wf = 2022.0 |
91 | | -for e_n,era in enumerate(eras_2022_1): |
92 | | - for p_n,pd in enumerate(pds_2022_1): |
93 | | - for e_key,evs in event_steps_dict.items(): |
94 | | - wf_number = base_wf |
95 | | - wf_number = wf_number + offset_era * e_n |
96 | | - wf_number = wf_number + offset_pd * p_n |
97 | | - wf_number = wf_number + offset_events * evs |
98 | | - wf_number = round(wf_number,6) |
99 | | - step_name = 'Run' + pd + era.split('Run')[1] + '_' + e_key |
100 | | - y = str(int(base_wf)) |
101 | | - suff = 'ZB_' if 'ZeroBias' in step_name else '' |
102 | | - workflows[wf_number] = ['',[step_name,'HLTDR3_' + y,'RECONANORUN3_' + suff + 'reHLT_'+y,'HARVESTRUN3_' + suff + y]] |
103 | | - |
104 | | -# PD names changed during 2022 |
105 | | -for e_n,era in enumerate(eras_2022_2): |
106 | | - for p_n,pd in enumerate(pds_2022_2): |
107 | | - for e_key,evs in event_steps_dict.items(): |
108 | | - wf_number = base_wf |
109 | | - wf_number = wf_number + offset_era * (e_n + len(eras_2022_1)) |
110 | | - wf_number = wf_number + offset_pd * (p_n + len(pds_2022_1)) |
111 | | - wf_number = wf_number + offset_events * evs |
112 | | - wf_number = round(wf_number,6) |
113 | | - step_name = 'Run' + pd + era.split('Run')[1] + '_' + e_key |
114 | | - y = str(int(base_wf)) |
115 | | - suff = 'ZB_' if 'ZeroBias' in step_name else '' |
116 | | - workflows[wf_number] = ['',[step_name,'HLTDR3_' + y,'RECONANORUN3_' + suff + 'reHLT_'+y,'HARVESTRUN3_' + suff + y]] |
| 11 | +def run3NameMod(name): |
| 12 | + # ParkingDouble* PDs would end up with a too long name for the submission infrastructure |
| 13 | + return name.replace('ParkingDouble','Park2') |
| 14 | + |
| 15 | +def run3HarvMod(pd): |
| 16 | + ## ZeroBias, ScoutingPFMonitor and ParkingDoubleMuonLowMass |
| 17 | + ## have their own HARVESTING setup |
| 18 | + if 'ZeroBias' in pd: |
| 19 | + return 'ZB_' |
| 20 | + elif 'ScoutingPFMonitor' in pd: |
| 21 | + return 'ScoutingPFMonitor_' |
| 22 | + elif 'ParkingDoubleMuonLowMass' in pd: |
| 23 | + return 'HFLAV_' |
| 24 | + else: |
| 25 | + return '' |
| 26 | + |
| 27 | +def run3RecoMod(pd): |
| 28 | + ## ZeroBias and ScoutingPFMonitor have |
| 29 | + ## their own RECO setup |
| 30 | + if 'ZeroBias' in pd: |
| 31 | + return 'ZB_' |
| 32 | + elif 'ScoutingPFMonitor' in pd: |
| 33 | + return 'ScoutingPFMonitor_' |
| 34 | + else: |
| 35 | + return '' |
| 36 | + |
| 37 | +def run3HLTMod(pd): |
| 38 | + ## ScoutingPFMonitor has its own HLT setup |
| 39 | + if 'ScoutingPFMonitor' in pd: |
| 40 | + return 'ScoutingPFMonitor_' |
| 41 | + else: |
| 42 | + return '' |
| 43 | + |
| 44 | +def addFixedEventsWfs(years, pds, eras, offset = 0, suffreco = None, suffhlt = None, suffharv = None, namemod = None): |
| 45 | + |
| 46 | + for y in years: |
| 47 | + for era in eras: |
| 48 | + for pd in pds: |
| 49 | + for e_key,evs in event_steps_dict.items(): |
| 50 | + |
| 51 | + wf_number = float(y) + offset_pd * pds.index(pd) |
| 52 | + wf_number = wf_number + offset_era * eras.index(era) |
| 53 | + wf_number = wf_number + offset |
| 54 | + wf_number = round(wf_number + offset_events * evs, 6) |
| 55 | + |
| 56 | + # Here we customise the steps depending on the PD name |
| 57 | + reco = suffreco(pd) if suffreco is not None else '' |
| 58 | + harv = suffharv(pd) if suffharv is not None else '' |
| 59 | + hlt = suffhlt(pd) if suffhlt is not None else '' |
| 60 | + name = namemod(pd) if namemod is not None else '' |
| 61 | + |
| 62 | + recosetup = 'RECONANORUN3_' + reco + 'reHLT_2025' |
| 63 | + harvsetup = 'HARVESTRUN3_' + harv + y |
| 64 | + hltsetup = 'HLTDR3_' + hlt + y |
| 65 | + |
| 66 | + step_name = 'Run' + name + y + era + '_' + e_key |
| 67 | + if namemod is not None: |
| 68 | + step_name = namemod(step_name) |
| 69 | + |
| 70 | + workflows[wf_number] = ['',[step_name, hltsetup, recosetup, harvsetup]] |
| 71 | + |
| 72 | + return wf_number - float(y) #to concatenate the offset |
| 73 | + |
| 74 | +run3FixedWfs = partial(addFixedEventsWfs,suffreco = run3RecoMod, suffhlt = run3HLTMod, suffharv = run3HarvMod, namemod = run3NameMod) |
| 75 | +run3FixedWfs(['2025'],pds_2025,eras_2025) |
| 76 | +run3FixedWfs(['2024'],pds_2024,eras_2024) |
| 77 | +run3FixedWfs(['2023'],pds_2023,eras_2023) |
| 78 | +offset_2022 = run3FixedWfs(['2022'],pds_2022_2,eras_2022_2) |
| 79 | +run3FixedWfs(['2022'],pds_2022_1,eras_2022_1,offset = offset_2022) |
0 commit comments