The Gaudi Framework  v30r3 (a5ef0a68)
Gaudi.Main.gaudimain Class Reference
Inheritance diagram for Gaudi.Main.gaudimain:
Collaboration diagram for Gaudi.Main.gaudimain:

Public Member Functions

def __init__ (self)
 
def setupParallelLogging (self)
 
def generatePyOutput (self, all=False)
 
def generateOptsOutput (self, all=False)
 
def printconfig (self, old_format=False, all=False)
 
def writeconfig (self, filename, all=False)
 
def run (self, attach_debugger, ncpus=None)
 
def hookDebugger (self, debugger='gdb')
 
def basicInit (self)
 
def gaudiPythonInit (self)
 
def runSerial (self, attach_debugger)
 
def runParallel (self, ncpus)
 

Public Attributes

 log
 
 printsequence
 
 ip
 
 g
 

Static Public Attributes

 mainLoop = None
 

Private Member Functions

def _writepickle (self, filename)
 

Detailed Description

Definition at line 164 of file Main.py.

Constructor & Destructor Documentation

def Gaudi.Main.gaudimain.__init__ (   self)

Definition at line 168 of file Main.py.

168  def __init__(self):
169  from Configurables import ApplicationMgr
170  appMgr = ApplicationMgr()
171  if "GAUDIAPPNAME" in os.environ:
172  appMgr.AppName = str(os.environ["GAUDIAPPNAME"])
173  if "GAUDIAPPVERSION" in os.environ:
174  appMgr.AppVersion = str(os.environ["GAUDIAPPVERSION"])
175  self.log = logging.getLogger(__name__)
176  self.printsequence = False
177 
The Application Manager class.
def __init__(self)
Definition: Main.py:168

Member Function Documentation

def Gaudi.Main.gaudimain._writepickle (   self,
  filename 
)
private

Definition at line 231 of file Main.py.

231  def _writepickle(self, filename):
232  # --- Lets take the first file input file as the name of the pickle file
233  import pickle
234  output = open(filename, 'wb')
235  # Dump only the the configurables that make sense to dump (not User ones)
236  from GaudiKernel.Proxy.Configurable import getNeededConfigurables
237  to_dump = {}
238  for n in getNeededConfigurables():
239  to_dump[n] = Configuration.allConfigurables[n]
240  pickle.dump(to_dump, output, -1)
241  output.close()
242 
def _writepickle(self, filename)
Definition: Main.py:231
getNeededConfigurables
Definition: Proxy.py:20
def Gaudi.Main.gaudimain.basicInit (   self)
Bootstrap the application with minimal use of Python bindings.

Definition at line 294 of file Main.py.

294  def basicInit(self):
295  '''
296  Bootstrap the application with minimal use of Python bindings.
297  '''
298  try:
299  from GaudiKernel.Proxy.Configurable import expandvars
300  except ImportError:
301  # pass-through implementation if expandvars is not defined (AthenaCommon)
302  def expandvars(data): return data
303 
304  from GaudiKernel.Proxy.Configurable import Configurable, getNeededConfigurables
305 
306  global _bootstrap
307  if _bootstrap is None:
308  _bootstrap = BootstrapHelper()
309 
310  self.log.debug('basicInit: instantiate ApplicationMgr')
311  self.ip = self.g = _bootstrap.createApplicationMgr()
312 
313  self.log.debug('basicInit: apply options')
314 
315  # set ApplicationMgr properties
316  comp = 'ApplicationMgr'
317  props = Configurable.allConfigurables.get(comp, {})
318  if props:
319  props = expandvars(props.getValuedProperties())
320  for p, v in props.items() + [('JobOptionsType', 'NONE')]:
321  if not self.g.setProperty(p, str(v)):
322  self.log.error('Cannot set property %s.%s to %s', comp, p, v)
323  sys.exit(10)
324  # issue with missing dictionary with ROOT < 6.2.7
325  if _bootstrap.ROOT_VERSION < (6, 2, 7):
326  # we need to load GaudiPython
327  import GaudiPython
328 
329  self.g.configure()
330 
331  # set MessageSvc properties
332  comp = 'MessageSvc'
333  msp = self.g.getService(comp)
334  if not msp:
335  self.log.error('Cannot get service %s', comp)
336  sys.exit(10)
337  props = Configurable.allConfigurables.get(comp, {})
338  if props:
339  props = expandvars(props.getValuedProperties())
340  for p, v in props.items():
341  if not _bootstrap.setProperty(msp, p, str(v)):
342  self.log.error('Cannot set property %s.%s to %s', comp, p, v)
343  sys.exit(10)
344 
345  # feed JobOptionsSvc
346  comp = 'JobOptionsSvc'
347  jos = self.g.getService(comp)
348  if not jos:
349  self.log.error('Cannot get service %s', comp)
350  sys.exit(10)
351  for n in getNeededConfigurables():
352  c = Configurable.allConfigurables[n]
353  if n in ['ApplicationMgr', 'MessageSvc']:
354  continue # These are already done
355  for p, v in c.getValuedProperties().items():
356  v = expandvars(v)
357  # Note: AthenaCommon.Configurable does not have Configurable.PropertyReference
358  if hasattr(Configurable, "PropertyReference") and type(v) == Configurable.PropertyReference:
359  # this is done in "getFullName", but the exception is ignored,
360  # so we do it again to get it
361  v = v.__resolve__()
362  if type(v) == str:
363  v = '"%s"' % v # need double quotes
364  elif type(v) == long:
365  v = '%d' % v # prevent pending 'L'
366  _bootstrap.addPropertyToCatalogue(jos, n, p, str(v))
367  if hasattr(Configurable, "_configurationLocked"):
368  Configurable._configurationLocked = True
369  self.log.debug('basicInit: done')
370 
def basicInit(self)
Definition: Main.py:294
getNeededConfigurables
Definition: Proxy.py:20
def Gaudi.Main.gaudimain.gaudiPythonInit (   self)
Initialize the application with full Python bindings.

Definition at line 371 of file Main.py.

371  def gaudiPythonInit(self):
372  '''
373  Initialize the application with full Python bindings.
374  '''
375  self.log.debug('gaudiPythonInit: import GaudiPython')
376  import GaudiPython
377  self.log.debug('gaudiPythonInit: instantiate ApplicationMgr')
378  self.g = GaudiPython.AppMgr()
379  self.ip = self.g._ip
380  self.log.debug('gaudiPythonInit: done')
381 
def gaudiPythonInit(self)
Definition: Main.py:371
def Gaudi.Main.gaudimain.generateOptsOutput (   self,
  all = False 
)

Definition at line 218 of file Main.py.

218  def generateOptsOutput(self, all=False):
219  from pprint import pformat
220  conf_dict = Configuration.configurationDict(all)
221  out = []
222  names = conf_dict.keys()
223  names.sort()
224  for n in names:
225  props = conf_dict[n].keys()
226  props.sort()
227  for p in props:
228  out.append('%s.%s = %s;' % (n, p, toOpt(conf_dict[n][p])))
229  return "\n".join(out)
230 
def toOpt(value)
Definition: Main.py:141
def generateOptsOutput(self, all=False)
Definition: Main.py:218
def Gaudi.Main.gaudimain.generatePyOutput (   self,
  all = False 
)

Definition at line 213 of file Main.py.

213  def generatePyOutput(self, all=False):
214  from pprint import pformat
215  conf_dict = Configuration.configurationDict(all)
216  return pformat(conf_dict)
217 
def generatePyOutput(self, all=False)
Definition: Main.py:213
def Gaudi.Main.gaudimain.hookDebugger (   self,
  debugger = 'gdb' 
)

Definition at line 279 of file Main.py.

279  def hookDebugger(self, debugger='gdb'):
280  import os
281  self.log.info('attaching debugger to PID ' + str(os.getpid()))
282  pid = os.spawnvp(os.P_NOWAIT,
283  debugger, [debugger, '-q', 'python', str(os.getpid())])
284 
285  # give debugger some time to attach to the python process
286  import time
287  time.sleep(5)
288 
289  # verify the process' existence (will raise OSError if failed)
290  os.waitpid(pid, os.WNOHANG)
291  os.kill(pid, 0)
292  return
293 
def hookDebugger(self, debugger='gdb')
Definition: Main.py:279
def Gaudi.Main.gaudimain.printconfig (   self,
  old_format = False,
  all = False 
)

Definition at line 243 of file Main.py.

243  def printconfig(self, old_format=False, all=False):
244  msg = 'Dumping all configurables and properties'
245  if not all:
246  msg += ' (different from default)'
247  log.info(msg)
248  conf_dict = Configuration.configurationDict(all)
249  if old_format:
250  print self.generateOptsOutput(all)
251  else:
252  print self.generatePyOutput(all)
253 
def generateOptsOutput(self, all=False)
Definition: Main.py:218
def generatePyOutput(self, all=False)
Definition: Main.py:213
def printconfig(self, old_format=False, all=False)
Definition: Main.py:243
def Gaudi.Main.gaudimain.run (   self,
  attach_debugger,
  ncpus = None 
)

Definition at line 270 of file Main.py.

270  def run(self, attach_debugger, ncpus=None):
271  if not ncpus:
272  # Standard sequential mode
273  result = self.runSerial(attach_debugger)
274  else:
275  # Otherwise, run with the specified number of cpus
276  result = self.runParallel(ncpus)
277  return result
278 
def run(self, attach_debugger, ncpus=None)
Definition: Main.py:270
def runParallel(self, ncpus)
Definition: Main.py:453
def runSerial(self, attach_debugger)
Definition: Main.py:382
def Gaudi.Main.gaudimain.runParallel (   self,
  ncpus 
)

Definition at line 453 of file Main.py.

453  def runParallel(self, ncpus):
454  if self.mainLoop:
455  self.log.fatal(
456  "Cannot use custom main loop in multi-process mode, check your options")
457  return 1
458  self.setupParallelLogging()
459  from Gaudi.Configuration import Configurable
460  import GaudiMP.GMPBase as gpp
461  c = Configurable.allConfigurables
462  self.log.info('-' * 80)
463  self.log.info('%s: Parallel Mode : %i ', __name__, ncpus)
464  for name, value in [('platrofm', ' '.join(os.uname())),
465  ('config', os.environ.get('BINARY_TAG') or
466  os.environ.get('CMTCONFIG')),
467  ('app. name', os.environ.get('GAUDIAPPNAME')),
468  ('app. version', os.environ.get('GAUDIAPPVERSION')),
469  ]:
470  self.log.info('%s: %30s : %s ', __name__,
471  name, value or 'Undefined')
472  try:
473  events = str(c['ApplicationMgr'].EvtMax)
474  except:
475  events = "Undetermined"
476  self.log.info('%s: Events Specified : %s ', __name__, events)
477  self.log.info('-' * 80)
478  # Parall = gpp.Coordinator(ncpus, shared, c, self.log)
479  Parall = gpp.Coord(ncpus, c, self.log)
480  sysStart = time()
481  sc = Parall.Go()
482  self.log.info('MAIN.PY : received %s from Coordinator' % (sc))
483  if sc.isFailure():
484  return 1
485  sysTime = time() - sysStart
486  self.log.name = 'Gaudi/Main.py Logger'
487  self.log.info('-' * 80)
488  self.log.info(
489  '%s: parallel system finished, time taken: %5.4fs', __name__, sysTime)
490  self.log.info('-' * 80)
491  return 0
def Gaudi.Main.gaudimain.runSerial (   self,
  attach_debugger 
)

Definition at line 382 of file Main.py.

382  def runSerial(self, attach_debugger):
383  # --- Instantiate the ApplicationMgr------------------------------
384  if (self.mainLoop or
385  os.environ.get('GAUDIRUN_USE_GAUDIPYTHON')):
386  self.gaudiPythonInit()
387  else:
388  self.basicInit()
389 
390  self.log.debug('-' * 80)
391  self.log.debug('%s: running in serial mode', __name__)
392  self.log.debug('-' * 80)
393  sysStart = time()
394 
395  if self.mainLoop:
396  runner = self.mainLoop
397  else:
398  def runner(app, nevt):
399  self.log.debug('initialize')
400  sc = app.initialize()
401  if sc.isSuccess():
402  if self.printsequence:
403  app.printAlgsSequences()
404  self.log.debug('start')
405  sc = app.start()
406  if sc.isSuccess():
407  self.log.debug('run(%d)', nevt)
408  sc = app.run(nevt)
409  self.log.debug('stop')
410  app.stop().ignore()
411  self.log.debug('finalize')
412  app.finalize().ignore()
413  self.log.debug('terminate')
414  sc1 = app.terminate()
415  if sc.isSuccess():
416  sc = sc1
417  else:
418  sc1.ignore()
419  self.log.debug('status code: %s',
420  'SUCCESS' if sc.isSuccess() else 'FAILURE')
421  return sc
422 
423  if (attach_debugger == True):
424  self.hookDebugger()
425 
426  try:
427  statuscode = runner(self.g, int(
428  self.ip.getProperty('EvtMax').toString()))
429  except SystemError:
430  # It may not be 100% correct, but usually it means a segfault in C++
431  self.ip.setProperty('ReturnCode', str(128 + 11))
432  statuscode = False
433  except Exception, x:
434  print 'Exception:', x
435  # for other exceptions, just set a generic error code
436  self.ip.setProperty('ReturnCode', '1')
437  statuscode = False
438  if hasattr(statuscode, "isSuccess"):
439  success = statuscode.isSuccess()
440  else:
441  success = statuscode
442  #success = self.g.exit().isSuccess() and success
443  if not success and self.ip.getProperty('ReturnCode').toString() == '0':
444  # ensure that the return code is correctly set
445  self.ip.setProperty('ReturnCode', '1')
446  sysTime = time() - sysStart
447  self.log.debug('-' * 80)
448  self.log.debug(
449  '%s: serial system finished, time taken: %5.4fs', __name__, sysTime)
450  self.log.debug('-' * 80)
451  return int(self.ip.getProperty('ReturnCode').toString())
452 
def basicInit(self)
Definition: Main.py:294
def gaudiPythonInit(self)
Definition: Main.py:371
def hookDebugger(self, debugger='gdb')
Definition: Main.py:279
std::string toString(const Type &)
def runSerial(self, attach_debugger)
Definition: Main.py:382
def Gaudi.Main.gaudimain.setupParallelLogging (   self)

Definition at line 178 of file Main.py.

179  # ---------------------------------------------------
180  # set up Logging
181  # ----------------
182  # from multiprocessing import enableLogging, getLogger
183  import multiprocessing
184  # preliminaries for handlers/output files, etc.
185  from time import ctime
186  datetime = ctime()
187  datetime = datetime.replace(' ', '_')
188  outfile = open('gaudirun-%s.log' % (datetime), 'w')
189  # two handlers, one for a log file, one for terminal
190  streamhandler = logging.StreamHandler(stream=outfile)
191  console = logging.StreamHandler()
192  # create formatter : the params in parentheses are variable names available via logging
193  formatter = logging.Formatter(
194  "%(asctime)s - %(name)s - %(levelname)s - %(message)s")
195  # add formatter to Handler
196  streamhandler.setFormatter(formatter)
197  console.setFormatter(formatter)
198  # now, configure the logger
199  # enableLogging( level=0 )
200  # self.log = getLogger()
201  self.log = multiprocessing.log_to_stderr()
202  self.log.setLevel(logging.INFO)
203  self.log.name = 'Gaudi/Main.py Logger'
204  self.log.handlers = []
205  # add handlers to logger : one for output to a file, one for console output
206  self.log.addHandler(streamhandler)
207  self.log.addHandler(console)
208  self.log.removeHandler(console)
209  # set level!!
210  self.log.setLevel = logging.INFO
211  # ---------------------------------------------------
212 
def setupParallelLogging(self)
Definition: Main.py:178
def Gaudi.Main.gaudimain.writeconfig (   self,
  filename,
  all = False 
)

Definition at line 254 of file Main.py.

254  def writeconfig(self, filename, all=False):
255  write = {".pkl": lambda filename, all: self._writepickle(filename),
256  ".py": lambda filename, all: open(filename, "w").write(self.generatePyOutput(all) + "\n"),
257  ".opts": lambda filename, all: open(filename, "w").write(self.generateOptsOutput(all) + "\n"),
258  }
259  from os.path import splitext
260  ext = splitext(filename)[1]
261  if ext in write:
262  write[ext](filename, all)
263  else:
264  log.error("Unknown file type '%s'. Must be any of %r.",
265  ext, write.keys())
266  sys.exit(1)
267 
def _writepickle(self, filename)
Definition: Main.py:231
def generateOptsOutput(self, all=False)
Definition: Main.py:218
def generatePyOutput(self, all=False)
Definition: Main.py:213
def writeconfig(self, filename, all=False)
Definition: Main.py:254

Member Data Documentation

Gaudi.Main.gaudimain.g

Definition at line 311 of file Main.py.

Gaudi.Main.gaudimain.ip

Definition at line 311 of file Main.py.

Gaudi.Main.gaudimain.log

Definition at line 175 of file Main.py.

Gaudi.Main.gaudimain.mainLoop = None
static

Definition at line 166 of file Main.py.

Gaudi.Main.gaudimain.printsequence

Definition at line 176 of file Main.py.


The documentation for this class was generated from the following file: