31#include <sycl/sycl.hpp>
34#include "ext/common.hpp"
38namespace dpnp::kernels::interpolate
40template <
typename TCoord,
typename TValue,
typename TIdx = std::
int64_t>
41sycl::event interpolate_impl(sycl::queue &q,
50 const std::size_t xp_size,
51 const std::vector<sycl::event> &depends)
55 return q.submit([&](sycl::handler &h) {
56 h.depends_on(depends);
57 h.parallel_for(sycl::range<1>(n), [=](sycl::id<1> i) {
58 TValue left_val = left ? *left : fp[0];
59 TValue right_val = right ? *right : fp[xp_size - 1];
62 TIdx x_idx = idx[i] - 1;
70 else if (x_val == xp[xp_size - 1]) {
71 out[i] = fp[xp_size - 1];
73 else if (x_idx >=
static_cast<TIdx
>(xp_size - 1)) {
78 (fp[x_idx + 1] - fp[x_idx]) / (xp[x_idx + 1] - xp[x_idx]);
79 TValue res = slope * (x_val - xp[x_idx]) + fp[x_idx];
82 res = slope * (x_val - xp[x_idx + 1]) + fp[x_idx + 1];
84 (fp[x_idx] == fp[x_idx + 1])) {