25#include <boost/multi_array.hpp>
41template <
class T,
class F>
44 using R =
decltype(f((offset)));
46 boost::multi_array<R, 3>
res(size);
48 auto const end = offset +
Vector<T, 3>{grid_spacing[0] * size[0],
49 grid_spacing[1] * size[1],
50 grid_spacing[2] * size[2]};
Vector implementation and trait types for boost qvm interoperability.
cudaStream_t stream[1]
CUDA streams for parallel computing on CPU and GPU.
auto make_lin_space(T start, T stop, std::size_t number, bool endpoint=true)
Equally spaced values in interval.
auto raster(Vector< T, 3 > const &offset, Vector< T, 3 > const &grid_spacing, Vector3i size, F f)
Raster a function over a regular 3d grid.
DEVICE_QUALIFIER constexpr pointer data() noexcept