diff --git a/README.md b/README.md index db4c88325d84c..6b43d5a790e8d 100644 --- a/README.md +++ b/README.md @@ -9,12 +9,12 @@ Then anywhere, ``` git clone git@github.com:CMS-HGCAL/reco-prodtools.git cd reco-prodtools -python SubmitHGCalPGun.py --nevts 2 --evtsperjob 1 --queue 1nh --partID 13 --thresholdMin 35 --thresholdMin 35 --gunType E --tag test_${USER} +python SubmitHGCalPGun.py --nevts 2 --evtsperjob 1 --queue 1nh --partID 13 --thresholdMin 35 --thresholdMax 35 --gunType E --tag test_${USER} ``` ## details -To produce `NEVENTS` GEN-SIM-DIGI events with `NPART` particles (per event) of type `PART_PDGID` and in the p_T range from `PTMIN` to `PTMAX`, one should run: +To produce `NEVENTS` GEN-SIM-DIGI events with `NPART` sets of particles (per event) of type `PART_PDGID` and in the p_T range from `PTMIN` to `PTMAX`, one should run: ``` python SubmitHGCalPGun.py --datTier GSD @@ -29,6 +29,8 @@ To produce `NEVENTS` GEN-SIM-DIGI events with `NPART` particles (per event) of t [--local] --tag MYTAG ``` +Here, one can produce a custom set of particles by providing `PART_PDGID` as a set of comma-separated single PDG IDs. + To produce `NEVENTS` GEN-SIM-DIGI events with pair of particles within given angular distance ΔR(η,φ) (per event), where the first particle is of type `PART_PDGID` and in the p_T range from `PTMIN` to `PTMAX`, and the second one is of type `INCONE_PART_PDGID` and at distance from `DRMIN` to `DRMAX` and with p_T in range from `PTRATIO_MIN` to `PTRATIO_MAX` relative to the first particle, one should run: ``` python SubmitHGCalPGun.py @@ -99,6 +101,7 @@ python SubmitHGCalPGun.py \ --evtsperjob NPERJOB \ --queue QUEUENAME \ --inDir partGun_[MYTAG]_[DATE] \ + [--noReClust] \ [--local] \ --tag MYTAG ``` diff --git a/SubmitHGCalPGun.py b/SubmitHGCalPGun.py index 0168a0d7e6a06..f2a70e3388b4e 100644 --- a/SubmitHGCalPGun.py +++ b/SubmitHGCalPGun.py @@ -24,14 +24,14 @@ def parseOptions(): parser.add_option('-n', '--nevts', dest='NEVTS', type=int, default=100, help='total number of events, applicable to runs with GEN stage, default is 100') parser.add_option('-e', '--evtsperjob', dest='EVTSPERJOB', type=int, default=-1, help='number of events per job, if set to -1 it will set to a recommended value (GSD: 4events/1nh, RECO:8events/1nh), default is -1') parser.add_option('-c', '--cfg', dest='CONFIGFILE', type='string', default='',help='CMSSW config template name, if empty string the deafult one will be used') - parser.add_option('-p', '--partID', dest='PARTID', type='string', default='', help='particle PDG ID, if empty string - run on all supported (11,12,13,14,15,16,22,111,211), default is empty string (all)') + parser.add_option('-p', '--partID', dest='PARTID', type='string', default='', help='string of particle PDG IDs separated by comma, if empty string - run on all supported (11,12,13,14,15,16,22,111,211,130), default is empty string (all)') parser.add_option('', '--nPart', dest='NPART', type=int, default=1, help='number of particles of type PARTID to be generated per event, default is 1') parser.add_option('', '--thresholdMin', dest='thresholdMin', type=float, default=1.0, help='min. threshold value') parser.add_option('', '--thresholdMax', dest='thresholdMax', type=float, default=35.0, help='max. threshold value') parser.add_option('', '--gunType', dest='gunType', type='string', default='Pt', help='Pt or E gun') parser.add_option('', '--PU', dest='PU', type='string', default='0', help='PU value (0 is the default)') parser.add_option('', '--PUDS', dest='PUDS', type='string', default='', help='PU dataset') - parser.add_option('', '--InConeID', dest='InConeID', type='string', default='', help='PDG ID for particle to be generated in the cone (supported as PARTID), default is empty string (none)') + parser.add_option('', '--InConeID', dest='InConeID', type='string', default='', help='PDG ID for sinlge particle to be generated in the cone (supported as PARTID), default is empty string (none)') parser.add_option('', '--MinDeltaR', dest='MinDeltaR', type=float, default=0.3, help='min. DR value') parser.add_option('', '--MaxDeltaR', dest='MaxDeltaR', type=float, default=0.4, help='max. DR value') parser.add_option('', '--MinMomRatio', dest='MinMomRatio', type=float, default=0.5, help='min. momentum ratio for particle inside of the cone and particle that defines the cone') @@ -42,6 +42,7 @@ def parseOptions(): parser.add_option('-d', '--datTier', dest='DTIER', type='string', default='GSD', help='data tier to run: "GSD" (GEN-SIM-DIGI) or "RECO", default is "GSD"') parser.add_option('-i', '--inDir', dest='inDir', type='string', default='', help='name of the previous stage dir (relative to the local submission or "eosArea"), to be used as the input for next stage, not applicable for GEN stage') parser.add_option('-r', '--RelVal', dest='RELVAL', type='string', default='', help='name of relval reco dataset to be ntuplized (currently implemented only for NTUP data Tier') + parser.add_option('', '--noReClust', action='store_false', dest='RECLUST', default=True, help='do not re-run RECO-level clustering at NTUP step, default is True (do re-run the clustering).') # store options and arguments as global variables global opt, args @@ -77,11 +78,12 @@ def parseOptions(): if opt.EVTSPERJOB==-1: opt.EVTSPERJOB = queues_evtsperjob[opt.QUEUE] # set the recommnded number of events per job, if requested - # list of supported particles, check if requested partID is supported + # list of supported particles, check if requested partID list is subset of the upported ones global particles - particles = ['22', '111', '211', '11', '13', '15', '12', '14', '16'] - if not (opt.PARTID in particles or opt.PARTID == ''): - parser.error('Particle with ID ' + opt.PARTID + ' is not supported. Exiting...') + particles = ['22', '111', '211', '11', '13', '15', '12', '14', '16', '130'] + inPartID = [p.strip(" ") for p in opt.PARTID.split(",")] # prepare list of requested IDs (split by ",", strip white spaces) + if not (set(inPartID) < set(particles) or opt.PARTID == ''): + parser.error('Particle(s) with ID(s) ' + opt.PARTID + ' is not supported. Exiting...') sys.exit() # sanity check for generation of particle within the cone (require to be compatibe with NPART==1, gunType==Pt and supported particles) @@ -295,9 +297,10 @@ def submitHGCalProduction(): for particle in particles: nFilesPerJob = 0 eventsPerPrevJob = 0 + sParticle = [p.strip(" ") for p in particle.split(",")] # prepare a list of particle strings without white spaces # in case of 'RECO' or 'NTUP', get the input file list for given particle, determine number of jobs, get also basic GSD/RECO info if (opt.DTIER == 'RECO' or opt.DTIER == 'NTUP'): - inputFilesList = getInputFileList(DASquery,inPath, previousDataTier, opt.LOCAL, commonFileNamePrefix+'*_PDGid'+particle+'_*.root') + inputFilesList = getInputFileList(DASquery,inPath, previousDataTier, opt.LOCAL, commonFileNamePrefix+'*_PDGid'+"_id".join(sParticle)+'_*.root') if len(inputFilesList) == 0: continue # build regular expression for splitting (NOTE: none of this is used for relval!) @@ -323,7 +326,7 @@ def submitHGCalProduction(): if DASquery: basename=outDir+'_'+opt.DTIER+'_'+str(job) else: - basename = commonFileNamePrefix + '_PDGid'+particle+'_x'+str([nFilesPerJob * eventsPerPrevJob, opt.EVTSPERJOB][opt.DTIER=='GSD'])+'_' + opt.gunType+str(opt.thresholdMin)+'To'+str(opt.thresholdMax)+'_'+opt.DTIER+'_'+str(job) + basename = commonFileNamePrefix + '_PDGid'+"_id".join(sParticle)+'_x'+str([nFilesPerJob * eventsPerPrevJob, opt.EVTSPERJOB][opt.DTIER=='GSD'])+'_' + opt.gunType+str(opt.thresholdMin)+'To'+str(opt.thresholdMax)+'_'+opt.DTIER+'_'+str(job) cfgfile = basename +'.py' outfile = basename +'.root' @@ -375,6 +378,9 @@ def submitHGCalProduction(): # otherwise put False s_template=s_template.replace('DUMMYROR','False') + if (opt.DTIER == 'NTUP'): + s_template=s_template.replace('DUMMYRECLUST',str(opt.RECLUST)) + # submit job # now write the file from the s_template diff --git a/templates/partGun_NTUP_template.py b/templates/partGun_NTUP_template.py index 03570e03809de..3ab7f72f70558 100644 --- a/templates/partGun_NTUP_template.py +++ b/templates/partGun_NTUP_template.py @@ -49,7 +49,7 @@ ) -reRunClustering = True +reRunClustering = DUMMYRECLUST if reRunClustering: # process.hgcalLayerClusters.minClusters = cms.uint32(0)