CMS 3D CMS Logo

MuScleFitCorrector.py
Go to the documentation of this file.
1 import os
2 from ROOT import heppy, TLorentzVector
3 
5  def __init__(self,isMC,isReReco,isSync=False):
6  #colin need to import muscle fit inputs, if tool still in use
7  path = "%s/src/CMGTools/RootTools/data/musclefit/" % os.environ['CMSSW_BASE'];
8  self.isMC = isMC
9  if self.isMC:
10  self.corr = heppy.MuScleFitCorrector(path+"MuScleFit_2012_MC_53X_smear%s.txt" % ("ReReco" if isReReco else "Prompt"))
11  self.isSync = isSync
12  else:
13  self.corrABC = heppy.MuScleFitCorrector(path+"MuScleFit_2012ABC_DATA%s_53X.txt" % ("_ReReco" if isReReco else ""))
14  self.corrD = heppy.MuScleFitCorrector(path+"MuScleFit_2012D_DATA%s_53X.txt" % ("_ReReco" if isReReco else ""))
15  def corrected_p4(self, mu, run):
16  p4 = TLorentzVector(mu.px(), mu.py(), mu.pz(), mu.energy())
17  if self.isMC:
18  self.corr.applyPtCorrection(p4, mu.charge())
19  self.corr.applyPtSmearing(p4, mu.charge(), self.isSync)
20  else:
21  corr = self.corrD if run >= 203773 else self.corrABC
22  corr.applyPtCorrection(p4, mu.charge())
23  ## convert to the proper C++ class (but preserve the mass!)
24  return ROOT.reco.Muon.PolarLorentzVector( p4.Pt(), p4.Eta(), p4.Phi(), mu.mass() )
25 
26  def correct(self, mu, run):
27  mu.setP4( self.corrected_p4(mu, run) )
28 
29  def correct_all(self, mus, run):
30  for mu in mus:
31  mu.setP4( self.corrected_p4(mu, run) )
32 
33 if __name__ == '__main__':
34  muscle = MuScleFitCorr(True, True)
def __init__(self, isMC, isReReco, isSync=False)