CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
DTResidualCalibration.py
Go to the documentation of this file.
1 from tools import loadCmsProcess,loadCrabCfg,loadCrabDefault,addCrabInputFile,writeCfg,prependPaths
2 from addPoolDBESSource import addPoolDBESSource
3 from CrabTask import *
4 import os
5 
7  def __init__(self, run, dir, input_db, config):
8  self.pset_name = 'dtResidualCalibration_cfg.py'
9  self.outputfile = 'residuals.root'
10  self.config = config
11  self.dir = dir
12  self.inputdb = input_db
13 
14  self.pset_template = 'CalibMuon.DTCalibration.dtResidualCalibration_cfg'
15  if hasattr(self.config,'runOnCosmics') and self.config.runOnCosmics:
16  self.pset_template = 'CalibMuon.DTCalibration.dtResidualCalibration_cosmics_cfg'
17 
18  self.process = None
19  self.crab_cfg = None
20  self.initProcess()
21  self.initCrab()
22  self.task = CrabTask(self.dir,self.crab_cfg)
23 
24  def initProcess(self):
26  self.process.GlobalTag.globaltag = self.config.globaltag
27  self.process.dtResidualCalibration.rootFileName = self.outputfile
28 
29  if hasattr(self.config,'inputVDriftDB') and self.config.inputVDriftDB:
30  addPoolDBESSource(process = self.process,
31  moduleName = 'vDriftDB',record = 'DTMtimeRcd',tag = 'vDrift',
32  connect = 'sqlite_file:%s' % os.path.basename(self.config.inputVDriftDB))
33 
34  if hasattr(self.config,'inputDBTag') and self.config.inputDBTag:
35  tag = self.config.inputDBTag
36  record = self.config.inputDBRcd
37  connect = self.config.connectStrDBTag
38  moduleName = 'customDB%s' % record
39  addPoolDBESSource(process = self.process,
40  moduleName = moduleName,record = record,tag = tag,
41  connect = connect)
42 
43  if(self.inputdb):
44  label = ''
45  if hasattr(self.config,'runOnCosmics') and self.config.runOnCosmics: label = 'cosmics'
46  addPoolDBESSource(process = self.process,
47  moduleName = 'calibDB',record = 'DTTtrigRcd',tag = 'ttrig',label = label,
48  connect = 'sqlite_file:%s' % os.path.basename(self.inputdb))
49 
50  if hasattr(self.config,'runOnRAW') and self.config.runOnRAW:
51  if hasattr(self.config,'runOnMC') and self.config.runOnMC:
52  getattr(self.process,self.config.digilabel).inputLabel = 'rawDataCollector'
53  prependPaths(self.process,self.config.digilabel)
54 
55  if hasattr(self.config,'preselection') and self.config.preselection:
56  pathsequence = self.config.preselection.split(':')[0]
57  seqname = self.config.preselection.split(':')[1]
58  self.process.load(pathsequence)
59  prependPaths(self.process,seqname)
60 
61  def initCrab(self):
62  crab_cfg_parser = loadCrabCfg()
63  loadCrabDefault(crab_cfg_parser,self.config)
64  crab_cfg_parser.set('CMSSW','pset',self.pset_name)
65  crab_cfg_parser.set('CMSSW','output_file',self.outputfile)
66  crab_cfg_parser.remove_option('USER','additional_input_files')
67  if self.inputdb:
68  addCrabInputFile(crab_cfg_parser,self.inputdb)
69 
70  if hasattr(self.config,'inputVDriftDB') and self.config.inputVDriftDB:
71  addCrabInputFile(crab_cfg_parser,self.config.inputVDriftDB)
72 
73  self.crab_cfg = crab_cfg_parser
74 
75  def writeCfg(self):
76  writeCfg(self.process,self.dir,self.pset_name)
77  #writeCfgPkl(self.process,self.dir,self.pset_name)
78 
79  def run(self):
80  self.project = self.task.run()
81  return self.project
def addCrabInputFile
Definition: tools.py:183
def loadCrabDefault
Definition: tools.py:195
def loadCmsProcess
Definition: tools.py:144
def loadCrabCfg
Definition: tools.py:178
perl if(1 lt scalar(@::datatypes))
Definition: edlooper.cc:31
def prependPaths
Definition: tools.py:154