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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
# Config file template to produce a treeFile.root usable as input for
# .../CMSSW/Alignment/MillePedeAlignmentAlgorithm/macros/CompareMillePede.h
# to compare two different geometries.
#
# last update on $Date: 2010/12/14 01:36:38 $ by $Author: flucke $
import FWCore.ParameterSet.Config as cms
process = cms.Process("Alignment")
process.options = cms.untracked.PSet(
Rethrow = cms.untracked.vstring("ProductNotFound") # do not accept this exception
)
# initialize MessageLogger
process.load("FWCore.MessageService.MessageLogger_cfi")
process.MessageLogger.files.alignment = cms.untracked.PSet(
DEBUG = cms.untracked.PSet(
limit = cms.untracked.int32(-1)
),
INFO = cms.untracked.PSet(
limit = cms.untracked.int32(5),
reportEvery = cms.untracked.int32(5)
),
WARNING = cms.untracked.PSet(
limit = cms.untracked.int32(10)
),
ERROR = cms.untracked.PSet(
limit = cms.untracked.int32(-1)
),
Alignment = cms.untracked.PSet(
limit = cms.untracked.int32(-1),
reportEvery = cms.untracked.int32(1)
),
enableStatistics = cms.untracked.bool(True)
)
# initialize magnetic field
process.load("Configuration.StandardSequences.MagneticField_cff")
# geometry
process.load("Configuration.Geometry.GeometryRecoDB_cff")
# global tag and other conditions
process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
process.GlobalTag.globaltag = 'DESIGN42_V12::All' # take your favourite
# if alignment constants not from global tag, add this
from CondCore.DBCommon.CondDBSetup_cfi import *
# CondDBSetup.DBParameters.authenticationPath = '...' # needed to access cms_orcoff_prod
process.trackerAlignment = cms.ESSource(
"PoolDBESSource",
CondDBSetup,
# connect = cms.string("sqlite_file:TrackerAlignment_GR10v6_offline_append.db"),
connect = cms.string("frontier://FrontierProd/CMS_COND_31X_ALIGNMENT"),
# connect = cms.string("oracle://cms_orcoff_prod/CMS_COND_31X_ALIGNMENT"),
toGet = cms.VPSet(cms.PSet(record = cms.string("TrackerAlignmentRcd"),
tag = cms.string("TrackerAlignment_GR10_v6_offline")
# tag = cms.string("Alignments")
# ),
# cms.PSet(record = cms.string("TrackerAlignmentErrorExtendedRcd"),
# tag = cms.string("TrackerIdealGeometryErrors210_mc")
)
)
)
process.es_prefer_trackerAlignment = cms.ESPrefer("PoolDBESSource", "trackerAlignment")
# Alignment producer
process.load("Alignment.CommonAlignmentProducer.AlignmentProducer_cff")
process.AlignmentProducer.ParameterBuilder.Selector = cms.PSet(
alignParams = cms.vstring(
'TrackerTPBModule,111111',
'TrackerTPEModule,111111',
'TrackerTIBModuleUnit,101111',
'TrackerTIDModuleUnit,101111',
'TrackerTOBModuleUnit,101111',
'TrackerTECModuleUnit,101111'
)
)
process.AlignmentProducer.doMisalignmentScenario = False #True
process.AlignmentProducer.applyDbAlignment = True # either globalTag or trackerAlignment
# assign by reference (i.e. could change MillePedeAlignmentAlgorithm as well):
process.AlignmentProducer.algoConfig = process.MillePedeAlignmentAlgorithm
process.AlignmentProducer.algoConfig.mode = 'pedeRead'
process.AlignmentProducer.algoConfig.pedeReader.readFile = 'FILE_MUST_NOT_EXIST.res'
process.AlignmentProducer.algoConfig.treeFile = 'my_treeFile.root'
process.source = cms.Source("EmptySource",
firstRun = cms.untracked.uint32(170249) # choose your run!
)
process.maxEvents = cms.untracked.PSet(input = cms.untracked.int32(1) )
process.dump = cms.EDAnalyzer("EventContentAnalyzer")
process.p = cms.Path(process.dump)
process.AlignmentProducer.saveToDB = True # should not be needed, but is:
# otherwise AlignmentProducer does not call relevant algorithm part
process.PoolDBOutputService = cms.Service(
"PoolDBOutputService",
CondDBSetup,
timetype = cms.untracked.string('runnumber'),
connect = cms.string('sqlite_file:remove_me.db'),
toPut = cms.VPSet(cms.PSet(
record = cms.string('TrackerAlignmentRcd'),
tag = cms.string('dummyTagAlignment')
)
)
)
|