13#ifndef ROOT_Fit_LogLikelihoodFCN
14#define ROOT_Fit_LogLikelihoodFCN
39template<
class DerivFunType,
class ModelFunType = ROOT::Math::IParamMultiFunction>
44 typedef typename ModelFunType::BackendType
T;
121 double DataElement(
const double *
x,
unsigned int i,
double *
g,
double *
h =
nullptr,
bool fullHessian =
false)
const override {
155 double DoEval (
const double *
x)
const override {
163 return fGrad[icoord];
void SetData(const std::shared_ptr< UnBinData > &data)
std::shared_ptr< IModelFunction > ModelFunctionPtr() const
void SetModelFunction(const std::shared_ptr< IModelFunction > &func)
virtual const DataType & Data() const
access to const reference to the data
BasicFCN(const std::shared_ptr< UnBinData > &data, const std::shared_ptr< IModelFunction > &func)
std::shared_ptr< UnBinData > DataPtr() const
virtual const IModelFunction & ModelFunction() const
access to const reference to the model function
LogLikelihoodFCN class for likelihood fits.
BaseObjFunction::BaseFunction BaseFunction
LogLikelihoodFCN(const UnBinData &data, const IModelFunction &func, int weight=0, bool extended=false, const ::ROOT::EExecutionPolicy &executionPolicy=::ROOT::EExecutionPolicy::kSequential)
Constructor from unbin data set and model function (pdf) for object managed by users.
LogLikelihoodFCN & operator=(const LogLikelihoodFCN &rhs)
Assignment operator.
::ROOT::Math::IParamMultiFunctionTempl< T > IModelFunction
LogLikelihoodFCN(const LogLikelihoodFCN &f)
Copy constructor.
double DoEval(const double *x) const override
Evaluation of the function (required by interface).
BasicFCN< DerivFunType, ModelFunType, UnBinData > BaseFCN
BaseFunction * Clone() const override
double DataElement(const double *x, unsigned int i, double *g, double *h=nullptr, bool fullHessian=false) const override
i-th likelihood contribution and its gradient
ModelFunType::BackendType T
LogLikelihoodFCN(const std::shared_ptr< UnBinData > &data, const std::shared_ptr< IModelFunction > &func, int weight=0, bool extended=false, const ::ROOT::EExecutionPolicy &executionPolicy=::ROOT::EExecutionPolicy::kSequential)
Constructor from unbin data set and model function (pdf).
void UseSumOfWeightSquare(bool on=true)
BaseObjFunction::Type_t Type() const override
get type of fit method function
::ROOT::Math::BasicFitMethodFunction< DerivFunType > BaseObjFunction
virtual ~LogLikelihoodFCN()
Destructor (no operations).
virtual unsigned int NFitPoints() const
double DoDerivative(const double *x, unsigned int icoord) const override
void Gradient(const double *x, double *g) const override
std::vector< double > fGrad
BaseObjFunction::Type_t Type_t
::ROOT::EExecutionPolicy fExecutionPolicy
Class describing the un-binned data sets (just x coordinates values) of any dimensions.
DerivFunType::BaseFunc BaseFunction
virtual void UpdateNCalls() const
Namespace for the fitting classes.
LogLikelihoodFCN< ROOT::Math::IMultiGenFunction, ROOT::Math::IParamMultiFunction > LogLikelihoodFunction
LogLikelihoodFCN< ROOT::Math::IMultiGradFunction, ROOT::Math::IParamMultiFunction > LogLikelihoodGradFunction