The Gaudi Framework  v28r3 (cc1cf868)
BrunelScenarioAvalancheScheduler.py
Go to the documentation of this file.
1 #!/usr/bin/env gaudirun.py
2 
3 from Gaudi.Configuration import *
4 from Configurables import HiveWhiteBoard, HiveSlimEventLoopMgr, AvalancheSchedulerSvc, AlgResourcePool
5 
6 # convenience machinery for assembling custom graphs of algorithm precedence rules (w/ CPUCrunchers as algorithms)
7 try:
8  from GaudiHive import precedence
9 except ImportError:
10  # of versions of LCG/heptools do not provide the required package networkx
11  import sys
12  sys.exit(77) # consider the test skipped
13 
14 # metaconfig
15 evtslots = 1
16 evtMax = 1
17 cardinality = 1
18 algosInFlight = 4
19 algoAvgTime = 0.02
20 
21 
22 InertMessageSvc(OutputLevel=INFO)
23 
24 whiteboard = HiveWhiteBoard("EventDataSvc",
25  EventSlots = evtslots,
26  OutputLevel = INFO,
27  ForceLeaves = True)
28 
29 slimeventloopmgr = HiveSlimEventLoopMgr(SchedulerName = "AvalancheSchedulerSvc", OutputLevel=INFO)
30 
31 scheduler = AvalancheSchedulerSvc(ThreadPoolSize = algosInFlight,
32  OutputLevel = DEBUG,
33  Optimizer = "DRE",
34  PreemptiveIOBoundTasks = False,
35  DumpIntraEventDynamics = False)
36 
37 AlgResourcePool(OutputLevel = DEBUG)
38 
39 timeValue = precedence.UniformTimeValue(algoAvgTime)
40 ifIObound = precedence.UniformBooleanValue(False)
41 #ifIObound = precedence.RndBiased10BooleanValue()
42 
43 
44 sequencer = precedence.CruncherSequence(timeValue, ifIObound, sleepFraction=0.0,
45  cfgPath = "lhcb/reco/cf_dependencies.graphml",
46  dfgPath = "lhcb/reco/data_dependencies.graphml",
47  topSequencer = 'GaudiSequencer/BrunelSequencer').get()
48 
49 ApplicationMgr( EvtMax = evtMax,
50  EvtSel = 'NONE',
51  ExtSvc = [whiteboard],
52  EventLoop = slimeventloopmgr,
53  TopAlg = [sequencer],
54  MessageSvcType = "InertMessageSvc",
55  OutputLevel = INFO)
Thread safe extension to the standard MessageSvc.
The Application Manager class.