The Gaudi Framework  v36r7 (7f57a304)
GaudiHive.precedence.RealTimeValue Class Reference
Inheritance diagram for GaudiHive.precedence.RealTimeValue:
Collaboration diagram for GaudiHive.precedence.RealTimeValue:

Public Member Functions

def __init__ (self, path, defaultTime, factor=1)
 
def get (self, algoName="")
 

Public Attributes

 path
 
 factor
 
 defaultTime
 
 varRuntime
 
 file
 
 timings
 

Detailed Description

A class to manage real algorithm timing

Definition at line 78 of file precedence.py.

Constructor & Destructor Documentation

◆ __init__()

def GaudiHive.precedence.RealTimeValue.__init__ (   self,
  path,
  defaultTime,
  factor = 1 
)
defaultTime -- run time, assigned to an algorithm if no time is found in provided timing library
       (and it will also be scaled by the 'factor' argument)

Definition at line 81 of file precedence.py.

81  def __init__(self, path, defaultTime, factor=1):
82  """
83  defaultTime -- run time, assigned to an algorithm if no time is found in provided timing library
84  (and it will also be scaled by the 'factor' argument)
85  """
86 
87  self.path = os.path.realpath(_buildFilePath(path))
88  self.factor = factor
89  self.defaultTime = defaultTime # typically 0.05s
90  self.varRuntime = 0
91 
92  self.file = open(self.path)
93  self.timings = json.load(self.file)
94 

Member Function Documentation

◆ get()

def GaudiHive.precedence.RealTimeValue.get (   self,
  algoName = "" 
)
Get time for a given algorithm name

Definition at line 95 of file precedence.py.

95  def get(self, algoName=""):
96  """Get time for a given algorithm name"""
97 
98  if algoName in self.timings:
99  time = float(self.timings[algoName])
100  else:
101  capAlgoName = algoName[0].upper() + algoName[1 : len(algoName)]
102 
103  if capAlgoName in self.timings:
104  time = float(self.timings[capAlgoName])
105  else:
106  time = self.defaultTime
107  print(
108  "WARNING: Timing for %s (or %s) not found in the provided library, using default one: %s"
109  % (algoName, capAlgoName, time)
110  )
111 
112  time = time * self.factor
113 
114  return time, self.varRuntime
115 
116 

Member Data Documentation

◆ defaultTime

GaudiHive.precedence.RealTimeValue.defaultTime

Definition at line 89 of file precedence.py.

◆ factor

GaudiHive.precedence.RealTimeValue.factor

Definition at line 88 of file precedence.py.

◆ file

GaudiHive.precedence.RealTimeValue.file

Definition at line 92 of file precedence.py.

◆ path

GaudiHive.precedence.RealTimeValue.path

Definition at line 87 of file precedence.py.

◆ timings

GaudiHive.precedence.RealTimeValue.timings

Definition at line 93 of file precedence.py.

◆ varRuntime

GaudiHive.precedence.RealTimeValue.varRuntime

Definition at line 90 of file precedence.py.


The documentation for this class was generated from the following file:
GaudiHive.precedence._buildFilePath
def _buildFilePath(filePath)
Definition: precedence.py:29
Gaudi::Functional::details::get
auto get(const Handle &handle, const Algo &, const EventContext &) -> decltype(details::deref(handle.get()))
Definition: FunctionalDetails.h:444