cepgen is hosted by Hepforge, IPPP Durham
CepGen N/A
Central exclusive processes event generator
GSLMonteFunctionWrapper.h
Go to the documentation of this file.
1/*
2 * CepGen: a central exclusive processes event generator
3 * Copyright (C) 2013-2025 Laurent Forthomme
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef CepGen_Utils_GSLMonteFunctionWrapper_h
20#define CepGen_Utils_GSLMonteFunctionWrapper_h
21
22#include <gsl/gsl_monte.h>
23
24#include <memory>
25
26namespace cepgen::utils {
29 template <typename F>
30 class GSLMonteFunctionWrapper : public gsl_monte_function {
31 public:
32 explicit GSLMonteFunctionWrapper(const F& func, size_t num_dimensions) : func_(func) {
33 f = &GSLMonteFunctionWrapper::eval;
34 dim = num_dimensions;
35 params = this;
36 }
38 static std::unique_ptr<gsl_monte_function> build(const F& func, size_t num_dimensions) {
39 return std::unique_ptr<gsl_monte_function>(new GSLMonteFunctionWrapper<decltype(func)>(func, num_dimensions));
40 }
41
42 private:
44 static double eval(double* x, size_t num_dimensions, void* params) {
45 return static_cast<GSLMonteFunctionWrapper*>(params)->func_(x, num_dimensions, params);
46 }
47 const F& func_;
48 };
49} // namespace cepgen::utils
50
51#endif
GSL wrapper to define a functor as an integrable functional.
GSLMonteFunctionWrapper(const F &func, size_t num_dimensions)
static std::unique_ptr< gsl_monte_function > build(const F &func, size_t num_dimensions)
Utility to build a gsl_monte_function pointer from a functional and phase space size.
Collection of utilities.