|
||||
File indexing completed on 2025-01-18 10:10:22
0001 // @(#)root/mathmore:$Id$ 0002 // Authors: B. List 29.4.2010 0003 0004 /********************************************************************** 0005 * * 0006 * Copyright (c) 2004 ROOT Foundation, CERN/PH-SFT * 0007 * * 0008 * This library is free software; you can redistribute it and/or * 0009 * modify it under the terms of the GNU General Public License * 0010 * as published by the Free Software Foundation; either version 2 * 0011 * of the License, or (at your option) any later version. * 0012 * * 0013 * This library is distributed in the hope that it will be useful, * 0014 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 0015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 0016 * General Public License for more details. * 0017 * * 0018 * You should have received a copy of the GNU General Public License * 0019 * along with this library (see file COPYING); if not, write * 0020 * to the Free Software Foundation, Inc., 59 Temple Place, Suite * 0021 * 330, Boston, MA 02111-1307 USA, or contact the author. * 0022 * * 0023 **********************************************************************/ 0024 0025 // Header file for class VavilovAccuratePdf 0026 // 0027 // Created by: blist at Thu Apr 29 11:19:00 2010 0028 // 0029 // Last update: Thu Apr 29 11:19:00 2010 0030 // 0031 #ifndef ROOT_Math_VavilovAccuratePdf 0032 #define ROOT_Math_VavilovAccuratePdf 0033 0034 0035 #include "Math/IParamFunction.h" 0036 #include "Math/VavilovAccurate.h" 0037 0038 #include <string> 0039 0040 namespace ROOT { 0041 namespace Math { 0042 0043 //____________________________________________________________________________ 0044 /** 0045 Class describing the Vavilov pdf. 0046 0047 The probability density function of the Vavilov distribution 0048 is given by: 0049 \f[ p(\lambda; \kappa, \beta^2) = 0050 \frac{1}{2 \pi i}\int_{c-i\infty}^{c+i\infty} \phi(s) e^{\lambda s} ds\f] 0051 where \f$\phi(s) = e^{C} e^{\psi(s)}\f$ 0052 with \f$ C = \kappa (1+\beta^2 \gamma )\f$ 0053 and \f[\psi(s) = s \ln \kappa + (s+\beta^2 \kappa) 0054 \cdot \left ( \int \limits_{0}^{1} 0055 \frac{1 - e^{\frac{-st}{\kappa}}}{t} \, dt- \gamma \right ) 0056 - \kappa \, e^{\frac{-s}{\kappa}}\f]. 0057 \f$ \gamma = 0.5772156649\dots\f$ is Euler's constant. 0058 0059 The parameters are: 0060 - 0: Norm: Normalization constant 0061 - 1: x0: Location parameter 0062 - 2: xi: Width parameter 0063 - 3: kappa: Parameter \f$\kappa\f$ of the Vavilov distribution 0064 - 4: beta2: Parameter \f$\beta^2\f$ of the Vavilov distribution 0065 0066 Benno List, June 2010 0067 0068 @ingroup StatFunc 0069 */ 0070 0071 0072 class VavilovAccuratePdf: public IParametricFunctionOneDim { 0073 public: 0074 0075 /** 0076 Default constructor 0077 */ 0078 VavilovAccuratePdf(); 0079 0080 /** 0081 Constructor with parameter values 0082 @param p vector of doubles containing the parameter values (Norm, x0, xi, kappa, beta2). 0083 */ 0084 VavilovAccuratePdf (const double *p); 0085 0086 /** 0087 Destructor 0088 */ 0089 ~VavilovAccuratePdf () override; 0090 0091 /** 0092 Access the parameter values 0093 */ 0094 const double * Parameters() const override; 0095 0096 /** 0097 Set the parameter values 0098 0099 @param p vector of doubles containing the parameter values (Norm, x0, xi, kappa, beta2). 0100 0101 */ 0102 void SetParameters(const double * p ) override; 0103 0104 /** 0105 Return the number of Parameters 0106 */ 0107 unsigned int NPar() const override; 0108 0109 /** 0110 Return the name of the i-th parameter (starting from zero) 0111 */ 0112 std::string ParameterName(unsigned int i) const override; 0113 0114 /** 0115 Evaluate the function 0116 0117 @param x The Landau parameter \f$x = \lambda_L\f$ 0118 */ 0119 double DoEval(double x) const override; 0120 0121 /** 0122 Evaluate the function, using parameters p 0123 0124 @param x The Landau parameter \f$x = \lambda_L\f$ 0125 @param p vector of doubles containing the parameter values (Norm, x0, xi, kappa, beta2). 0126 */ 0127 double DoEvalPar(double x, const double * p) const override; 0128 0129 /** 0130 Return a clone of the object 0131 */ 0132 IBaseFunctionOneDim * Clone() const override; 0133 0134 private: 0135 double fP[5]; 0136 0137 }; 0138 0139 0140 } // namespace Math 0141 } // namespace ROOT 0142 0143 #endif /* ROOT_Math_VavilovAccuratePdf */
[ Source navigation ] | [ Diff markup ] | [ Identifier search ] | [ general search ] |
This page was automatically generated by the 2.3.7 LXR engine. The LXR team |