Line Code
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
#! /usr/bin/env cmsRun
# Author: Izaak Neutelings (March 2020)
import FWCore.ParameterSet.Config as cms
from Configuration.StandardSequences.Eras import eras

# SETTINGS
run       = 313000
era       = eras.Run2_2017
verbose   = False #or True
threshold = 'INFO' if verbose else 'WARNING'
print(">>> run = %s"%run)

# LOAD PROCESS
process = cms.Process("SiPixelVCalReader",era)
process.load("FWCore.MessageService.MessageLogger_cfi")
process.load("Configuration.StandardSequences.GeometryDB_cff")
#process.load("Configuration.StandardSequences.GeometryIdeal_cff")
#process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
process.load("Configuration.StandardSequences.FrontierConditions_GlobalTag_cff")
#process.load("CondTools.SiPixel.SiPixelGainCalibrationService_cfi")
process.load("CondCore.CondDB.CondDB_cfi")

# BASIC SETTINGS
process.source = cms.Source("EmptyIOVSource",
    firstValue = cms.uint64(run),
    lastValue = cms.uint64(run),
    #firstRun = cms.untracked.uint32(run),
    timetype = cms.string('runnumber'),
    interval = cms.uint64(1),
)
###process.source = cms.Source("EmptySource",
###    #lastRun = cms.untracked.uint32(1),
###    #timetype = cms.string('runnumber'),
###    #interval = cms.uint32(1),
###    firstRun = cms.untracked.uint32(run) # select the geometry for Phase-I pixels
###)
process.maxEvents = cms.untracked.PSet(
    input = cms.untracked.int32(1)
)

# GLOBAL TAG
from Configuration.AlCa.GlobalTag import GlobalTag
#from Configuration.AlCa.autoCond import autoCond
#process.GlobalTag.globaltag = "auto:run2_data'" #autoCond['run2_design']
# In case you of conditions missing, or if you want to test a specific GT
#process.GlobalTag.globaltag = 'PRE_DES72_V6'
process.GlobalTag = GlobalTag(process.GlobalTag,'auto:run2_data','')
print(">>> globaltag = '%s'"%(process.GlobalTag.globaltag))

# EXTRA
outfile = "siPixelVCal.root"
print(">>> outfile = '%s'"%outfile)
process.TFileService = cms.Service("TFileService",
    fileName = cms.string(outfile)
)
process.MessageLogger = cms.Service("MessageLogger",
    cerr = cms.untracked.PSet(
        enable = cms.untracked.bool(False)
    ),
    cout = cms.untracked.PSet(
        enable = cms.untracked.bool(True),
        threshold = cms.untracked.string('WARNING')
    )
)
process.Timing = cms.Service("Timing")

# READER
sqlfile = "sqlite_file:siPixelVCal.db"
print(">>> sqlfile = '%s'"%sqlfile)
process.VCalReaderSource = cms.ESSource("PoolDBESSource",
    #BlobStreamerName = cms.untracked.string('TBufferBlobStreamingService'),
    DBParameters = cms.PSet(
        messageLevel = cms.untracked.int32(0),
        authenticationPath = cms.untracked.string('')
    ),
    connect = cms.string(sqlfile),
    toGet = cms.VPSet(
        cms.PSet(
            record = cms.string("SiPixelVCalRcd"),
            #tag = cms.string("trivial_VCal")
            tag = cms.string("SiPixelVCal_v1")
            #tag = cms.string("SiPixelVCal_2015_v2")
        ),
        #cms.PSet(
        #    record = cms.string("SiPixelVCalSimRcd"),
        #    tag = cms.string("trivial_VCal_Sim")
        #)
    ),
)
process.myprefer = cms.ESPrefer("PoolDBESSource","VCalReaderSource")

process.VCalReader = cms.EDAnalyzer("SiPixelVCalReader",
    printDebug = cms.untracked.bool(False),
    useSimRcd = cms.bool(False)
)
#process.VCalSimReader = cms.EDAnalyzer("SiPixelVCalReader",
#    printDebug = cms.untracked.bool(False),
#    useSimRcd = cms.bool(True)                                    
#)

#process.p = cms.Path(process.VCalReader*process.VCalSimReader)
process.p = cms.Path(process.VCalReader)