Logo ROOT  
Reference Guide
 
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
Loading...
Searching...
No Matches
RooFuncWrapper.h
Go to the documentation of this file.
1/*
2 * Project: RooFit
3 * Authors:
4 * Garima Singh, CERN 2022
5 *
6 * Copyright (c) 2022, CERN
7 *
8 * Redistribution and use in source and binary forms,
9 * with or without modification, are permitted according to the terms
10 * listed in LICENSE (http://roofit.sourceforge.net/license.txt)
11 */
12
13#ifndef RooFit_RooFuncWrapper_h
14#define RooFit_RooFuncWrapper_h
15
16#include <RooAbsReal.h>
17#include <RooListProxy.h>
18
19#include <map>
20#include <memory>
21#include <string>
22#include <sstream>
23
24class RooSimultaneous;
25
26namespace RooFit {
27
28namespace Experimental {
29
30/// @brief A wrapper class to store a C++ function of type 'double (*)(double*, double*)'.
31/// The parameters can be accessed as params[<relative position of param in paramSet>] in the function body.
32/// The observables can be accessed as obs[i + j], where i represents the observable position and j
33/// represents the data entry.
34class RooFuncWrapper final : public RooAbsReal {
35public:
36 RooFuncWrapper(const char *name, const char *title, RooAbsReal &obj, const RooAbsData *data = nullptr,
37 RooSimultaneous const *simPdf = nullptr, bool useEvaluator = false);
38
39 RooFuncWrapper(const RooFuncWrapper &other, const char *name = nullptr);
40
41 TObject *clone(const char *newname) const override { return new RooFuncWrapper(*this, newname); }
42
43 double defaultErrorLevel() const override { return 0.5; }
44
45 bool hasGradient() const override { return _hasGradient; }
46 void gradient(double *out) const override;
47
48 void gradient(const double *x, double *g) const;
49
50 std::size_t getNumParams() const { return _params.size(); }
51
52 /// No constant term optimization is possible in code-generation mode.
53 void constOptimizeTestStatistic(ConstOpCode /*opcode*/, bool /*doAlsoTrackingOpt*/) override {}
54
55 std::string const &funcName() const { return _funcName; }
56
57 void createGradient();
58
59 void disableEvaluator() { _useEvaluator = false; }
60
61 void writeDebugMacro(std::string const &) const;
62
63 std::vector<std::string> const &collectedFunctions() { return _collectedFunctions; }
64
65protected:
66 double evaluate() const override;
67
68private:
69 void updateGradientVarBuffer() const;
70
71 std::map<RooFit::Detail::DataKey, std::span<const double>>
72 loadParamsAndData(RooArgSet const &paramSet, const RooAbsData *data, RooSimultaneous const *simPdf);
73
75
76 using Func = double (*)(double *, double const *, double const *);
77 using Grad = void (*)(double *, double const *, double const *, double *);
78
79 struct ObsInfo {
80 ObsInfo(std::size_t i, std::size_t n) : idx{i}, size{n} {}
81 std::size_t idx = 0;
82 std::size_t size = 0;
83 };
84
85 std::unique_ptr<RooAbsReal> _absReal;
87 std::string _funcName;
90 bool _hasGradient = false;
91 bool _useEvaluator = false;
92 mutable std::vector<double> _gradientVarBuffer;
93 std::vector<double> _observables;
94 std::map<RooFit::Detail::DataKey, ObsInfo> _obsInfos;
95 std::vector<double> _xlArr;
96 std::vector<std::string> _collectedFunctions;
97};
98
99} // namespace Experimental
100
101} // namespace RooFit
102
103#endif
#define g(i)
Definition RSha256.hxx:105
Option_t Option_t TPoint TPoint const char GetTextMagnitude GetFillStyle GetLineColor GetLineWidth GetMarkerStyle GetTextAlign GetTextColor GetTextSize void data
char name[80]
Definition TGX11.cxx:110
Storage_t::size_type size() const
Abstract base class for binned and unbinned datasets.
Definition RooAbsData.h:57
Abstract base class for objects that represent a real value and implements functionality common to al...
Definition RooAbsReal.h:59
RooArgSet is a container object that can hold multiple RooAbsArg objects.
Definition RooArgSet.h:24
A wrapper class to store a C++ function of type 'double (*)(double*, double*)'.
std::vector< std::string > const & collectedFunctions()
std::string const & funcName() const
double(*)(double *, double const *, double const *) Func
double evaluate() const override
Evaluate this PDF / function / constant. Needs to be overridden by all derived classes.
std::unique_ptr< RooAbsReal > _absReal
std::vector< std::string > _collectedFunctions
TObject * clone(const char *newname) const override
double defaultErrorLevel() const override
std::map< RooFit::Detail::DataKey, std::span< const double > > loadParamsAndData(RooArgSet const &paramSet, const RooAbsData *data, RooSimultaneous const *simPdf)
void writeDebugMacro(std::string const &) const
Dumps a macro "filename.C" that can be used to test and debug the generated code and gradient.
void constOptimizeTestStatistic(ConstOpCode, bool) override
No constant term optimization is possible in code-generation mode.
void gradient(double *out) const override
std::map< RooFit::Detail::DataKey, ObsInfo > _obsInfos
std::vector< double > _gradientVarBuffer
void(*)(double *, double const *, double const *, double *) Grad
Facilitates simultaneous fitting of multiple PDFs to subsets of a given dataset.
Mother of all ROOT objects.
Definition TObject.h:41
Double_t x[n]
Definition legend1.C:17
const Int_t n
Definition legend1.C:16
The namespace RooFit contains mostly switches that change the behaviour of functions of PDFs (or othe...
Definition CodegenImpl.h:64