|
DiFfRG
|
Integration of an arbitrary 2D function from (qx_min, qy_min) to (qx_max, qy_max) using TBB. More...
#include <integrator_2D_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 | |
| Integrator2DCartesianTBB (QuadratureProvider &quadrature_provider, const std::array< uint, 2 > grid_sizes, const ctype x_extent, const JSONValue &json) | |
| Construct a new Integrator2DCartesianTBB object. | |
| Integrator2DCartesianTBB (QuadratureProvider &quadrature_provider, std::array< uint, 2 > grid_sizes, const ctype x_extent, const uint max_block_size=0, const ctype qx_min=-M_PI, const ctype qy_min=-M_PI, const ctype qx_max=M_PI, const ctype qy_max=M_PI) | |
| Construct a new Integrator2DCartesianTBB object. | |
| void | set_qx_min (const ctype qx_min) |
| Set the minimum value of the qx integration range. | |
| void | set_qy_min (const ctype qy_min) |
| Set the minimum value of the qy integration range. | |
| void | set_qx_max (const ctype qx_max) |
| Set the maximum value of the qx integration range. | |
| void | set_qy_max (const ctype qy_max) |
| Set the maximum value of the qy integration range. | |
| template<typename... T> | |
| NT | get (const ctype k, const T &...t) const |
| Get the value of the integral. | |
| template<typename... T> | |
| std::future< NT > | request (const ctype k, const T &...t) const |
| Get the value of the integral asynchronously. | |
Private Attributes | |
| const std::array< uint, 2 > | grid_sizes |
| ctype | qx_min = -M_PI |
| ctype | qy_min = -M_PI |
| ctype | qx_extent = 2 * M_PI |
| ctype | qy_extent = 2 * M_PI |
| const std::vector< ctype > & | x_quadrature_p |
| const std::vector< ctype > & | x_quadrature_w |
| const std::vector< ctype > & | y_quadrature_p |
| const std::vector< ctype > & | y_quadrature_w |
Integration of an arbitrary 2D function from (qx_min, qy_min) to (qx_max, qy_max) using TBB.
| NT | The numerical type of the result. |
| KERNEL | The kernel to integrate. |
| using DiFfRG::Integrator2DCartesianTBB< 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 Integrator2DCartesianTBB object.
| quadrature_provider | The quadrature provider to use. |
| grid_sizes | The number of grid points in x and y direction. |
| x_extent | The extent of the x integration range. This argument is not used, but kept for compatibility with flow classes. |
| json | The JSON object to read additional parameters from. |
|
inline |
Construct a new Integrator2DCartesianTBB object.
| quadrature_provider | The quadrature provider to use. |
| grid_sizes | The number of grid points in x and y direction. |
| x_extent | The extent of the x integration range. 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. |
| qy_min | The minimum value of the y integration range. |
| qx_max | The maximum value of the x integration range. |
| qy_max | The maximum value of the y integration range. |
|
inline |
Get the value of the integral.
| k | The current RG scale. |
| t | The additional parameters for the kernel. |
|
inline |
Get the value of the integral asynchronously.
| k | The current RG scale. |
| t | The additional parameters for the kernel. |
|
inline |
Set the maximum value of the qx integration range.
|
inline |
Set the minimum value of the qx integration range.
|
inline |
Set the maximum value of the qy integration range.
|
inline |
Set the minimum value of the qy integration range.
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |
|
private |