Skip to content

Commit

Permalink
Merge pull request cms-sw#148 from jheikkil/feature_name_branch
Browse files Browse the repository at this point in the history
Solution on how to hande missing or zero signal strengths of ggH measurement
  • Loading branch information
gpetruc committed Sep 22, 2014
2 parents e3d5066 + 619404c commit 2d2d7e8
Showing 1 changed file with 15 additions and 2 deletions.
17 changes: 15 additions & 2 deletions python/DegenerateMatrixRank.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,13 @@ def __init__(self):
SMLikeHiggsModel.__init__(self) # not using 'super(x,self).__init__' since I don't understand it
self.decays = [ "hbb", "htt", "hgg", "hww", "hzz" ]
self.productions = ["ggH", "qqH", "VH", "ttH"]
self.fixDecays = []
self.mHRange = []
def setPhysicsOptions(self,physOptions):
for po in physOptions:
if po.startswith("decays="): self.decays = po.replace("decays=","").split(",")
if po.startswith("productions="): self.productions = po.replace("productions=","").split(",")
if po.startswith("fixDecays="): self.fixDecays = po.replace("fixDecays=","").split(",")
if po.startswith("higgsMassRange="):
self.mHRange = po.replace("higgsMassRange=","").split(",")
if len(self.mHRange) != 2:
Expand All @@ -31,7 +33,12 @@ def doParametersOfInterest(self):
poi.append('lambdat');
for decay in self.decays:
#poi.append('mu_'+decay);
self.modelBuilder.doVar("mu_%s[1,0,5]" % decay)
if decay in self.fixDecays:
print "It seems that you set signal strength ggH->"+decay+" as missing, I will set that as POI. Please set it to unity when running HybridNew."
self.modelBuilder.doVar("mu_%s[1,0,5]" % decay)
poi.append('mu_'+decay)
else:
self.modelBuilder.doVar("mu_%s[1,0,5]" % decay)
self.modelBuilder.factory_("expr::lambdamu_%s(\"@0*@1\",lambda,mu_%s)" % (decay,decay))
self.modelBuilder.factory_("expr::lambdavmu_%s(\"@0*@1\",lambdav,mu_%s)" % (decay,decay))
self.modelBuilder.factory_("expr::lambdatmu_%s(\"@0*@1\",lambdat,mu_%s)" % (decay,decay))
Expand Down Expand Up @@ -85,11 +92,13 @@ def __init__(self):
SMLikeHiggsModel.__init__(self) # not using 'super(x,self).__init__' since I don't understand it
self.decays = [ "hbb", "htt", "hgg", "hww", "hzz" ]
self.productions = ["ggH", "qqH", "VH", "ttH"]
self.fixDecays = []
self.mHRange = []
def setPhysicsOptions(self,physOptions):
for po in physOptions:
if po.startswith("decays="): self.decays = po.replace("decays=","").split(",")
if po.startswith("productions="): self.productions = po.replace("productions=","").split(",")
if po.startswith("fixDecays="): self.fixDecays = po.replace("fixDecays=","").split(",")
if po.startswith("higgsMassRange="):
self.mHRange = po.replace("higgsMassRange=","").split(",")
if len(self.mHRange) != 2:
Expand All @@ -112,7 +121,11 @@ def doParametersOfInterest(self):
poi.append('lambdav_'+decay);
elif production == "ttH":
poi.append('lambdat_'+decay);
self.modelBuilder.doVar("mu_%s[1,0,5]" % decay)
if decay in self.fixDecays:
print "It seems that you set signal strength ggH->"+decay+" as missing, I will set that equal to unity."
self.modelBuilder.doVar("mu_%s[1.0]" % decay)
else:
self.modelBuilder.doVar("mu_%s[1,0,5]" % decay)
self.modelBuilder.doVar("lambda_%s[1,0,10]" % decay)
self.modelBuilder.doVar("lambdav_%s[1,0,10]" % decay)
self.modelBuilder.doVar("lambdat_%s[1,0,10]" % decay)
Expand Down

0 comments on commit 2d2d7e8

Please sign in to comment.