46 const TCoord *x =
nullptr;
47 const TIdx *idx =
nullptr;
48 const TCoord *xp =
nullptr;
49 const TValue *fp =
nullptr;
50 const TValue *left =
nullptr;
51 const TValue *right =
nullptr;
52 TValue *out =
nullptr;
53 const std::size_t xp_size;
63 const std::size_t xp_size_)
64 : x(x_), idx(idx_), xp(xp_), fp(fp_), left(left_), right(right_),
65 out(out_), xp_size(xp_size_)
71 void operator()(sycl::id<1>
id)
const
73 TValue left_val = left ? *left : fp[0];
74 TValue right_val = right ? *right : fp[xp_size - 1];
77 TIdx x_idx = idx[id] - 1;
85 else if (x_val == xp[xp_size - 1]) {
86 out[id] = fp[xp_size - 1];
88 else if (x_idx >=
static_cast<TIdx
>(xp_size - 1)) {
93 (fp[x_idx + 1] - fp[x_idx]) / (xp[x_idx + 1] - xp[x_idx]);
94 TValue res = slope * (x_val - xp[x_idx]) + fp[x_idx];
97 res = slope * (x_val - xp[x_idx + 1]) + fp[x_idx + 1];