5 from AthenaConfiguration.ComponentFactory
import CompFactory
6 from AthenaConfiguration.ComponentAccumulator
import ComponentAccumulator
8 if __name__==
'__main__':
13 from AthenaCommon
import Logging
14 log = Logging.logging.getLogger(
'LArSC2Ntuple' )
16 parser = argparse.ArgumentParser(formatter_class=argparse.ArgumentDefaultsHelpFormatter)
18 parser.add_argument(
'-i',
'--indir', dest=
'indir', default=
"/eos/atlas/atlastier0/rucio/data_test/calibration_pulseall/00414414/data_test.00414414.calibration_pulseall.daq.RAW/", help=
'input files dir', type=str)
19 parser.add_argument(
'-p',
'--inprefix', dest=
'inpref', default=
"data_test", help=
'Input filenames prefix', type=str)
20 parser.add_argument(
'-y',
'--inppatt', dest=
'inppatt', default=
"lb3512", help=
'Input filenames pattern', type=str)
21 parser.add_argument(
'-f',
'--infile', dest=
'infile', default=
"", help=
'Input filename (if given indir and inprefix are ignored', type=str)
22 parser.add_argument(
'-r',
'--run', dest=
'run', default=0, help=
'Run number (if not given trying to judge from input file name)', type=int)
23 parser.add_argument(
'-m',
'--maxev', dest=
'maxev', default=-1, help=
'Max number of events to dump', type=int)
24 parser.add_argument(
'-x',
'--outlevel', dest=
'olevel', default=5, help=
'OuputLevel for dumping algo', type=int)
25 parser.add_argument(
'-o',
'--outfile', dest=
'outfile', default=
"Digits.root", help=
'Output root filename', type=str)
26 parser.add_argument(
'-s',
'--addSamples', dest=
'samples', default=
False, help=
'Add Samples to output ntuple', action=
"store_true")
27 parser.add_argument(
'-a',
'--addSampBas', dest=
'samplesBas', default=
False, help=
'Add ADC_BAS to output ntuple', action=
"store_true")
28 parser.add_argument(
'-z',
'--addEt', dest=
'Et', default=
False, help=
'Add ET to output ntuple', action=
"store_true")
29 parser.add_argument(
'-g',
'--addEtId', dest=
'EtId', default=
False, help=
'Add ET_ID to output ntuple', action=
"store_true")
30 parser.add_argument(
'-l',
'--noLatHeader', dest=
'lheader', default=
True, help=
'Add LATOME Header to output ntuple', action=
'store_false')
31 parser.add_argument(
'-b',
'--noBCID', dest=
'bcid', default=
True, help=
'Add BCID info to output ntuple', action=
'store_false')
32 parser.add_argument(
'-e',
'--expandId', dest=
'expid', default=
False, help=
'Expand online Id to fields', action=
'store_true')
33 parser.add_argument(
'-n',
'--nsamp', dest=
'nsamp', default=0, help=
'Number of samples to dump', type=int)
34 parser.add_argument(
'-c',
'--overEvNumber', dest=
'overEvN', default=
False, help=
'Overwrite event number', action=
'store_true')
35 parser.add_argument(
'-d',
'--addHash', dest=
'ahash', default=
False, help=
'Add hash number to output ntuple', action=
'store_true')
36 parser.add_argument(
'-j',
'--addOffline', dest=
'offline', default=
False, help=
'Add offline Id to output ntuple', action=
'store_true')
37 parser.add_argument(
'-k',
'--addCalib', dest=
'calib', default=
False, help=
'Add calib. info to output ntuple', action=
'store_true')
38 parser.add_argument(
'-t',
'--addGeom', dest=
'geom', default=
False, help=
'Add real geom info to output ntuple', action=
'store_true')
39 parser.add_argument(
'-u',
'--noBC', dest=
'bc', default=
False, help=
'Add Bad. chan info to output ntuple', action=
'store_true')
40 parser.add_argument(
'-w',
'--addROD', dest=
'rod', default=
False, help=
'Add ROD energies sum to output ntuple', action=
'store_true')
41 parser.add_argument(
'-v',
'--addEvTree', dest=
'evtree', default=
False, help=
'Add tree with per event info to output ntuple', action=
'store_true')
42 parser.add_argument(
'-q',
'--addNoisyRO', dest=
'noisyRO', default=
False, help=
'Add reco and info from LArNoisyROSummary to output ntuple', action=
'store_true')
43 parser.add_argument(
'--addTT', dest=
'TT', default=
False, help=
'Add info from LArTriggerTowers to output ntuple', action=
'store_true')
44 parser.add_argument(
'--EMF', dest=
'emf', default=
False, help=
'Is it for EMF', action=
'store_true')
46 args = parser.parse_args()
47 if help
in args
and args.help
is not None and args.help:
51 for _, value
in args._get_kwargs():
56 from AthenaConfiguration.AllConfigFlags
import initConfigFlags
59 from LArCafJobs.LArSCDumperFlags
import addSCDumpFlags
62 if len(args.infile) > 0:
63 flags.Input.Files = [args.infile]
64 elif len(args.inppatt) > 0:
65 from LArCalibProcessing.GetInputFiles
import GetInputFilesFromPattern
68 from LArCalibProcessing.GetInputFiles
import GetInputFilesFromPrefix
72 flags.Input.RunNumbers = [args.run]
75 from AthenaConfiguration.TestDefaults
import defaultGeometryTags
76 flags.GeoModel.AtlasVersion = defaultGeometryTags.RUN3
83 log.warning(
"Could not get DT run info, using defaults !")
84 flags.LArSCDump.doEt=
True
86 flags.LArSCDump.nSamples=args.nsamp
88 flags.LArSCDump.nSamples=5
90 flags.LArSCDump.digitsKey=
"SC"
94 flags.LArSCDump.digitsKey=
""
95 for i
in range(0,len(runinfo.streamTypes())):
96 if args.EtId
and runinfo.streamTypes()[i] ==
"SelectedEnergy":
98 flags.LArSCDump.doEt=
True
99 flags.LArSCDump.nEt=runinfo.streamLengths()[i]
100 elif args.Et
and runinfo.streamTypes()[i] ==
"Energy":
102 flags.LArSCDump.doEt=
True
103 flags.LArSCDump.nEt=runinfo.streamLengths()[i]
104 elif args.samples
and runinfo.streamTypes()[i] ==
"RawADC":
105 flags.LArSCDump.digitsKey=
"SC"
107 flags.LArSCDump.nSamples=args.nsamp
109 flags.LArSCDump.nSamples=runinfo.streamLengths()[i]
110 elif args.samplesBas
and runinfo.streamTypes()[i] ==
"ADC":
111 CKeys += [
"SC_ADC_BAS"]
113 flags.LArSCDump.nSamples=args.nsamp
115 flags.LArSCDump.nSamples=runinfo.streamLengths()[i]
116 if args.nsamp > 0
and args.nsamp < flags.LArSCDump.nSamples:
117 flags.LArSCDump.nSamples=args.nsamp
119 log.info(
"Autoconfigured: ")
120 log.info(
"nSamples: %d nEt: %d digitsKey %s",flags.LArSCDump.nSamples, flags.LArSCDump.nEt, flags.LArSCDump.digitsKey)
127 if args.samplesBas
and "SC_ADC_BAS" not in CKeys:
128 CKeys += [
"SC_ADC_BAS"]
129 if args.Et
and "SC_ET" not in CKeys:
131 if args.EtId
and "SC_ET_ID" not in CKeys:
132 CKeys += [
"SC_ET_ID"]
133 if args.lheader
and "SC_LATOME_HEADER" not in CKeys:
134 CKeys += [
"SC_LATOME_HEADER"]
137 flags.LArSCDump.doRawChan=
True
138 CKeys += [
"LArRawChannels"]
139 log.info(
"Adding ROD energies")
142 flags.LAr.doAlign=
False
145 flags.Trigger.triggerConfig =
'DB'
146 flags.Trigger.L1.doCTP =
True
147 flags.Trigger.L1.doMuon =
False
148 flags.Trigger.L1.doCalo =
False
149 flags.Trigger.L1.doTopo =
False
151 flags.Trigger.enableL1CaloLegacy =
True
152 flags.Trigger.enableL1CaloPhase1 =
False
155 flags.Trigger.L1.doCalo =
True
156 flags.Trigger.triggerConfig =
'DB'
158 flags.LArSCDump.fillNoisyRO=args.noisyRO
161 flags.Exec.OutputLevel=args.olevel
168 flags.IOVDb.SqliteInput=
"/afs/cern.ch/user/p/pavol/public/EMF_otherCond.db"
169 flags.IOVDb.SqliteFolders = (
"/LAR/BadChannelsOfl/BadChannelsSC",
"/LAR/BadChannels/BadChannelsSC",
"/LAR/Identifier/OnOffIdMap",)
172 flags.dump(
'LArSCDump.*')
176 from AthenaConfiguration.MainServicesConfig
import MainServicesCfg
177 from LArGeoAlgsNV.LArGMConfig
import LArGMCfg
183 from LArCafJobs.LArSCDumperSkeleton
import L1CaloMenuCfg
185 from TrigDecisionTool.TrigDecisionToolConfig
import TrigDecisionToolCfg
192 from LArBadChannelTool.LArBadChannelConfig
import LArBadFebCfg, LArBadChannelCfg
197 acc.addCondAlgo(CompFactory.CaloAlignCondAlg(LArAlignmentStore=
"",CaloCellPositionShiftFolder=
""))
198 acc.addCondAlgo(CompFactory.CaloSuperCellAlignCondAlg())
200 from LArCalibTools.LArSC2NtupleConfig
import LArSC2NtupleCfg
201 acc.merge(
LArSC2NtupleCfg(flags, isEmf = args.emf, AddBadChannelInfo=args.bc, AddFEBTempInfo=
False, isSC=
True, isFlat=
False,
202 OffId=args.offline, AddHash=args.ahash, AddCalib=args.calib, RealGeometry=args.geom, ExpandId=args.expid,
203 NSamples=flags.LArSCDump.nSamples, FTlist=[], FillBCID=args.bcid, ContainerKey=flags.LArSCDump.digitsKey,
204 SCContainerKeys=CKeys, OverwriteEventNumber = args.overEvN,
205 FillRODEnergy = flags.LArSCDump.doRawChan,
206 FillLB=args.evtree, FillTriggerType = args.evtree,
207 TrigNames=[
"L1_EM3",
"L1_EM7",
"L1_EM15",
"L1_EM22VHI",
"L1_eEM5",
"L1_eEM15",
"L1_eEM22M"],
208 TrigDecisionTool=tdt, FillTriggerTowers = args.TT,
209 OutputLevel=args.olevel
212 if os.path.exists(args.outfile):
213 os.remove(args.outfile)
214 acc.addService(CompFactory.NTupleSvc(Output = [
"FILE1 DATAFILE='"+args.outfile+
"' OPT='NEW'" ]))
215 acc.setAppProperty(
"HistogramPersistency",
"ROOT")
218 log.info(
"Input files to be processed:")
219 for f
in flags.Input.Files:
221 log.info(
"Output file: ")
222 log.info(args.outfile)