Back to home page

Project CMSSW displayed by LXR

 
 

    


File indexing completed on 2021-08-10 22:50:00

0001 #!/usr/bin/env python3
0002 
0003 import sys, os, re
0004 
0005 from optparse import OptionParser # Command line parsing
0006 usage = "usage: %prog summary files"
0007 version = "%prog."
0008 parser = OptionParser(usage=usage,version=version)
0009 parser.add_option("-p", "--printDataSets", action="store_true", dest="printDS", default=False, help="Print datasets without attempting to download.")
0010 parser.add_option("-M", "--MC", action="store_true", dest="getMC", default=False, help="Get DQM files for MC campaign.")
0011 parser.add_option("-D", "--DATA", action="store_true", dest="getDATA", default=False, help="Get DQM files for DATA campaign.")
0012 parser.add_option("-2", "--2023", action="store_true", dest="get2023", default=False, help="Get DQM files for 2023 campaign.")
0013 (options, args) = parser.parse_args()
0014 
0015 ##Begin declaration of Functions
0016 
0017 #getDataSets if used to discover and download the datasets. It is seperated as a function so that we can easily switch between
0018 #MC and DATA datasets
0019 
0020 def getDataSets( dsFlags = {'RelValMinBias_13__':'MinBias'},
0021                  curl = "/usr/bin/curl -O -L --capath %(CERT_DIR)s --key %(USER_PROXY)s --cert %(USER_PROXY)s https://cmsweb.cern.ch/dqm/relval/data/browse/ROOT/RelVal/%(relValDIR)s",
0022                  ofnBlank = "HcalRecHitValidationRelVal_%(sample)s_%(label)s_%(info)s.root",
0023                  label = "CMSSW_X_Y_Z",
0024                  slabel = "XYZ",
0025                  X509_CERT_DIR = os.getenv('X509_CERT_DIR', "/etc/grid-security/certificates"),
0026                  X509_USER_PROXY = os.getenv('X509_USER_PROXY'),
0027                  relValDIR = "CMSSW_?_?_x",
0028                  printDS = False,
0029                  camType = "MC"):
0030                
0031     print ("Taking filenames from directory %s"%relValDIR)
0032 
0033     # retrieve the list of datasets
0034     if not os.path.isfile(relValDIR):
0035         curlCommand = curl%{"CERT_DIR":X509_CERT_DIR, "USER_PROXY":X509_USER_PROXY, "relValDIR":relValDIR}
0036         print (curlCommand)
0037         os.system(curlCommand)
0038 
0039     # open raw input file 
0040     fin = open(relValDIR, "r")
0041 
0042     # loop over file and pull out lines of interest
0043     for line in fin:
0044         # limit to one entry per dataset
0045         if label in line:
0046             # select datasets of interest
0047             for str in dsFlags.keys():
0048                 if str in line:
0049                     # extract dataset path
0050                     path = line.split('\'')[1].strip()
0051                     #print ("Getting DQM output from dataset: %s"%path)
0052                     if (path.find("Ideal") > 0 or path.find("design") > 0 or path.find("FastSim") > 0 or path.find("DQM") < 0 or path.find("Pixel") > 0 ):  #skip for unnecessary samples
0053                         continue
0054                     print (path.split("/")[-1]) #path
0055                     if printDS:
0056                         continue
0057 
0058                     # construct file name
0059                     fname = path.split("/")[-1]
0060 
0061                     # create file name for use with hcal scripts
0062                     info = fname.split("__")[2].replace(label, "").strip("-")
0063 
0064                     #The Data sample have an additional piece put in. We strip it out so that the MC and DATA code can be common
0065 
0066                     if camType == "DATA":
0067                         iparts = info.split("_")
0068                         info = ""
0069                         skip = False
0070                         for fragment in iparts:
0071                             if skip:
0072                                 info = info.strip("_")
0073                                 skip = False
0074                                 continue
0075                             if fragment == "RelVal":
0076                                 skip = True
0077                                 continue
0078                             info += fragment
0079                             info += "_"
0080                         info = info.strip("_")
0081 
0082                     ofn = ofnBlank%{"sample":dsFlags[str],"label":slabel,"info":info}
0083                     print ("ofn = ",ofn)
0084                     #Check if file exists already
0085                     if not os.path.isfile(ofn):
0086                         # copy file with curl
0087                         curlCommand = curl%{"CERT_DIR":X509_CERT_DIR,"USER_PROXY":X509_USER_PROXY, "relValDIR":relValDIR} + "/" + fname
0088                         print (curlCommand)
0089                         os.system(curlCommand)
0090 
0091                         # Rename file for use with HCAL scripts
0092                         mvCommand = "mv %(fn)s %(ofn)s"%{"fn":fname,"ofn":ofn}
0093                         print (mvCommand)
0094                         os.system(mvCommand)
0095                         #print ""
0096 
0097     fin.close();
0098     rmCommand = "rm %(ofn)s"%{"ofn":relValDIR}
0099     print (rmCommand)
0100     os.system(rmCommand)
0101 
0102     if printDS:
0103         return
0104 
0105     # Copy the single pion scan part from Salavat's directory
0106     #    spFileName = "pi50scan%s_fullGeom_ECALHCAL_CaloTowers.root"%slabel #->original line
0107     #spFileName = "pi50scan%s_ECALHCAL_CaloTowers.root"%slabel 
0108     #cpCommand = "cp /afs/cern.ch/user/a/abdullin/public/pi50_scan/%s ."%spFileName
0109     #if not os.path.isfile(spFileName):
0110     #    print cpCommand
0111     #    os.system(cpCommand)
0112     #    print ""
0113 
0114 ##End Functions
0115 
0116 
0117 
0118 # This is a dictionary of flags to pull out the datasets of interest mapped to the desired name from the hcal script
0119 dsMCFlags = {'RelValTTbar_13__':'TTbar', 'RelValQCD_Pt_80_120_13__':'QCD', 'RelValQCD_Pt_3000_3500_13__':'HighPtQCD', 'RelValMinBias_13__':'MinBias'}
0120 ds2023Flags = {'RelValTTbar_14TeV__':'TTbar', 'RelValMinBias_14TeV__':'MinBias'}
0121 
0122 #dsDATAFlags = {'301998__JetHT__':'JetHT', '301998__ZeroBias__':'ZeroBias'}  #Original
0123 #dsDATAFlags = {'305064__JetHT__':'JetHT','305064__ZeroBias__':'ZeroBias'} # 2017F
0124 dsDATAFlags = {'315489__JetHT__':'JetHT','315489__ZeroBias__':'ZeroBias'} # 2018A
0125 #dsDATAFlags = {'297557__JetHT__':'JetHT','297557__ZeroBias__':'ZeroBias'} # 2017B
0126 #dsDATAFlags = {'274199__JetHT__':'JetHT','274199__ZeroBias__':'ZeroBias','297227__JetHT__':'JetHT','297227__ZeroBias__':'ZeroBias'} #2016B & 2017B dataset
0127 
0128 #dsDATAFlags = {'274199__JetHT__':'JetHT','274199__ZeroBias__':'ZeroBias','297227__JetHT__':'JetHT','297227__ZeroBias__':'ZeroBias','302663__JetHT__':'JetHT','302663__ZeroBias__':'ZeroBias'} #2016B & 2017B & 2017D dataset
0129 
0130 
0131 #dsDATAFlags = {'274199__JetHT__':'JetHT','274199__ZeroBias__':'ZeroBias','297557__JetHT__':'JetHT','297557__ZeroBias__':'ZeroBias','305064__JetHT__':'JetHT','305064__ZeroBias__':'ZeroBias'} #2016B & 2017B & 2017D dataset
0132 #dsDATAFlags = {'256677__SingleMuon__':'SingleMuon'} #New_original
0133 #dsDATAFlags = {'254790__JetHT__':'JetHT','254790__ZeroBias__':'ZeroBias','254790__SingleMuon__':'SingleMuon'} #New_new
0134 # filename prefix 
0135 #fnPrefix = "DQM_V0001_R000000001"
0136 #MinBiasPrefix = "DQM_V0001_R000149011"
0137 #JetPrefix = "DQM_V0001_R000191226"
0138 
0139 # blank curl command 
0140 curlMC = "/usr/bin/curl -O -L --capath %(CERT_DIR)s --key %(USER_PROXY)s --cert %(USER_PROXY)s https://cmsweb.cern.ch/dqm/relval/data/browse/ROOT/RelVal/%(relValDIR)s"
0141 curlDATA = "/usr/bin/curl -O -L --capath %(CERT_DIR)s --key %(USER_PROXY)s --cert %(USER_PROXY)s https://cmsweb.cern.ch/dqm/relval/data/browse/ROOT/RelValData/%(relValDIR)s"
0142 # output file name blank
0143 ofnBlank = "HcalRecHitValidationRelVal_%(sample)s_%(label)s_%(info)s.root"
0144 
0145 # default release file for MC stub
0146 #dfTextFile = "%s_%s.txt"
0147 dfTextFile = "%s"
0148 
0149 # ensure all required parameters are included
0150 if len(args) < 1:
0151     print ("Usage: ./RelValHarvest.py -M (or -D) fullReleaseName")
0152     print ("fullReleaseName : CMSSW_7_4_0_pre8")
0153     exit(0)
0154 
0155 #Make sure a Dataset is specified
0156 if not options.getMC and not options.getDATA and not options.get2023:
0157     print ("You must specify a dataset:")
0158     print ("    -M : Monte Carlo")
0159     print ("    -D : Data")
0160     print ("    -2 : 2023")
0161     exit(0)
0162 
0163 # gather input parameter
0164 label     = args[0]
0165 
0166 #Now we check if the release provided works
0167 pattern = re.compile(r'CMSSW_\d{1,2}_\d{1,2}_\d{1,2}.*') #We are checking if the string begins with CMSSW_?_?_?, posibly with two digits in each position
0168 match = pattern.match(label)
0169 if match:
0170     slabel = match.group().replace('CMSSW','').replace("_","")
0171 else:
0172     print (label, " is an invalid CMMSW release name.")
0173     print ("Please provide a release name in the form: CMSSW_X_Y_Z")
0174     exit(0)
0175 
0176 # gather necessary proxy info for curl
0177 X509_CERT_DIR = os.getenv('X509_CERT_DIR', "/etc/grid-security/certificates")
0178 X509_USER_PROXY = os.getenv('X509_USER_PROXY')
0179 
0180 # modify label to shortened format (remove CMSSW and '_')
0181 #slabel = label.replace('CMSSW','').replace("_","")
0182 
0183 # get relval dir from label
0184 clabel = label.split("_")
0185 relValDIR = "%s_%s_%s_x"%(clabel[0], clabel[1], clabel[2])
0186 
0187 if options.getMC:
0188     getDataSets( dsFlags = dsMCFlags,
0189                  curl = curlMC,
0190                  label = label,
0191                  slabel = slabel,
0192                  relValDIR = relValDIR,
0193                  printDS = options.printDS,
0194                  camType = "MC")
0195 
0196 if options.get2023:
0197     getDataSets( dsFlags = ds2023Flags,
0198                  curl = curlMC,
0199                  label = label,
0200                  slabel = slabel,
0201                  relValDIR = relValDIR,
0202                  printDS = options.printDS,
0203                  camType = "2023")
0204 
0205 if options.getDATA:
0206     getDataSets( dsFlags = dsDATAFlags,
0207                  curl = curlDATA,
0208                  label = label,
0209                  slabel = slabel,
0210                  relValDIR = relValDIR,
0211                  printDS = options.printDS,
0212                  camType = "DATA")
0213