CMS 3D CMS Logo

List of all members | Public Member Functions | Private Attributes
plotting.FakeDuplicate Class Reference

Public Member Functions

def __init__ (self, name, assoc, dup, reco, title="")
 
def __str__ (self)
 
def create (self, tdirectory)
 

Private Attributes

 _assoc
 
 _dup
 
 _name
 
 _reco
 
 _title
 

Detailed Description

Class to calculate the fake+duplicate rate

Definition at line 842 of file plotting.py.

Constructor & Destructor Documentation

def plotting.FakeDuplicate.__init__ (   self,
  name,
  assoc,
  dup,
  reco,
  title = "" 
)
Constructor.

Arguments:
name  -- String for the name of the resulting efficiency histogram
assoc -- String for the name of the "associated" histogram
dup   -- String for the name of the "duplicates" histogram
reco  -- String for the name of the "reco" (denominator) histogram

Keyword arguments:
title  -- String for a title of the resulting histogram (default "")

The result is calculated as 1 - (assoc - dup) / reco

Definition at line 844 of file plotting.py.

844  def __init__(self, name, assoc, dup, reco, title=""):
845  """Constructor.
846 
847  Arguments:
848  name -- String for the name of the resulting efficiency histogram
849  assoc -- String for the name of the "associated" histogram
850  dup -- String for the name of the "duplicates" histogram
851  reco -- String for the name of the "reco" (denominator) histogram
852 
853  Keyword arguments:
854  title -- String for a title of the resulting histogram (default "")
855 
856  The result is calculated as 1 - (assoc - dup) / reco
857  """
858  self._name = name
859  self._assoc = assoc
860  self._dup = dup
861  self._reco = reco
862  self._title = title
863 
def __init__(self, name, assoc, dup, reco, title="")
Definition: plotting.py:844

Member Function Documentation

def plotting.FakeDuplicate.__str__ (   self)
def plotting.FakeDuplicate.create (   self,
  tdirectory 
)
Create and return the fake+duplicate histogram from a TDirectory

Definition at line 868 of file plotting.py.

References SpecialClusterImporter< T >._assoc, plotting.FakeDuplicate._assoc, plotting.FakeDuplicate._dup, plotting._getObject(), FP420HitsObject._name, TrackerHitsObject._name, PGeometricDet::Item._name, TrackingRecHitAlgorithm._name, LikelihoodSpecies._name, L1TMuon::PtAssignmentUnit._name, L1TMuon::PtRefinementUnit._name, LikelihoodPdfProduct._name, LikelihoodPdf._name, citk::IsolationConeDefinitionBase._name, Logger._name, hcaldqm::DQModule._name, DrellYanValidation._name, WValidation._name, HistoParams< T >._name, hcaldqm::flag::Flag._name, hcaldqm::quantity::Quantity._name, CutApplicatorBase._name, ElectronMVAEstimatorRun2Phys14NonTrig._name, PhotonMVAEstimatorRun2Spring15NonTrig._name, PhotonMVAEstimatorRun2Phys14NonTrig._name, GeometricDetExtra._name, ElectronMVAEstimatorRun2Spring15Trig._name, ElectronMVAEstimatorRun2Spring15NonTrig._name, HistoParams< TH2F >._name, HistoParams< TProfile2D >._name, Vispa.Views.PropertyView.Property._name, SequenceTypes.SequencePlaceholder._name, plotting.Subtract._name, plotting.Transform._name, plotting.FakeDuplicate._name, plotting.FakeDuplicate._reco, HistoParams< T >._title, SiStripHitEffFromCalibTree._title, HistoParams< TH2F >._title, HistoParams< TProfile2D >._title, html.PageSet._title, html.HtmlReport._title, plotting.Subtract._title, plotting.Transform._title, and plotting.FakeDuplicate._title.

868  def create(self, tdirectory):
869  """Create and return the fake+duplicate histogram from a TDirectory"""
870  # Get the numerator/denominator histograms
871  hassoc = _getObject(tdirectory, self._assoc)
872  hdup = _getObject(tdirectory, self._dup)
873  hreco = _getObject(tdirectory, self._reco)
874 
875  # Skip if any of them does not exist
876  if not hassoc or not hdup or not hreco:
877  return None
878 
879  hfakedup = hreco.Clone(self._name)
880  hfakedup.SetTitle(self._title)
881 
882  for i in xrange(1, hassoc.GetNbinsX()+1):
883  numerVal = hassoc.GetBinContent(i) - hdup.GetBinContent(i)
884  denomVal = hreco.GetBinContent(i)
885 
886  fakedupVal = (1 - numerVal / denomVal) if denomVal != 0.0 else 0.0
887  errVal = math.sqrt(fakedupVal*(1-fakedupVal)/denomVal) if (denomVal != 0.0 and fakedupVal <= 1) else 0.0
888 
889  hfakedup.SetBinContent(i, fakedupVal)
890  hfakedup.SetBinError(i, errVal)
891 
892  return hfakedup
893 
def create(self, tdirectory)
Definition: plotting.py:868
def _getObject(tdirectory, name)
Definition: plotting.py:46

Member Data Documentation

plotting.FakeDuplicate._assoc
private

Definition at line 859 of file plotting.py.

Referenced by plotting.FakeDuplicate.create().

plotting.FakeDuplicate._dup
private

Definition at line 860 of file plotting.py.

Referenced by plotting.FakeDuplicate.create().

plotting.FakeDuplicate._name
private
plotting.FakeDuplicate._reco
private

Definition at line 861 of file plotting.py.

Referenced by plotting.FakeDuplicate.create().

plotting.FakeDuplicate._title
private