DiFfRG
|
Integration of an arbitrary 1D function from qx_min to qx_max using TBB. More...
#include <integrator_1D_cartesian_cpu.hh>
Public Types | |
using | ctype = typename get_type::ctype<NT> |
Numerical type to be used for integration tasks e.g. the argument or possible jacobians. | |
Public Member Functions | |
Integrator1DCartesianTBB (QuadratureProvider &quadrature_provider, const std::array< uint, 1 > grid_size, const ctype x_extent=0., const uint max_block_size=0, const ctype qx_min=-M_PI, const ctype qx_max=M_PI) | |
Construct a new Integrator1DCartesianTBB object. | |
Integrator1DCartesianTBB (QuadratureProvider &quadrature_provider, const std::array< uint, 1 > grid_size, const JSONValue &json) | |
Construct a new Integrator1DCartesianTBB object. | |
Integrator1DCartesianTBB (QuadratureProvider &quadrature_provider, const std::array< uint, 1 > grid_size, const ctype x_extent, const JSONValue &json) | |
Construct a new Integrator1DCartesianTBB object. | |
Integrator1DCartesianTBB (QuadratureProvider &quadrature_provider, const uint grid_size, const ctype x_extent=0., const ctype qx_min=-M_PI, const ctype qx_max=M_PI) | |
Construct a new Integrator1DCartesianTBB object. | |
void | set_qx_min (const ctype qx_min) |
Set the minimum value of the qx integration range. | |
void | set_qx_max (const ctype qx_max) |
Set the maximum value of the qx integration range. | |
template<typename... T> | |
NT | get (const ctype k, const T &...t) const |
Get the integration result. | |
template<typename... T> | |
std::future< NT > | request (const ctype k, const T &...t) const |
Get the integration result asynchronously. | |
Private Attributes | |
const uint | grid_size |
ctype | qx_min = -M_PI |
ctype | qx_extent = 2. * M_PI |
const std::vector< ctype > & | x_quadrature_p |
const std::vector< ctype > & | x_quadrature_w |
Integration of an arbitrary 1D function from qx_min to qx_max using TBB.
NT | The numerical type of the result. |
KERNEL | The kernel to integrate. |
using DiFfRG::Integrator1DCartesianTBB< NT, KERNEL >::ctype = typename get_type::ctype<NT> |
Numerical type to be used for integration tasks e.g. the argument or possible jacobians.
|
inline |
Construct a new Integrator1DCartesianTBB object.
quadrature_provider | The quadrature provider to use. |
grid_size | The number of grid points in x direction. |
x_extent | The extent of the x integration range. This argument is not used, but kept for compatibility with flow classes. |
qx_min | The minimum value of the x integration range. |
qx_max | The maximum value of the x integration range. |
|
inline |
Construct a new Integrator1DCartesianTBB object.
quadrature_provider | The quadrature provider to use. |
grid_size | The number of grid points in x direction. |
x_extent | This argument is not used, but kept for compatibility with flow classes. |
max_block_size | The maximum block size to use on GPU. This argument is not used, but kept for compatibility. |
qx_min | The minimum value of the x integration range. |
qx_max | The maximum value of the x integration range. |
|
inline |
Construct a new Integrator1DCartesianTBB object.
quadrature_provider | The quadrature provider to use. |
grid_size | The number of grid points in x direction. |
x_extent | This argument is not used, but kept for compatibility with flow classes. |
qx_min | The minimum value of the x integration range. |
qx_max | The maximum value of the x integration range. |
|
inline |
Construct a new Integrator1DCartesianTBB object.
quadrature_provider | The quadrature provider to use. |
grid_size | The number of grid points in x direction. |
x_extent | This argument is not used, but kept for compatibility with flow classes. |
qx_min | The minimum value of the x integration range. |
qx_max | The maximum value of the x integration range. |
|
inline |
Get the integration result.
T | The types of the additional arguments to the kernel. |
k | The current RG scale. |
t | The additional arguments of the kernel. |
|
inline |
Get the integration result asynchronously.
T | The types of the additional arguments to the kernel. |
k | The current RG scale. |
t | The additional arguments of the kernel. |
|
inline |
Set the maximum value of the qx integration range.
|
inline |
Set the minimum value of the qx integration range.
|
private |
|
private |
|
private |
|
private |
|
private |