diff --git a/PhysicsTools/Heppy/interface/MuScleFitCorrector_Functions.h b/PhysicsTools/Heppy/interface/MuScleFitCorrector_Functions.h index b6608fe934787..d1552db04ea1f 100644 --- a/PhysicsTools/Heppy/interface/MuScleFitCorrector_Functions.h +++ b/PhysicsTools/Heppy/interface/MuScleFitCorrector_Functions.h @@ -20,316 +20,320 @@ * Used to define parameters inside the functions. */ -struct ParSet { - ParSet() {} - ParSet(const TString& inputName, const double& inputStep, const double& inputMini, const double& inputMaxi) - : step(inputStep), mini(inputMini), maxi(inputMaxi) { - std::cout << "setting name = " << inputName << std::endl; - name = inputName; - } - TString name; - double step, mini, maxi; -}; - -// ----------------------- // -// Scale functors // -// ----------------------- // - -template -class scaleFunctionBase { -public: - virtual double scale( - const double& pt, const double& eta, const double& phi, const int chg, const T& parScale) const = 0; - virtual ~scaleFunctionBase() = 0; - virtual int parNum() const { return parNum_; } - -protected: - int parNum_; - virtual void setPar(double* Start, - double* Step, - double* Mini, - double* Maxi, - int* ind, - TString* parname, - const T& parResol, - const std::vector& parResolOrder, - const std::vector& parSet) { - if (int(parSet.size()) != this->parNum_) { - std::cout << "Error: wrong number of parameter initializations = " << parSet.size() - << ". Number of parameters is " << this->parNum_ << std::endl; - exit(1); +namespace heppy { + struct ParSet { + ParSet() {} + ParSet(const TString& inputName, const double& inputStep, const double& inputMini, const double& inputMaxi) + : step(inputStep), mini(inputMini), maxi(inputMaxi) { + std::cout << "setting name = " << inputName << std::endl; + name = inputName; } - for (int iPar = 0; iPar < this->parNum_; ++iPar) { - Start[iPar] = parResol[iPar]; - Step[iPar] = parSet[iPar].step; - Mini[iPar] = parSet[iPar].mini; - Maxi[iPar] = parSet[iPar].maxi; - ind[iPar] = parResolOrder[iPar]; - parname[iPar] = parSet[iPar].name; + TString name; + double step, mini, maxi; + }; + + // ----------------------- // + // Scale functors // + // ----------------------- // + + template + class scaleFunctionBase { + public: + virtual double scale( + const double& pt, const double& eta, const double& phi, const int chg, const T& parScale) const = 0; + virtual ~scaleFunctionBase() = 0; + virtual int parNum() const { return parNum_; } + + protected: + int parNum_; + virtual void setPar(double* Start, + double* Step, + double* Mini, + double* Maxi, + int* ind, + TString* parname, + const T& parResol, + const std::vector& parResolOrder, + const std::vector& parSet) { + if (int(parSet.size()) != this->parNum_) { + std::cout << "Error: wrong number of parameter initializations = " << parSet.size() + << ". Number of parameters is " << this->parNum_ << std::endl; + exit(1); + } + for (int iPar = 0; iPar < this->parNum_; ++iPar) { + Start[iPar] = parResol[iPar]; + Step[iPar] = parSet[iPar].step; + Mini[iPar] = parSet[iPar].mini; + Maxi[iPar] = parSet[iPar].maxi; + ind[iPar] = parResolOrder[iPar]; + parname[iPar] = parSet[iPar].name; + } } - } -}; - -template -inline scaleFunctionBase::~scaleFunctionBase() { -} // defined even though it's pure virtual; should be faster this way. - -// -// Curvature: (linear eta + sinusoidal in phi (both in 5 eta bins)) * global scale -// ------------------------------------------------------------ -template -class scaleFunction50 : public scaleFunctionBase { -public: - scaleFunction50() { this->parNum_ = 27; } - virtual double scale(const double& pt, const double& eta, const double& phi, const int chg, const T& parScale) const { - double ampl(0), phase(0), twist(0), ampl2(0), freq2(0), phase2(0); - - // very bwd bin - if (eta < parScale[4]) { - ampl = parScale[1]; - phase = parScale[2]; - ampl2 = parScale[21]; - freq2 = parScale[22]; - phase2 = parScale[23]; - twist = - parScale[3] * (eta - parScale[4]) + parScale[7] * (parScale[4] - parScale[8]) + parScale[11] * parScale[8]; - // bwd bin - } else if (parScale[4] <= eta && eta < parScale[8]) { - ampl = parScale[5]; - phase = parScale[6]; - twist = parScale[7] * (eta - parScale[8]) + parScale[11] * parScale[8]; - // barrel bin - } else if (parScale[8] <= eta && eta < parScale[12]) { - ampl = parScale[9]; - phase = parScale[10]; - twist = parScale[11] * eta; - // fwd bin - } else if (parScale[12] <= eta && eta < parScale[16]) { - ampl = parScale[13]; - phase = parScale[14]; - twist = parScale[15] * (eta - parScale[12]) + parScale[11] * parScale[12]; - // very fwd bin - } else if (parScale[16] < eta) { - ampl = parScale[17]; - phase = parScale[18]; - ampl2 = parScale[24]; - freq2 = parScale[25]; - phase2 = parScale[26]; - twist = parScale[19] * (eta - parScale[16]) + parScale[15] * (parScale[16] - parScale[12]) + - parScale[11] * parScale[12]; + }; + + template + inline scaleFunctionBase::~scaleFunctionBase() { + } // defined even though it's pure virtual; should be faster this way. + + // + // Curvature: (linear eta + sinusoidal in phi (both in 5 eta bins)) * global scale + // ------------------------------------------------------------ + template + class scaleFunction50 : public scaleFunctionBase { + public: + scaleFunction50() { this->parNum_ = 27; } + virtual double scale( + const double& pt, const double& eta, const double& phi, const int chg, const T& parScale) const { + double ampl(0), phase(0), twist(0), ampl2(0), freq2(0), phase2(0); + + // very bwd bin + if (eta < parScale[4]) { + ampl = parScale[1]; + phase = parScale[2]; + ampl2 = parScale[21]; + freq2 = parScale[22]; + phase2 = parScale[23]; + twist = + parScale[3] * (eta - parScale[4]) + parScale[7] * (parScale[4] - parScale[8]) + parScale[11] * parScale[8]; + // bwd bin + } else if (parScale[4] <= eta && eta < parScale[8]) { + ampl = parScale[5]; + phase = parScale[6]; + twist = parScale[7] * (eta - parScale[8]) + parScale[11] * parScale[8]; + // barrel bin + } else if (parScale[8] <= eta && eta < parScale[12]) { + ampl = parScale[9]; + phase = parScale[10]; + twist = parScale[11] * eta; + // fwd bin + } else if (parScale[12] <= eta && eta < parScale[16]) { + ampl = parScale[13]; + phase = parScale[14]; + twist = parScale[15] * (eta - parScale[12]) + parScale[11] * parScale[12]; + // very fwd bin + } else if (parScale[16] < eta) { + ampl = parScale[17]; + phase = parScale[18]; + ampl2 = parScale[24]; + freq2 = parScale[25]; + phase2 = parScale[26]; + twist = parScale[19] * (eta - parScale[16]) + parScale[15] * (parScale[16] - parScale[12]) + + parScale[11] * parScale[12]; + } + + // apply the correction + double curv = (1. + parScale[0]) * ((double)chg / pt - twist - ampl * sin(phi + phase) - + ampl2 * sin(freq2 * phi + phase2) - 0.5 * parScale[20]); + return 1. / ((double)chg * curv); + } + }; + + // ----------------------- // + // Resolution functors // + // ----------------------- // + + template + class resolutionFunctionBase { + public: + virtual double sigmaPt(const double& pt, const double& eta, const T& parval) = 0; + + resolutionFunctionBase() {} + virtual ~resolutionFunctionBase() = 0; + virtual int parNum() const { return parNum_; } + + protected: + int parNum_; + }; + template + inline resolutionFunctionBase::~resolutionFunctionBase() { + } // defined even though it's pure virtual; should be faster this way. + + template + class resolutionFunction45 : public resolutionFunctionBase { + public: + resolutionFunction45() { this->parNum_ = 13; } + + inline double getGEO(const double& pt, const double& eta, const T& parval) { return parval[0]; } + + inline double getMS(const double& pt, const double& eta, const T& parval) { + if (eta < -2.0) + return (parval[1]); + if (eta < -1.8) + return (parval[2]); + if (eta < -1.6) + return (parval[3]); + if (eta < -1.2) + return (parval[4]); + if (eta < -0.8) + return (parval[5]); + if (eta < 0.) + return (parval[6]); + if (eta < 0.8) + return (parval[7]); + if (eta < 1.2) + return (parval[8]); + if (eta < 1.6) + return (parval[9]); + if (eta < 1.8) + return (parval[10]); + if (eta < 2.0) + return (parval[11]); + return (parval[12]); } - // apply the correction - double curv = (1. + parScale[0]) * ((double)chg / pt - twist - ampl * sin(phi + phase) - - ampl2 * sin(freq2 * phi + phase2) - 0.5 * parScale[20]); - return 1. / ((double)chg * curv); - } -}; - -// ----------------------- // -// Resolution functors // -// ----------------------- // - -template -class resolutionFunctionBase { -public: - virtual double sigmaPt(const double& pt, const double& eta, const T& parval) = 0; - - resolutionFunctionBase() {} - virtual ~resolutionFunctionBase() = 0; - virtual int parNum() const { return parNum_; } - -protected: - int parNum_; -}; -template -inline resolutionFunctionBase::~resolutionFunctionBase() { -} // defined even though it's pure virtual; should be faster this way. - -template -class resolutionFunction45 : public resolutionFunctionBase { -public: - resolutionFunction45() { this->parNum_ = 13; } - - inline double getGEO(const double& pt, const double& eta, const T& parval) { return parval[0]; } - - inline double getMS(const double& pt, const double& eta, const T& parval) { - if (eta < -2.0) - return (parval[1]); - if (eta < -1.8) - return (parval[2]); - if (eta < -1.6) - return (parval[3]); - if (eta < -1.2) - return (parval[4]); - if (eta < -0.8) - return (parval[5]); - if (eta < 0.) - return (parval[6]); - if (eta < 0.8) - return (parval[7]); - if (eta < 1.2) - return (parval[8]); - if (eta < 1.6) - return (parval[9]); - if (eta < 1.8) - return (parval[10]); - if (eta < 2.0) - return (parval[11]); - return (parval[12]); - } + virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { + return pt * getGEO(pt, eta, parval) + getMS(pt, eta, parval); + } + }; + + template + class resolutionFunction46 : public resolutionFunctionBase { + public: + resolutionFunction46() { this->parNum_ = 13; } + + int etaBin(const double& eta) { + // std::cout << "for eta = " << eta << ", bin = " << bin << std::endl; + + if (eta < -2.0) + return 1; + if (eta < -1.8) + return 2; + if (eta < -1.6) + return 3; + if (eta < -1.2) + return 4; + if (eta < -0.8) + return 5; + if (eta < 0.) + return 6; + if (eta < 0.8) + return 7; + if (eta < 1.2) + return 8; + if (eta < 1.6) + return 9; + if (eta < 1.8) + return 10; + if (eta < 2.0) + return 11; + return 12; + } - virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { - return pt * getGEO(pt, eta, parval) + getMS(pt, eta, parval); - } -}; - -template -class resolutionFunction46 : public resolutionFunctionBase { -public: - resolutionFunction46() { this->parNum_ = 13; } - - int etaBin(const double& eta) { - // std::cout << "for eta = " << eta << ", bin = " << bin << std::endl; - - if (eta < -2.0) - return 1; - if (eta < -1.8) - return 2; - if (eta < -1.6) - return 3; - if (eta < -1.2) - return 4; - if (eta < -0.8) - return 5; - if (eta < 0.) - return 6; - if (eta < 0.8) - return 7; - if (eta < 1.2) - return 8; - if (eta < 1.6) - return 9; - if (eta < 1.8) - return 10; - if (eta < 2.0) - return 11; - return 12; - } + virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { + return sqrt(pow(parval[0] * pt, 2) + pow(parval[etaBin(eta)], 2)); + } + }; + + // parametrization as sum in quadrature + // Geometric and MSC both as function of eta, adding straight lines between parabolas wrt type51 + template + class resolutionFunction57 : public resolutionFunctionBase { + public: + resolutionFunction57() { this->parNum_ = 17; } + + inline double getGEO(const double& pt, const double& eta, const T& parval) { + // geometrical term + double qGEO(0); + if (eta < parval[0]) { + qGEO = parval[10] * (eta - parval[0]) * (eta - parval[0]) + parval[11]; + } else if (parval[0] <= eta && eta < parval[3]) { + qGEO = parval[11]; + } else { + qGEO = parval[12] * (eta - parval[3]) * (eta - parval[3]) + parval[11]; + } + return qGEO; + } - virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { - return sqrt(pow(parval[0] * pt, 2) + pow(parval[etaBin(eta)], 2)); - } -}; - -// parametrization as sum in quadrature -// Geometric and MSC both as function of eta, adding straight lines between parabolas wrt type51 -template -class resolutionFunction57 : public resolutionFunctionBase { -public: - resolutionFunction57() { this->parNum_ = 17; } - - inline double getGEO(const double& pt, const double& eta, const T& parval) { - // geometrical term - double qGEO(0); - if (eta < parval[0]) { - qGEO = parval[10] * (eta - parval[0]) * (eta - parval[0]) + parval[11]; - } else if (parval[0] <= eta && eta < parval[3]) { - qGEO = parval[11]; - } else { - qGEO = parval[12] * (eta - parval[3]) * (eta - parval[3]) + parval[11]; + inline double centralParabola(const double& pt, const double& eta, const T& parval) { + return parval[4] + parval[5] * eta * eta; } - return qGEO; - } - inline double centralParabola(const double& pt, const double& eta, const T& parval) { - return parval[4] + parval[5] * eta * eta; - } + inline double middleParabola(const double& pt, const double& eta, const T& parval) { + return parval[15] + parval[16] * eta * eta; + } - inline double middleParabola(const double& pt, const double& eta, const T& parval) { - return parval[15] + parval[16] * eta * eta; - } + inline double leftParabola(const double& pt, const double& eta, const T& parval) { + return parval[6] + parval[7] * (eta - parval[0]) * (eta - parval[0]); + } - inline double leftParabola(const double& pt, const double& eta, const T& parval) { - return parval[6] + parval[7] * (eta - parval[0]) * (eta - parval[0]); - } + inline double rightParabola(const double& pt, const double& eta, const T& parval) { + return parval[8] + parval[9] * (eta - parval[3]) * (eta - parval[3]); + } - inline double rightParabola(const double& pt, const double& eta, const T& parval) { - return parval[8] + parval[9] * (eta - parval[3]) * (eta - parval[3]); - } + inline double leftLine(const double& pt, const double& eta, const T& parval) { + double x_1 = parval[13]; + double y_1 = middleParabola(pt, parval[13], parval); + double x_2 = parval[0]; + double y_2 = leftParabola(pt, parval[0], parval); + return ((eta - x_1) * (y_2 - y_1) / (x_2 - x_1) + y_1); + } - inline double leftLine(const double& pt, const double& eta, const T& parval) { - double x_1 = parval[13]; - double y_1 = middleParabola(pt, parval[13], parval); - double x_2 = parval[0]; - double y_2 = leftParabola(pt, parval[0], parval); - return ((eta - x_1) * (y_2 - y_1) / (x_2 - x_1) + y_1); - } + inline double rightLine(const double& pt, const double& eta, const T& parval) { + double x_1 = parval[14]; + double y_1 = middleParabola(pt, parval[14], parval); + double x_2 = parval[3]; + double y_2 = rightParabola(pt, parval[3], parval); + return ((eta - x_1) * (y_2 - y_1) / (x_2 - x_1) + y_1); + } - inline double rightLine(const double& pt, const double& eta, const T& parval) { - double x_1 = parval[14]; - double y_1 = middleParabola(pt, parval[14], parval); - double x_2 = parval[3]; - double y_2 = rightParabola(pt, parval[3], parval); - return ((eta - x_1) * (y_2 - y_1) / (x_2 - x_1) + y_1); - } + inline double getMSC(const double& pt, const double& eta, const T& parval) { + // MSC term + double qMSC(0); + if (eta < parval[0]) { + qMSC = leftParabola(pt, eta, parval); + } else if (parval[0] <= eta && eta < parval[13]) { + qMSC = leftLine(pt, eta, parval); + } else if (parval[13] <= eta && eta < parval[1]) { + qMSC = middleParabola(pt, eta, parval); + } else if (parval[1] <= eta && eta < parval[2]) { + qMSC = centralParabola(pt, eta, parval); + } else if (parval[2] <= eta && eta < parval[14]) { + qMSC = middleParabola(pt, eta, parval); + } else if (parval[14] <= eta && eta < parval[3]) { + qMSC = rightLine(pt, eta, parval); + } else { + qMSC = rightParabola(pt, eta, parval); + } + return qMSC; + } - inline double getMSC(const double& pt, const double& eta, const T& parval) { - // MSC term - double qMSC(0); - if (eta < parval[0]) { - qMSC = leftParabola(pt, eta, parval); - } else if (parval[0] <= eta && eta < parval[13]) { - qMSC = leftLine(pt, eta, parval); - } else if (parval[13] <= eta && eta < parval[1]) { - qMSC = middleParabola(pt, eta, parval); - } else if (parval[1] <= eta && eta < parval[2]) { - qMSC = centralParabola(pt, eta, parval); - } else if (parval[2] <= eta && eta < parval[14]) { - qMSC = middleParabola(pt, eta, parval); - } else if (parval[14] <= eta && eta < parval[3]) { - qMSC = rightLine(pt, eta, parval); - } else { - qMSC = rightParabola(pt, eta, parval); + virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { + double qGEO = getGEO(pt, eta, parval); + double qMSC = getMSC(pt, eta, parval); + return sqrt(pow(qGEO * pt, 2) + pow(qMSC, 2)); + } + }; + + // Service to build the scale functor corresponding to the passed identifier + scaleFunctionBase* scaleFunctionService(const int identifier) { + switch (identifier) { + case (50): + return (new scaleFunction50); + break; + default: + std::cout << "scaleFunctionService error: wrong identifier = " << identifier << std::endl; + exit(1); } - return qMSC; } - virtual double sigmaPt(const double& pt, const double& eta, const T& parval) { - double qGEO = getGEO(pt, eta, parval); - double qMSC = getMSC(pt, eta, parval); - return sqrt(pow(qGEO * pt, 2) + pow(qMSC, 2)); - } -}; - -// Service to build the scale functor corresponding to the passed identifier -scaleFunctionBase* scaleFunctionService(const int identifier) { - switch (identifier) { - case (50): - return (new scaleFunction50); - break; - default: - std::cout << "scaleFunctionService error: wrong identifier = " << identifier << std::endl; - exit(1); - } -} - -// Service to build the resolution functor corresponding to the passed identifier -resolutionFunctionBase* resolutionFunctionService(const int identifier) { - switch (identifier) { - case (45): - return (new resolutionFunction45); - break; - case (46): - return (new resolutionFunction46); - break; - case (57): - return (new resolutionFunction57); - break; - default: - std::cout << "resolutionFunctService error: wrong identifier = " << identifier << std::endl; - exit(1); + // Service to build the resolution functor corresponding to the passed identifier + resolutionFunctionBase* resolutionFunctionService(const int identifier) { + switch (identifier) { + case (45): + return (new resolutionFunction45); + break; + case (46): + return (new resolutionFunction46); + break; + case (57): + return (new resolutionFunction57); + break; + default: + std::cout << "resolutionFunctService error: wrong identifier = " << identifier << std::endl; + exit(1); + } } -} + +} // namespace heppy #endif