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
19
#include "
CepGen/Core/Exception.h
"
20
#include "
CepGen/Integration/FunctionalIntegrand.h
"
21
#include "
CepGen/Modules/FunctionalFactory.h
"
22
#include "
CepGen/Utils/Functional.h
"
23
24
namespace
cepgen
{
25
FunctionalIntegrand::FunctionalIntegrand
(
const
std::string& expr,
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
45
size_t
FunctionalIntegrand::size
()
const
{
46
if
(!func_)
47
throw
CG_FATAL
(
"FunctionalIntegrand:eval"
) <<
"Functional object was not properly initialised!"
;
48
return
func_->variables().size();
49
}
50
}
// namespace cepgen
Exception.h
CG_FATAL
#define CG_FATAL(mod)
Definition
Exception.h:61
FunctionalFactory.h
FunctionalIntegrand.h
Functional.h
CG_DEBUG
#define CG_DEBUG(mod)
Definition
Message.h:220
cepgen::FunctionalIntegrand::FunctionalIntegrand
FunctionalIntegrand(const std::string &, const std::vector< std::string > &, const std::string &func_eval)
Definition
FunctionalIntegrand.cpp:25
cepgen::FunctionalIntegrand::eval
double eval(const std::vector< double > &) override
Compute the integrand for a given coordinates set.
Definition
FunctionalIntegrand.cpp:36
cepgen::FunctionalIntegrand::size
size_t size() const override
Phase space dimension.
Definition
FunctionalIntegrand.cpp:45
cepgen::ParametersList
Definition
ParametersList.h:52
cepgen
Common namespace for this Monte Carlo generator.
Definition
CommandLineHandler.cpp:36
CepGen
Integration
FunctionalIntegrand.cpp
Generated on Mon Jul 29 2024 for CepGen by
1.9.7