CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Protected Member Functions | Protected Attributes
resolutionFunctionBase< T > Class Template Referenceabstract

#include <Functions.h>

Inheritance diagram for resolutionFunctionBase< T >:
resolutionFunctionType1< T > resolutionFunctionType10< T > resolutionFunctionType11< T > resolutionFunctionType12< T > resolutionFunctionType13< T > resolutionFunctionType14< T > resolutionFunctionType15< T > resolutionFunctionType17< T > resolutionFunctionType18< T > resolutionFunctionType19< T > resolutionFunctionType20< T > resolutionFunctionType30< T > resolutionFunctionType6< T > resolutionFunctionType7< T > resolutionFunctionType8< T > resolutionFunctionType9< T >

Public Member Functions

virtual double covPt1Pt2 (const double &pt1, const double &eta1, const double &pt2, const double &eta2, const T &parval)
 
virtual int parNum () const
 
 resolutionFunctionBase ()
 
virtual void setParameters (double *Start, double *Step, double *Mini, double *Maxi, int *ind, TString *parname, const T &parResol, const std::vector< int > &parResolOrder, const int muonType)=0
 This method is used to differentiate parameters among the different functions. More...
 
virtual double sigmaCotgTh (const double &pt, const double &eta, const T &parval)=0
 
virtual double sigmaPhi (const double &pt, const double &eta, const T &parval)=0
 
virtual double sigmaPt (const double &pt, const double &eta, const T &parval)=0
 
virtual double sigmaPtError (const double &pt, const double &eta, const T &parval, const T &parError)
 
virtual ~resolutionFunctionBase ()=0
 

Protected Member Functions

virtual void setPar (double *Start, double *Step, double *Mini, double *Maxi, int *ind, TString *parname, const T &parResol, const std::vector< int > &parResolOrder, double *thisStep, double *thisMini, double *thisMaxi, TString *thisParName)
 This method sets the parameters. More...
 
virtual void setPar (double *Start, double *Step, double *Mini, double *Maxi, int *ind, TString *parname, const T &parResol, const std::vector< int > &parResolOrder, const std::vector< ParameterSet > &parSet)
 

Protected Attributes

int parNum_
 

Detailed Description

template<class T>
class resolutionFunctionBase< T >

Resolution functions.
Need to use templates to make it work with both array and std::vector<double>.

Definition at line 1522 of file Functions.h.

Constructor & Destructor Documentation

template<class T>
resolutionFunctionBase< T >::resolutionFunctionBase ( )
inline

Definition at line 1535 of file Functions.h.

1535 {}
template<class T >
resolutionFunctionBase< T >::~resolutionFunctionBase ( )
inlinepure virtual

Definition at line 1571 of file Functions.h.

1571 { } // defined even though it's pure virtual; should be faster this way.

Member Function Documentation

template<class T>
virtual double resolutionFunctionBase< T >::covPt1Pt2 ( const double &  pt1,
const double &  eta1,
const double &  pt2,
const double &  eta2,
const T parval 
)
inlinevirtual

Reimplemented in resolutionFunctionType30< T >.

Definition at line 1531 of file Functions.h.

Referenced by MuScleFitUtils::massResolution().

1532  {
1533  return 0.;
1534  }
template<class T>
virtual int resolutionFunctionBase< T >::parNum ( ) const
inlinevirtual

Definition at line 1539 of file Functions.h.

Referenced by MuScleFitUtils::minimizeLikelihood().

1539 { return parNum_; }
template<class T>
virtual void resolutionFunctionBase< T >::setPar ( double *  Start,
double *  Step,
double *  Mini,
double *  Maxi,
int *  ind,
TString *  parname,
const T parResol,
const std::vector< int > &  parResolOrder,
double *  thisStep,
double *  thisMini,
double *  thisMaxi,
TString *  thisParName 
)
inlineprotectedvirtual
template<class T>
virtual void resolutionFunctionBase< T >::setPar ( double *  Start,
double *  Step,
double *  Mini,
double *  Maxi,
int *  ind,
TString *  parname,
const T parResol,
const std::vector< int > &  parResolOrder,
const std::vector< ParameterSet > &  parSet 
)
inlineprotectedvirtual

Definition at line 1555 of file Functions.h.

1556  {
1557  if( int(parSet.size()) != this->parNum_ ) {
1558  std::cout << "Error: wrong number of parameter initializations = " << parSet.size() << ". Number of parameters is " << this->parNum_ << std::endl;
1559  exit(1);
1560  }
1561  for( int iPar=0; iPar<this->parNum_; ++iPar ) {
1562  Start[iPar] = parResol[iPar];
1563  Step[iPar] = parSet[iPar].step;
1564  Mini[iPar] = parSet[iPar].mini;
1565  Maxi[iPar] = parSet[iPar].maxi;
1566  ind[iPar] = parResolOrder[iPar];
1567  parname[iPar] = parSet[iPar].name;
1568  }
1569  }
tuple cout
Definition: gather_cfg.py:41
template<class T>
virtual void resolutionFunctionBase< T >::setParameters ( double *  Start,
double *  Step,
double *  Mini,
double *  Maxi,
int *  ind,
TString *  parname,
const T parResol,
const std::vector< int > &  parResolOrder,
const int  muonType 
)
pure virtual
template<class T>
virtual double resolutionFunctionBase< T >::sigmaCotgTh ( const double &  pt,
const double &  eta,
const T parval 
)
pure virtual
template<class T>
virtual double resolutionFunctionBase< T >::sigmaPhi ( const double &  pt,
const double &  eta,
const T parval 
)
pure virtual
template<class T>
virtual double resolutionFunctionBase< T >::sigmaPt ( const double &  pt,
const double &  eta,
const T parval 
)
pure virtual
template<class T>
virtual double resolutionFunctionBase< T >::sigmaPtError ( const double &  pt,
const double &  eta,
const T parval,
const T parError 
)
inlinevirtual

Reimplemented in resolutionFunctionType30< T >.

Definition at line 1525 of file Functions.h.

Referenced by ErrorsPropagationAnalyzer::fillHistograms().

1526  {
1527  return 0.;
1528  }

Member Data Documentation

template<class T>
int resolutionFunctionBase< T >::parNum_
protected