-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #2 from shane-breeze/master
Add T1qqqq fragment to cross-check
- Loading branch information
Showing
1 changed file
with
223 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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, 1200, 100, 100)) | ||
scanBlocks.append(gridBlock(1200, 2301, 50, 100)) | ||
minDM = 25 | ||
ymin, ymed, ymax = 0, 500, 1600 | ||
|
||
|
||
# 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, | ||
), | ||
) |