1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
import FWCore.ParameterSet.Config as cms
#import FWCore.PythonUtilities.LumiList as LumiList
from FWCore.ParameterSet.VarParsing import VarParsing
import json
import os
##Define process
process = cms.Process("validation")
##Argument parsing
options = VarParsing()
options.register("config", "", VarParsing.multiplicity.singleton, VarParsing.varType.string , "AllInOne config")
options.parseArguments()
###Set validation mode
#valiMode = "StandAlone"
##Read in AllInOne config in JSON format
with open(options.config, "r") as configFile:
config = json.load(configFile)
##Get emptyModuleList.txt
if 'empty_modules' in config["validation"]["GCP"]:
if config["validation"]["GCP"]["empty_modules"].startswith('/store'):
os.system('xrdcp root://eoscms//eos/'+config["validation"]["GCP"]["empty_modules"])
elif config["validation"]["GCP"]["empty_modules"].startswith('root://'):
os.system('xrdcp '+config["validation"]["GCP"]["empty_modules"])
else:
os.system('cp '+config["validation"]["GCP"]["empty_modules"])
else: os.system('touch emptyModuleList.txt')
#Global tag
process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
from Configuration.AlCa.GlobalTag import GlobalTag
process.GlobalTag = GlobalTag(process.GlobalTag,config["alignments"]["comp"]["globaltag"])
process.load("Configuration.Geometry.GeometryRecoDB_cff")
process.load("CondCore.CondDB.CondDB_cfi")
process.MessageLogger = cms.Service("MessageLogger",
#destinations = cms.untracked.vstring('detailedInfo', 'cout')
destinations = cms.untracked.vstring('warnings'),
warnings = cms.untracked.PSet(
threshold = cms.untracked.string('WARNING')
)
)
process.source = cms.Source("EmptySource",
firstRun=cms.untracked.uint32(config["validation"]["IOVcomp"])
)
process.maxEvents = cms.untracked.PSet(
input = cms.untracked.int32(1)
)
process.siStripQualityESProducer.ListOfRecordToMerge=cms.VPSet(
cms.PSet(record = cms.string('SiStripDetCablingRcd'),
tag = cms.string('')),
cms.PSet(record = cms.string('RunInfoRcd'),
tag = cms.string('')),
cms.PSet(record = cms.string('SiStripBadChannelRcd'),
tag = cms.string('')),
cms.PSet(record = cms.string('SiStripBadFiberRcd'),
tag = cms.string('')),
cms.PSet(record = cms.string('SiStripBadModuleRcd'),
tag = cms.string('')),
cms.PSet(record = cms.string('SiStripBadStripRcd'),
tag = cms.string(''))
)
process.load("DQM.SiStripCommon.TkHistoMap_cff")
# configuration of the Tracker Geometry Comparison Tool
# Tracker Geometry Comparison
process.load("Alignment.OfflineValidation.TrackerGeometryCompare_cfi")
# the input "IDEAL" is special indicating to use the ideal geometry of the release
process.TrackerGeometryCompare.inputROOTFile1 = str(config['input_ref']+'/Ntuples.root')
process.TrackerGeometryCompare.inputROOTFile2 = str(config['input_comp']+'/Ntuples.root')
process.TrackerGeometryCompare.moduleList = 'emptyModuleList.txt'
process.TrackerGeometryCompare.outputFile = str(config['output'])+'/GCPtree.root'
process.TrackerGeometryCompare.levels = [ str(config['validation']['GCP']['levels']) ]
surf_dir = str(config['output'])+'/SurfDeform'
if not os.path.isdir(surf_dir):
os.mkdir(surf_dir)
process.TrackerGeometryCompare.surfDir = surf_dir
process.load("CommonTools.UtilAlgos.TFileService_cfi")
process.TFileService.fileName = cms.string("TkSurfDeform.root")
##FIXME!!!!!!!!!
##replace TrackerGeometryCompare.writeToDB = False
##removed: dbOutputService
process.p = cms.Path(process.TrackerGeometryCompare)
|