diff --git a/T1qqqq_fullsim/README.md b/T1qqqq_fullsim/README.md new file mode 100644 index 0000000..f9797a0 --- /dev/null +++ b/T1qqqq_fullsim/README.md @@ -0,0 +1,83 @@ +# T1qqqq full sim production + +## Setup CMSSW + +Checkout CMSSW version `8_0_21`: +```bash +export SCRAM_ARCH=slc6_amd64_gcc530 +cmsrel CMSSW_8_0_21 +cd CMSSW_8_0_21/src +cmsenv +mkdir -p Configuration/GenProduction/python/ +cp ../../fragments/T1qqqq_fragment.py Configuration/GenProduction/python/ +scram b -j 9 +cd - +``` + +### GEN-SIM +Runs Madgraph and Pythia +```bash +cmsDriver.py Configuration/GenProduction/python/T1qqqq_fragment.py \ + --mc \ + --eventcontent RAWSIM \ + --customise_commands "process.source.numberEventsInLuminosityBlock = cms.untracked.uint32(50) \n process.source.firstRun = cms.untracked.uint32(3) \n process.generator.initialSeed = cms.untracked.uint32(3)" \ + --datatier GEN-SIM \ + --conditions 80X_mcRun2_asymptotic_2016_TrancheIV_v6 \ + --beamspot Realistic50ns13TeVCollision \ + --step GEN,SIM \ + --magField 38T_PostLS1 \ + --fileout file:T1qqqq_fullsim_GEN-SIM.root \ + --python_filename step1_T1qqqq_fullsim_GEN-SIM_cfg.py \ + --no_exec \ + -n 50 +``` + +### PU Mixing +Run the PU mixing step over all events produced by the GEN-SIM step +```bash +cmsDriver.py --mc \ + --eventcontent PREMIXRAW \ + --datatier GEN-SIM-RAW \ + --conditions 80X_mcRun2_asymptotic_2016_TrancheIV_v6 \ + --step DIGIPREMIX_S2,DATAMIX,L1,DIGI2RAW,HLT:@frozen2016 \ + --datamix PreMix \ + --era Run2_2016 \ + --filein file:T1qqqq_fullsim_GEN-SIM.root \ + --fileout file:T1qqqq_fullsim_PUMix.root \ + --python_filename step2_T1qqqq_fullsim_PUMix_cfg.py \ + --pileup_input "/store/mc/RunIISpring15PrePremix/Neutrino_E-10_gun/GEN-SIM-DIGI-RAW/PUMoriond17_80X_mcRun2_asymptotic_2016_TrancheIV_v2-v2/90023/FED016AB-6A85-E611-96E7-002590A80DF0.root" \ + --no_exec \ + -n -1 +``` + +### AODSIM +```bash +cmsDriver.py --mc \ + --eventcontent AODSIM,DQM \ + --runUnscheduled \ + --datatier AODSIM,DQMIO \ + --conditions 80X_mcRun2_asymptotic_2016_TrancheIV_v6 \ + --step RAW2DIGI,RECO,EI,DQM:DQMOfflinePOGMC \ + --era Run2_2016 \ + --filein file:T1qqqq_fullsim_PUMix.root \ + --fileout file:T1qqqq_fullsim_AODSIM.root \ + --python_filename step3_T1qqqq_fullsim_AODSIM_cfg.py \ + --no_exec \ + -n -1 +``` + +### MINIAODSIM +```bash +cmsDriver.py --mc \ + --eventcontent MINIAODSIM \ + --runUnscheduled \ + --datatier MINIAODSIM \ + --conditions 80X_mcRun2_asymptotic_2016_TrancheIV_v6 \ + --step PAT \ + --era Run2_2016 \ + --filein file:T1qqqq_fullsim_AODSIM.root \ + --fileout file:T1qqqq_fullsim_MINIAODSIM.root \ + --python_filename step4_T1qqqq_fullsim_MINIAODSIM_cfg.py \ + --no_exec \ + -n -1 +``` diff --git a/T1qqqq_fullsim/crab_submission_AODSIM.py b/T1qqqq_fullsim/crab_submission_AODSIM.py new file mode 100644 index 0000000..c7d8382 --- /dev/null +++ b/T1qqqq_fullsim/crab_submission_AODSIM.py @@ -0,0 +1,23 @@ +from CRABClient.UserUtilities import config, getUsernameFromSiteDB +config = config() + +config.General.requestName = 'SMS_T1qqqq_fullsim' +config.General.workArea = 'SMS_T1qqqq_fullsim_AODSIM' +config.General.transferOutputs = True +config.General.transferLogs = True + +config.JobType.pluginName = 'ANALYSIS' +config.JobType.psetName = 'step3_T1qqqq_fullsim_AODSIM_cfg.py' +config.JobType.outputFiles = ['T1qqqq_fullsim_AODSIM.root',] + +config.Data.inputDataset = '' +config.Data.inputDBS = 'phys03' +config.Data.splitting = 'EventAwareLumiBased' +config.Data.unitsPerJob = 100 +config.Data.totalUnits = -1 +config.Data.outLFNDirBase = '/store/user/%s/' % (getUsernameFromSiteDB()) +config.Data.publication = True +config.Data.outputDatasetTag = 'T1qqqq_fullsim_Madgraph_Pythia_AODSIM' + +config.Site.storageSite = 'T2_UK_London_IC' +#config.Site.storageSite = 'T2_UK_SGrid_Bristol' diff --git a/T1qqqq_fullsim/crab_submission_GEN-SIM.py b/T1qqqq_fullsim/crab_submission_GEN-SIM.py new file mode 100644 index 0000000..10858cd --- /dev/null +++ b/T1qqqq_fullsim/crab_submission_GEN-SIM.py @@ -0,0 +1,22 @@ +from CRABClient.UserUtilities import config, getUsernameFromSiteDB +config = config() + +config.General.requestName = 'SMS_T1qqqq_fullsim' +config.General.workArea = 'SMS_T1qqqq_fullsim_GEN-SIM' +config.General.transferOutputs = True +config.General.transferLogs = True + +config.JobType.pluginName = 'PrivateMC' +config.JobType.psetName = 'step1_T1qqqq_fullsim_GEN-SIM_cfg.py' + +config.Data.outputPrimaryDataset = 'T1qqqq_fullsim_Madgraph_Pythia' +config.Data.inputDBS = 'global' +config.Data.splitting = 'EventBased' +config.Data.unitsPerJob = 500 +config.Data.totalUnits = 100000 +config.Data.outLFNDirBase = '/store/user/%s/' % (getUsernameFromSiteDB()) +config.Data.publication = True +config.Data.outputDatasetTag = 'T1qqqq_fullsim_Madgraph_Pythia_GEN-SIM' + +config.Site.storageSite = 'T2_UK_London_IC' +#config.Site.storageSite = 'T2_UK_SGrid_Bristol' diff --git a/T1qqqq_fullsim/crab_submission_MINIAODSIM.py b/T1qqqq_fullsim/crab_submission_MINIAODSIM.py new file mode 100644 index 0000000..23b34bc --- /dev/null +++ b/T1qqqq_fullsim/crab_submission_MINIAODSIM.py @@ -0,0 +1,23 @@ +from CRABClient.UserUtilities import config, getUsernameFromSiteDB +config = config() + +config.General.requestName = 'SMS_T1qqqq_fullsim' +config.General.workArea = 'SMS_T1qqqq_fullsim_MINIAODSIM' +config.General.transferOutputs = True +config.General.transferLogs = True + +config.JobType.pluginName = 'ANALYSIS' +config.JobType.psetName = 'step4_T1qqqq_fullsim_MINIAODSIM_cfg.py' +config.JobType.outputFiles = ['T1qqqq_fullsim_MINIAODSIM.root'] + +config.Data.inputDataset = '' +config.Data.inputDBS = 'phys03' +config.Data.splitting = 'EventAwareLumiBased' +config.Data.unitsPerJob = 100 +config.Data.totalUnits = -1 +config.Data.outLFNDirBase = '/store/user/%s/' % (getUsernameFromSiteDB()) +config.Data.publication = True +config.Data.outputDatasetTag = 'T1qqqq_fullsim_Madgraph_Pythia_MINIAODSIM' + +config.Site.storageSite = 'T2_UK_London_IC' +#config.Site.storageSite = 'T2_UK_SGrid_Bristol' diff --git a/T1qqqq_fullsim/crab_submission_PUMix.py b/T1qqqq_fullsim/crab_submission_PUMix.py new file mode 100644 index 0000000..bc80898 --- /dev/null +++ b/T1qqqq_fullsim/crab_submission_PUMix.py @@ -0,0 +1,23 @@ +from CRABClient.UserUtilities import config, getUsernameFromSiteDB +config = config() + +config.General.requestName = 'SMS_T1qqqq_fullsim' +config.General.workArea = 'SMS_T1qqqq_fullsim_PUMix' +config.General.transferOutputs = True +config.General.transferLogs = True + +config.JobType.pluginName = 'ANALYSIS' +config.JobType.psetName = 'step2_T1qqqq_fullsim_PUMix_cfg.py' +config.JobType.outputFiles = ['T1qqqq_fullsim_PUMix.root',] + +config.Data.inputDataset = '' +config.Data.inputDBS = 'phys03' +config.Data.splitting = 'EventAwareLumiBased' +config.Data.unitsPerJob = 100 +config.Data.totalUnits = -1 +config.Data.outLFNDirBase = '/store/user/%s/' % (getUsernameFromSiteDB()) +config.Data.publication = True +config.Data.outputDatasetTag = 'T1qqqq_fullsim_Madgraph_Pythia_PUMix' + +config.Site.storageSite = 'T2_UK_London_IC' +#config.Site.storageSite = 'T2_UK_SGrid_Bristol' diff --git a/T1qqqq_fullsim/fragments/T1qqqq_fragment.py b/T1qqqq_fullsim/fragments/T1qqqq_fragment.py new file mode 100644 index 0000000..47495cc --- /dev/null +++ b/T1qqqq_fullsim/fragments/T1qqqq_fragment.py @@ -0,0 +1,223 @@ +import FWCore.ParameterSet.Config as cms + +from Configuration.Generator.Pythia8CommonSettings_cfi import * +from Configuration.Generator.Pythia8CUEP8M1Settings_cfi import * + +import math + +baseSLHATable=""" +BLOCK MASS # Mass Spectrum +# PDG code mass particle + 1000001 1.00000000E+05 # ~d_L + 2000001 1.00000000E+05 # ~d_R + 1000002 1.00000000E+05 # ~u_L + 2000002 1.00000000E+05 # ~u_R + 1000003 1.00000000E+05 # ~s_L + 2000003 1.00000000E+05 # ~s_R + 1000004 1.00000000E+05 # ~c_L + 2000004 1.00000000E+05 # ~c_R + 1000005 1.00000000E+05 # ~b_1 + 2000005 1.00000000E+05 # ~b_2 + 1000006 1.00000000E+05 # ~t_1 + 2000006 1.00000000E+05 # ~t_2 + 1000011 1.00000000E+05 # ~e_L + 2000011 1.00000000E+05 # ~e_R + 1000012 1.00000000E+05 # ~nu_eL + 1000013 1.00000000E+05 # ~mu_L + 2000013 1.00000000E+05 # ~mu_R + 1000014 1.00000000E+05 # ~nu_muL + 1000015 1.00000000E+05 # ~tau_1 + 2000015 1.00000000E+05 # ~tau_2 + 1000016 1.00000000E+05 # ~nu_tauL + 1000021 %MGLU% # ~g + 1000022 %MLSP% # ~chi_10 + 1000023 1.00000000E+05 # ~chi_20 + 1000025 1.00000000E+05 # ~chi_30 + 1000035 1.00000000E+05 # ~chi_40 + 1000024 1.00000000E+05 # ~chi_1+ + 1000037 1.00000000E+05 # ~chi_2+ + +# DECAY TABLE +# PDG Width +DECAY 1000001 0.00000000E+00 # sdown_L decays +DECAY 2000001 0.00000000E+00 # sdown_R decays +DECAY 1000002 0.00000000E+00 # sup_L decays +DECAY 2000002 0.00000000E+00 # sup_R decays +DECAY 1000003 0.00000000E+00 # sstrange_L decays +DECAY 2000003 0.00000000E+00 # sstrange_R decays +DECAY 1000004 0.00000000E+00 # scharm_L decays +DECAY 2000004 0.00000000E+00 # scharm_R decays +DECAY 1000005 0.00000000E+00 # sbottom1 decays +DECAY 2000005 0.00000000E+00 # sbottom2 decays +DECAY 1000006 0.00000000E+00 # stop1 decays +DECAY 2000006 0.00000000E+00 # stop2 decays + +DECAY 1000011 0.00000000E+00 # selectron_L decays +DECAY 2000011 0.00000000E+00 # selectron_R decays +DECAY 1000012 0.00000000E+00 # snu_elL decays +DECAY 1000013 0.00000000E+00 # smuon_L decays +DECAY 2000013 0.00000000E+00 # smuon_R decays +DECAY 1000014 0.00000000E+00 # snu_muL decays +DECAY 1000015 0.00000000E+00 # stau_1 decays +DECAY 2000015 0.00000000E+00 # stau_2 decays +DECAY 1000016 0.00000000E+00 # snu_tauL decays +##### gluino decays - no offshell decays needed +DECAY 1000021 1.00000000E+00 # gluino decays +# BR NDA ID1 ID2 ID3 + 2.50000000E-01 3 1000022 -1 1 # BR(~gl -> N1 ubar u) + 2.50000000E-01 3 1000022 -2 2 # BR(~gl -> N1 dbar d) + 2.50000000E-01 3 1000022 -3 3 # BR(~gl -> N1 cbar c) + 2.50000000E-01 3 1000022 -4 4 # BR(~gl -> N1 sbar s) + +DECAY 1000022 0.00000000E+00 # neutralino1 decays +DECAY 1000023 0.00000000E+00 # neutralino2 decays +DECAY 1000024 0.00000000E+00 # chargino1+ decays +DECAY 1000025 0.00000000E+00 # neutralino3 decays +DECAY 1000035 0.00000000E+00 # neutralino4 decays +DECAY 1000037 0.00000000E+00 # chargino2+ decays +""" + +generator = cms.EDFilter("Pythia8GeneratorFilter", + maxEventsToPrint = cms.untracked.int32(1), + pythiaPylistVerbosity = cms.untracked.int32(1), + filterEfficiency = cms.untracked.double(1.0), + pythiaHepMCVerbosity = cms.untracked.bool(False), + comEnergy = cms.double(13000.), + RandomizedParameters = cms.VPSet(), +) + +model = "T1qqqq" +# weighted average of matching efficiencies for the full scan +# must equal the number entered in McM generator params +mcm_eff = 0.244 + + +# Parameters that define the grid in the bulk and diagonal +class gridBlock: + def __init__(self, xmin, xmax, xstep, ystep): + self.xmin = xmin + self.xmax = xmax + self.xstep = xstep + self.ystep = ystep + +# Fit to gluino cross-section in fb +def xsec(mass): + return 4.563e+17*math.pow(mass, -4.761*math.exp(5.848e-05*mass)) + +def matchParams(mass): + if mass<799: return 118., 0.235 + elif mass<999: return 128., 0.235 + elif mass<1199: return 140., 0.235 + elif mass<1399: return 143., 0.245 + elif mass<1499: return 147., 0.255 + elif mass<1799: return 150., 0.267 + elif mass<2099: return 156., 0.290 + else: return 160., 0.315 + +# Number of events: min(goalLumi*xsec, maxEvents) (always in thousands) +goalLumi = 800 +minLumi = 40 +minEvents, maxEvents = 10, 150 +diagStep = 50 +maxDM = 1000 + + +scanBlocks = [] +scanBlocks.append(gridBlock(600, 650, 100, 100)) +#scanBlocks.append(gridBlock(1200, 2301, 50, 100)) +minDM = 25 +ymin, ymed, ymax = 0, 50, 100 + + +# Number of events for mass point, in thousands +def events(mass): + xs = xsec(mass) + nev = min(goalLumi*xs, maxEvents*1000) + if nev < xs*minLumi: nev = xs*minLumi + nev = max(nev/1000, minEvents) + return math.ceil(nev) # Rounds up + +# Constructing grid + +print "Starting grid construction" + +cols = [] +Nevents = [] +xmin, xmax = 9999, 0 +for block in scanBlocks: + Nbulk, Ndiag = 0, 0 + for mx in range(block.xmin, block.xmax, diagStep): + xmin = min(xmin, block.xmin) + xmax = max(xmax, block.xmax) + col = [] + my = 0 + begDiag = max(ymed, mx-maxDM) + # Adding bulk points + if (mx-block.xmin)%block.xstep == 0 : + for my in range(ymin, begDiag, block.ystep): + if my > ymax: continue + nev = events(mx) + col.append([mx,my, nev]) + Nbulk += nev + # Adding diagonal points + for my in range(begDiag, mx-minDM+1, diagStep): + if my > ymax: continue + nev = events(mx) + col.append([mx,my, nev]) + Ndiag += nev + if(my != mx-minDM and mx-minDM <= ymax): + my = mx-minDM + nev = events(mx) + col.append([mx,my, nev]) + Ndiag += nev + cols.append(col) + Nevents.append([Nbulk, Ndiag]) + +mpoints = [] + +for col in cols: mpoints.extend(col) + +print "Finished grid construction" + +for point in mpoints: + mglu, mlsp = point[0], point[1] + qcut, tru_eff = matchParams(mglu) + wgt = point[2]*(mcm_eff/tru_eff) + + if mlsp==0: mlsp = 1 + slhatable = baseSLHATable.replace('%MGLU%','%e' % mglu) + slhatable = slhatable.replace('%MLSP%','%e' % mlsp) + + basePythiaParameters = cms.PSet( + pythia8CommonSettingsBlock, + pythia8CUEP8M1SettingsBlock, + JetMatchingParameters = cms.vstring( + 'JetMatching:setMad = off', + 'JetMatching:scheme = 1', + 'JetMatching:merge = on', + 'JetMatching:jetAlgorithm = 2', + 'JetMatching:etaJetMax = 5.', + 'JetMatching:coneRadius = 1.', + 'JetMatching:slowJetPower = 1', + 'JetMatching:qCut = %.0f' % qcut, #this is the actual merging scale + 'JetMatching:nQmatch = 5', #4 corresponds to 4-flavour scheme (no matching of b-quarks), 5 for 5-flavour scheme + 'JetMatching:nJetMax = 2', #number of partons in born matrix element for highest multiplicity + 'JetMatching:doShowerKt = off', #off for MLM matching, turn on for shower-kT matching + '6:m0 = 172.5', + 'Check:abortIfVeto = on', + ), + parameterSets = cms.vstring('pythia8CommonSettings', + 'pythia8CUEP8M1Settings', + 'JetMatchingParameters' + ) + ) + + generator.RandomizedParameters.append( + cms.PSet( + ConfigWeight = cms.double(wgt), + GridpackPath = cms.string('/cvmfs/cms.cern.ch/phys_generator/gridpacks/slc6_amd64_gcc481/13TeV/madgraph/V5_2.3.3/sus_sms/SMS-GlGl/SMS-GlGl_mGl-%i_tarball.tar.xz' % mglu), + ConfigDescription = cms.string('%s_%i_%i' % (model, mglu, mlsp)), + SLHATableForPythia8 = cms.string('%s' % slhatable), + PythiaParameters = basePythiaParameters, + ), + )