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
|
import FWCore.ParameterSet.Config as cms
minIov = 368023
maxIov = 999999999
subSystemName = "TotemT2"
process = cms.Process('writeTotemDAQMappingMask')
process.source = cms.Source("EmptyIOVSource",
timetype = cms.string('runnumber'),
firstValue = cms.uint64(minIov),
lastValue = cms.uint64(minIov),
interval = cms.uint64(1)
)
process.MessageLogger = cms.Service("MessageLogger",
destinations = cms.untracked.vstring('cout'),
cout = cms.untracked.PSet(
threshold = cms.untracked.string('ERROR'),
)
)
# load a mapping from XML file, set dummy validity range
process.load("CalibPPS.ESProducers.totemDAQMappingESSourceXML_cfi")
process.totemDAQMappingESSourceXML.subSystem = subSystemName
process.totemDAQMappingESSourceXML.sampicSubDetId = cms.uint32(7)
process.totemDAQMappingESSourceXML.multipleChannelsPerPayload = True
process.totemDAQMappingESSourceXML.configuration = cms.VPSet(
cms.PSet(
validityRange = cms.EventRange(f"{minIov}:min - {maxIov}:max"),
mappingFileNames = cms.vstring('CondFormats/PPSObjects/xml/mapping_totem_nt2_2023_final.xml'),
maskFileNames = cms.vstring(),
)
)
#Database output service
process.load("CondCore.CondDB.CondDB_cfi")
process.CondDB.connect = "sqlite_file:CTPPSTotemT2_DAQMapping.db"
process.PoolDBOutputService = cms.Service("PoolDBOutputService",
process.CondDB,
timetype = cms.untracked.string('runnumber'),
toPut = cms.VPSet(
cms.PSet(
record = cms.string('TotemReadoutRcd'),
tag = cms.string('DiamondDAQMapping'),
label = cms.string(subSystemName)
),
cms.PSet(
record = cms.string('TotemAnalysisMaskRcd'),
tag = cms.string('AnalysisMask'),
label = cms.string(subSystemName)
)
)
)
# print the mapping and write it to DB
process.writeCTPPSTotemDAQMappingMask = cms.EDAnalyzer("WriteCTPPSTotemDAQMappingMask",
cms.PSet(
daqMappingIov = cms.uint64(minIov),
recordMap = cms.string('TotemReadoutRcd'),
recordMask = cms.string('TotemAnalysisMaskRcd'),
label = cms.string(subSystemName),
)
)
process.content = cms.EDAnalyzer("EventContentAnalyzer")
process.path = cms.Path(
process.writeCTPPSTotemDAQMappingMask
)
|