Skip to content

Instantly share code, notes, and snippets.

@mmusich
Created June 13, 2018 16:46
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save mmusich/a654c92326cc4d92152e82b0b86e4c80 to your computer and use it in GitHub Desktop.
Save mmusich/a654c92326cc4d92152e82b0b86e4c80 to your computer and use it in GitHub Desktop.
import ConfigParser
import glob
import os
import numpy
import re
import ROOT
import subprocess
import string
import subprocess
import sys
import optparse
import time
import json
import datetime
from datetime import datetime
import CondCore.Utilities.conddblib as conddb
##############################################
def runTheComparison(startiov,endiov,tag):
##############################################
plotTypes=["SiStripApvGainsComparator",
"SiStripApvGainsValuesComparator",
"SiStripApvGainsComparatorByRegion",
"SiStripApvGainsRatioComparatorByRegion",
"SiStripApvGainsAvgDeviationRatio1sigmaTrackerMap",
"SiStripApvGainsAvgDeviationRatio2sigmaTrackerMap",
"SiStripApvGainsAvgDeviationRatio3sigmaTrackerMap",
"SiStripApvGainsMaxDeviationRatio1sigmaTrackerMap",
"SiStripApvGainsMaxDeviationRatio2sigmaTrackerMap",
"SiStripApvGainsMaxDeviationRatio3sigmaTrackerMap"]
for plot in plotTypes:
inputjson = {"start_iov": "{}".format(startiov), "end_iov": "{}".format(endiov)}
json_string = json.dumps(inputjson)
print json_string
cmd = "getPayloadData.py --plugin pluginSiStripApvGain_PayloadInspector --plot plot_{} --tag {} --time_type Run --iovs '{}' --db sqlite_file:toCompare.db --test".format(plot,tag,json_string)
print cmd
p = subprocess.Popen(cmd, stdout=subprocess.PIPE, shell=True)
out, err = p.communicate()
result = out.split('\n')
for lin in result:
if not lin.startswith('#'):
print(lin)
##############################################
def getCommandOutput(command):
##############################################
"""This function executes `command` and returns it output.
Arguments:
- `command`: Shell command to be invoked by this function.
"""
child = os.popen(command)
data = child.read()
err = child.close()
if err:
print '%s failed w/ exit code %d' % (command, err)
return data
##############################################
def getFSCR():
##############################################
out = subprocess.check_output(["curl", "-k", "-s", "https://cmsweb.cern.ch/t0wmadatasvc/prod/firstconditionsaferun"])
response = json.loads(out)["result"][0]
return int(response)
##############################################
def getPromptGT():
##############################################
out = subprocess.check_output(["curl", "-k", "-s", "https://cmsweb.cern.ch/t0wmadatasvc/prod/reco_config"])
response = json.loads(out)["result"][0]['global_tag']
return response
##############################################
def getExpressGT():
##############################################
out = subprocess.check_output(["curl", "-k", "-s", "https://cmsweb.cern.ch/t0wmadatasvc/prod/express_config"])
response = json.loads(out)["result"][0]['global_tag']
return response
##############################################
if __name__ == "__main__":
##############################################
parser = optparse.OptionParser(usage = 'Usage: %prog [options] <file> [<file> ...]\n')
parser.add_option('-t', '--validationTag',
dest = 'validationTag',
default = "SiStripApvGainAfterAbortGap_PCL_multirun_v0_prompt",
help = 'validation tag',
)
parser.add_option('-s', '--since',
dest = 'since',
default = -1,
help = 'sinces to copy from validation tag',
)
(options, arguments) = parser.parse_args()
FSCR = getFSCR()
promptGT = getPromptGT()
expressGT = getExpressGT()
print "Current FSCR:",FSCR,"| Express Global Tag",expressGT,"| Prompt Global Tag",promptGT
con = conddb.connect(url = conddb.make_url("pro"))
session = con.session()
IOV = session.get_dbtype(conddb.IOV)
TAG = session.get_dbtype(conddb.Tag)
GT = session.get_dbtype(conddb.GlobalTag)
GTMAP = session.get_dbtype(conddb.GlobalTagMap)
RUNINFO = session.get_dbtype(conddb.RunInfo)
myGTMap = session.query(GTMAP.record, GTMAP.label, GTMAP.tag_name).\
filter(GTMAP.global_tag_name == str(expressGT)).\
order_by(GTMAP.record, GTMAP.label).\
all()
## connect to prep DB and get the list of IOVs to look at
con2 = conddb.connect(url = conddb.make_url("dev"))
session2 = con2.session()
validationTagIOVs = session2.query(IOV.since,IOV.payload_hash,IOV.insertion_time).filter(IOV.tag_name == options.validationTag).all()
### fill the list of IOVs to be validated
IOVsToValidate=[]
if(options.since==-1):
IOVsToValidate.append(validationTagIOVs[-1][0])
print "changing the default validatio tag since to:",IOVsToValidate[0]
else:
for entry in validationTagIOVs:
if(options.since!=1 and int(entry[0])>int(options.since)):
print "appending to the validation list:",entry[0],entry[1],entry[2]
IOVsToValidate.append(entry[0])
for element in myGTMap:
#print element
Record = element[0]
Label = element[1]
Tag = element[2]
if(Record=="SiStripApvGain2Rcd"):
TagIOVs = session.query(IOV.since,IOV.payload_hash,IOV.insertion_time).filter(IOV.tag_name == Tag).all()
lastG2Payload = TagIOVs[-1]
print "last payload has IOV since:",lastG2Payload[0],"payload hash:",lastG2Payload[1],"insertion time:",lastG2Payload[2]
command = 'conddb_import -c sqlite_file:toCompare.db -f frontier://FrontierProd/CMS_CONDITIONS -i '+str(Tag) +' -t '+str(Tag)+' -b '+str(lastG2Payload[0])
print command
getCommandOutput(command)
for theValidationTagSince in IOVsToValidate:
command = 'conddb_import -c sqlite_file:toCompare.db -f frontier://FrontierPrep/CMS_CONDITIONS -i '+str(options.validationTag) +' -t '+str(Tag)+' -b '+str(theValidationTagSince)
print command
getCommandOutput(command)
## call the comparison
runTheComparison(str(lastG2Payload[0]),str(theValidationTagSince),str(Tag))
#command = './testCompare.sh SiStripApvGain_FromParticles_GR10_v1_express '+str(lastG2Payload[0])+' '+str(theValidationTagSince)+ ' toCompare.db'
#print command
#getCommandOutput(command)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment