28#include <sycl/sycl.hpp> 
   31#include "ext/common.hpp" 
   35namespace dpnp::kernels::interpolate
 
   37template <
typename TCoord, 
typename TValue, 
typename TIdx = std::
int64_t>
 
   38sycl::event interpolate_impl(sycl::queue &q,
 
   47                             const std::size_t xp_size,
 
   48                             const std::vector<sycl::event> &depends)
 
   52    return q.submit([&](sycl::handler &h) {
 
   53        h.depends_on(depends);
 
   54        h.parallel_for(sycl::range<1>(n), [=](sycl::id<1> i) {
 
   55            TValue left_val = left ? *left : fp[0];
 
   56            TValue right_val = right ? *right : fp[xp_size - 1];
 
   59            TIdx x_idx = idx[i] - 1;
 
   67            else if (x_val == xp[xp_size - 1]) {
 
   68                out[i] = fp[xp_size - 1];
 
   70            else if (x_idx >= 
static_cast<TIdx
>(xp_size - 1)) {
 
   75                    (fp[x_idx + 1] - fp[x_idx]) / (xp[x_idx + 1] - xp[x_idx]);
 
   76                TValue res = slope * (x_val - xp[x_idx]) + fp[x_idx];
 
   79                    res = slope * (x_val - xp[x_idx + 1]) + fp[x_idx + 1];
 
   81                        (fp[x_idx] == fp[x_idx + 1])) {