6 if __name__==
'__main__':
12 parser = argparse.ArgumentParser(formatter_class=argparse.ArgumentDefaultsHelpFormatter)
14 parser.add_argument(
'-r',
'--run', dest=
'run', default=
'00408918', help=
'Run number string as in input filename', type=str)
15 parser.add_argument(
'-g',
'--gain', dest=
'gain', default=
"MEDIUM", help=
'Gain string', type=str)
16 parser.add_argument(
'-p',
'--partition', dest=
'partition', default=
"Em", help=
'Data taking partition string', type=str)
17 parser.add_argument(
'-f',
'--fileprefix', dest=
'fprefix', default=
"data24_calib", help=
'File prefix string', type=str)
18 parser.add_argument(
'-i',
'--indirprefix', dest=
'dprefix', default=
"/eos/atlas/atlastier0/rucio/", help=
'Input directory prefix string', type=str)
19 parser.add_argument(
'-d',
'--indir', dest=
'indir', default=
"", help=
'Full input dir string', type=str)
20 parser.add_argument(
'-t',
'--trigger', dest=
'trig', default=
'calibration_', help=
'Trigger string in filename', type=str)
21 parser.add_argument(
'-o',
'--outrwaveprefix', dest=
'outrwaveprefix', default=
"LArCaliWave", help=
'Prefix of CaliWave output root filename', type=str)
22 parser.add_argument(
'-l',
'--outpprefix', dest=
'outpprefix', default=
"LArCaliWave_OFC_Cali", help=
'Prefix of output pool filename', type=str)
23 parser.add_argument(
'-j',
'--outrofcprefix', dest=
'outrofcprefix', default=
"LArOFCCali", help=
'Prefix of output Cali OFC root filename', type=str)
24 parser.add_argument(
'-e',
'--outrdir', dest=
'outrdir', default=
"/eos/atlas/atlascerngroupdisk/det-larg/Temp/Weekly/ntuples", help=
'Output root file directory', type=str)
25 parser.add_argument(
'-k',
'--outpdir', dest=
'outpdir', default=
"/eos/atlas/atlascerngroupdisk/det-larg/Temp/Weekly/poolFiles", help=
'Output pool file directory', type=str)
26 parser.add_argument(
'-u',
'--insqlite', dest=
'insql', default=
"mysql.db", help=
'Input sqlite file with pedestals, in pool output dir.', type=str)
27 parser.add_argument(
'-n',
'--outsqlite', dest=
'outsql', default=
"mysql_delay.db", help=
'Output sqlite file, in pool output dir.', type=str)
28 parser.add_argument(
'-m',
'--subdet', dest=
'subdet', default=
"EMB", help=
'Subdetector, EMB, EMEC, HEC, FCAL or HECFCAL', type=str)
29 parser.add_argument(
'-s',
'--side', dest=
'side', default=
"C", help=
'Detector side empty (means both), C or A', type=str)
30 parser.add_argument(
'-c',
'--isSC', dest=
'supercells', default=
False, action=
"store_true", help=
'is SC data ?')
31 parser.add_argument(
'-a',
'--isRawdata', dest=
'rawdata', default=
False, action=
"store_true", help=
'is raw data ?')
32 parser.add_argument(
'-x',
'--ignoreBarrel', dest=
'ignoreB', default=
False, action=
"store_true", help=
'ignore Barrel channels ?')
33 parser.add_argument(
'-v',
'--ignoreEndcap', dest=
'ignoreE', default=
False, action=
"store_true", help=
'ignore Endcap channels ?')
34 parser.add_argument(
'-b',
'--badchansqlite', dest=
'badsql', default=
"SnapshotBadChannel.db", help=
'Output sqlite file, in pool output dir.', type=str)
35 parser.add_argument(
'--FW6', dest=
'fw6', default=
False, help=
'Is it for fw v. 6', action=
'store_true')
36 parser.add_argument(
'--EMF', dest=
'emf', default=
False, help=
'Is it for EMF', action=
'store_true')
37 parser.add_argument(
'--pulseAll', dest=
'pulseall', default=
False, help=
'Is it PulseAll run ?', action=
'store_true')
39 args = parser.parse_args()
40 if help
in args
and args.help
is not None and args.help:
44 for _, value
in args._get_kwargs():
49 args.run = args.run.zfill(8)
55 gain=args.gain.lower().capitalize()
56 if not args.supercells:
57 partstr = args.partition
59 partstr = args.partition+
"-DT"
63 InputDir = args.dprefix+args.fprefix+
"/calibration_LArElec-Delay-32s-"+gain+
"-"+partstr+
"/"+args.run+
"/"+args.fprefix+
"."+args.run+
".calibration_LArElec-Delay-32s-"+gain+
"-"+partstr+
".daq.RAW/"
66 from LArCalibProcessing.LArCalib_Delay_OFCCaliConfig
import LArDelay_OFCCaliCfg
69 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
72 from AthenaConfiguration.AllConfigFlags
import initConfigFlags
73 from LArCalibProcessing.LArCalibConfigFlags
import addLArCalibFlags
79 flags.LArCalib.Input.Dir = InputDir
80 flags.LArCalib.Input.Type = args.trig
81 flags.LArCalib.Input.RunNumbers = [
int(args.run),]
82 flags.LArCalib.Input.Database = args.outpdir +
"/" +args.insql
83 flags.LArCalib.Input.isRawData = args.rawdata
84 gainNumMap={
"HIGH":0,
"MEDIUM":1,
"LOW":2}
85 flags.LArCalib.Gain=gainNumMap[args.gain.upper()]
89 flags.Input.Files=flags.LArCalib.Input.Files
91 print (
"Input files to be processed:")
92 for f
in flags.Input.Files:
95 if len(flags.Input.Files) == 0 :
96 print(
"Unable to find any input files. Please check the input directory:",InputDir)
101 if not flags.LArCalib.isSC:
102 if args.subdet ==
'EMB' or args.subdet ==
'EMEC':
103 flags.LArCalib.Input.SubDet=
"EM"
105 flags.LArCalib.Input.SubDet=args.subdet
108 flags.LArCalib.Preselection.Side = [0,1]
109 elif args.side ==
"C":
110 flags.LArCalib.Preselection.Side = [0]
111 elif args.side ==
"A":
112 flags.LArCalib.Preselection.Side = [1]
114 print(
"unknown side ",args.side)
117 if args.subdet !=
"EM":
118 if args.subdet ==
'EMB':
119 flags.LArCalib.Preselection.BEC = [0]
121 flags.LArCalib.Preselection.BEC = [1]
123 if args.subdet ==
'FCAL':
124 flags.LArCalib.Preselection.FT = [6]
125 elif args.subdet ==
'HEC':
126 flags.LArCalib.Preselection.FT = [3,10,16,22]
127 elif args.subdet ==
'HECFCAL':
128 flags.LArCalib.Preselection.FT = [3,6,10,16,22]
133 if args.badsql.startswith(
"/"):
134 flags.LArCalib.BadChannelDB = args.badsql
136 flags.LArCalib.BadChannelDB = args.outpdir +
"/" + args.badsql
139 OutputCaliWaveRootFileName = args.outrwaveprefix +
"_" + args.run
140 OutputPoolFileName = args.outpprefix +
"_" + args.run
141 OutputOFCCaliRootFileName = args.outrofcprefix +
"_" + args.run
143 if args.subdet !=
"" and not flags.LArCalib.isSC:
144 OutputCaliWaveRootFileName +=
"_"+args.subdet
145 OutputPoolFileName +=
"_"+args.subdet
146 OutputOFCCaliRootFileName +=
"_"+args.subdet
148 if flags.LArCalib.Input.SubDet==
"EM":
149 OutputCaliWaveRootFileName += args.side
150 OutputPoolFileName += args.side
151 OutputOFCCaliRootFileName += args.side
153 OutputCaliWaveRootFileName +=
".root"
154 OutputPoolFileName +=
".pool.root"
155 OutputOFCCaliRootFileName +=
".root"
157 flags.LArCalib.Output.ROOTFile = args.outrdir +
"/" + OutputCaliWaveRootFileName
158 flags.LArCalib.Output.POOLFile = args.outpdir +
"/" + OutputPoolFileName
159 flags.LArCalib.Output.ROOTFile2 = args.outrdir +
"/" + OutputOFCCaliRootFileName
160 if args.outsql.startswith(
"/"):
161 flags.IOVDb.DBConnection=
"sqlite://;schema=" + args.outsql +
";dbname=CONDBR2"
163 flags.IOVDb.DBConnection=
"sqlite://;schema="+args.outpdir +
"/" + args.outsql +
";dbname=CONDBR2"
166 flags.IOVDb.GlobalTag =
"LARCALIB-RUN2-00"
170 flags.LArCalib.doValidation=
False
172 flags.LArCalib.CaliWave.Nsteps=1
173 flags.LArCalib.doOFCCali=
False
180 pdir=
'/afs/cern.ch/user/l/lardaq/public/detlar/athena/P1CalibrationProcessing/run/Patterns/EMF/EMF_Oct2024/Delay/emf/'
181 pfile = pdir+args.partition+
'/parameters.dat'
183 pdir=
'/afs/cern.ch/user/l/lardaq/public/detlar/athena/P1CalibrationProcessing/run/Patterns/P1/'
185 pdir +=
'LatomeRuns/'
186 if 'Emec' in args.partition:
187 pfile = pdir +
'emec-std/SC_HighDelay/parameters.dat'
189 pfile = pdir +
'barrel/Delay_' + args.partition[:-4] +
'/parameters.dat'
196 flags.LArCalib.Input.paramsFile = pfile
200 flags.Exec.OutputLevel = INFO
202 from AthenaConfiguration.Enums
import LHCPeriod
203 flags.GeoModel.Run = LHCPeriod.Run3
205 from AthenaConfiguration.TestDefaults
import defaultGeometryTags
206 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN3
210 flags.IOVDb.SqliteInput=
"/afs/cern.ch/user/p/pavol/public/EMF_otherCond.db"
211 flags.IOVDb.SqliteFolders = (
"/LAR/BadChannelsOfl/BadChannelsSC",
"/LAR/BadChannels/BadChannelsSC",
"/LAR/Identifier/OnOffIdMap",
"/LAR/BadChannelsOfl/MissingFEBs",
"/LAR/BadChannelsOfl/KnownMNBFEBs",
"/LAR/BadChannelsOfl/KnownBADFEBs",
"/LAR/BadChannelsOfl/BadChannels",)
212 flags.LArCalib.CorrectBadChannels=
False
213 flags.LArCalib.doValidation=
False
216 flags.dump(evaluate=
True)
232 from IOVDbSvc.IOVDbSvcConfig
import addOverride
233 cfg.merge(
addOverride(flags,
"/LAR/Identifier/LatomeMapping",
"LARIdentifierLatomeMapping-fw6"))
237 from IOVDbSvc.IOVDbSvcConfig
import addOverride
238 cfg.merge(
addOverride(flags,
"/LAR/Identifier/LatomeMapping",
"LARIdentifierLatomeMapping-EMF"))
239 fldrs=cfg.getService(
"IOVDbSvc").Folders
240 for i
in range(0, len(fldrs)):
241 if 'Align' in fldrs[i]: fldrs[i] +=
'<forceRunNumber>9999999</forceRunNumber>'
246 cfg.getEventAlgo(
"LArRawSCDataReadingAlg").LATOMEDecoder.IgnoreBarrelChannels=args.ignoreB
248 cfg.getEventAlgo(
"LArRawSCCalibDataReadingAlg").LATOMEDecoder.IgnoreBarrelChannels=args.ignoreB
251 cfg.getEventAlgo(
"LArRawSCDataReadingAlg").LATOMEDecoder.IgnoreEndcapChannels=args.ignoreE
253 cfg.getEventAlgo(
"LArRawSCCalibDataReadingAlg").LATOMEDecoder.IgnoreEndcapChannels=args.ignoreE
255 cfg.getService(
"IOVDbSvc").DBInstance=
""
257 cfg.getService(
"MessageSvc").defaultLimit=20000
264 cmdline = ([
'/afs/cern.ch/user/l/larcalib/LArDBTools/python/BuildTagHierarchy.py',args.outpdir +
"/" + args.outsql , flags.IOVDb.GlobalTag])
267 subprocess.run(cmdline, check=
True)
268 except Exception
as e:
269 print(
'Could not create tag hierarchy in output sqlite file !!!!')