cepgen is hosted by Hepforge, IPPP Durham
CepGen 1.2.5
Central exclusive processes event generator
Loading...
Searching...
No Matches
FunctionalIntegrand.cpp
Go to the documentation of this file.
1/*
2 * CepGen: a central exclusive processes event generator
3 * Copyright (C) 2013-2022 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
23
24namespace cepgen {
26 const std::vector<std::string>& vars,
27 const std::string& func_eval)
28 : func_(FunctionalFactory::get().build(
29 func_eval,
30 ParametersList().set<std::string>("expression", expr).set<std::vector<std::string> >("variables", vars))) {
31 CG_DEBUG("FunctionalIntegrand") << "Built a " << func_eval << " " << func_->variables().size()
32 << "-dimensional functional with variables " << func_->variables() << " (" << vars
33 << "): " << func_->expression() << ".";
34 }
35
36 double FunctionalIntegrand::eval(const std::vector<double>& x) {
37 if (!func_)
38 throw CG_FATAL("FunctionalIntegrand:eval") << "Functional object was not properly initialised!";
39 if (x.size() != size())
40 throw CG_FATAL("FunctionalIntegrand:eval")
41 << "Invalid coordinates multiplicity: expected(" << size() << ") != received(" << x.size() << ")!";
42 return (*func_)(x);
43 }
44
46 if (!func_)
47 throw CG_FATAL("FunctionalIntegrand:eval") << "Functional object was not properly initialised!";
48 return func_->variables().size();
49 }
50} // namespace cepgen
#define CG_FATAL(mod)
Definition Exception.h:61
#define CG_DEBUG(mod)
Definition Message.h:220
FunctionalIntegrand(const std::string &, const std::vector< std::string > &, const std::string &func_eval)
double eval(const std::vector< double > &) override
Compute the integrand for a given coordinates set.
size_t size() const override
Phase space dimension.
Common namespace for this Monte Carlo generator.