22 #pragma omp parallel for
23 for (
size_t j = 0; j < nh; j++)
24 heap_heapify<C> (k, val + j * k, ids + j * k);
30 #pragma omp parallel for
31 for (
size_t j = 0; j < nh; j++)
32 heap_reorder<C> (k, val + j * k, ids + j * k);
39 if (ni == -1) ni = nh;
40 assert (i0 >= 0 && i0 + ni <= nh);
41 #pragma omp parallel for
42 for (
size_t i = i0; i < i0 + ni; i++) {
43 T * __restrict simi = get_val(i);
44 TI * __restrict idxi = get_ids (i);
45 const T *ip_line = vin + (i - i0) * nj;
47 for (
size_t j = 0; j < nj; j++) {
49 if (C::cmp(simi[0], ip)) {
50 heap_pop<C> (k, simi, idxi);
51 heap_push<C> (k, simi, idxi, ip, j + j0);
59 size_t nj,
const T *vin,
const TI *id_in,
60 long id_stride,
size_t i0,
long ni)
62 if (id_in ==
nullptr) {
63 addn (nj, vin, 0, i0, ni);
66 if (ni == -1) ni = nh;
67 assert (i0 >= 0 && i0 + ni <= nh);
68 #pragma omp parallel for
69 for (
size_t i = i0; i < i0 + ni; i++) {
70 T * __restrict simi = get_val(i);
71 TI * __restrict idxi = get_ids (i);
72 const T *ip_line = vin + (i - i0) * nj;
73 const TI *id_line = id_in + (i - i0) * id_stride;
75 for (
size_t j = 0; j < nj; j++) {
77 if (C::cmp(simi[0], ip)) {
78 heap_pop<C> (k, simi, idxi);
79 heap_push<C> (k, simi, idxi, ip, id_line [j]);
90 #pragma omp parallel for
91 for (
size_t j = 0; j < nh; j++) {
93 typename C::T xval = C::Crev::neutral ();
94 const typename C::T * x_ = val + j * k;
95 for (
size_t i = 0; i < k; i++)
96 if (C::cmp (x_[i], xval)) {
104 if (ids && imin != -1)
105 out_ids[j] = ids [j * k + imin];
void reorder()
reorder all the heaps
void per_line_extrema(T *vals_out, TI *idx_out) const
void addn_with_ids(size_t nj, const T *vin, const TI *id_in=nullptr, long id_stride=0, size_t i0=0, long ni=-1)
void heapify()
prepare all the heaps before adding
void addn(size_t nj, const T *vin, TI j0=0, size_t i0=0, long ni=-1)