
#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void kernel_run(int R, int D, const double *x, double *vals, int32_t *idx) {

  for (int r = 0; r < R; r++) {
    const double *xr = x + r * D;
    double *vr = vals + r * 3;
    int32_t *ir = idx + r * 3;
    int i0 = 0, i1 = 1, i2 = 2;
    if (xr[i1] > xr[i0]) {
      int t = i0;
      i0 = i1;
      i1 = t;
    }
    if (xr[i2] > xr[i0]) {
      int t = i0;
      i0 = i2;
      i2 = t;
    }
    if (xr[i2] > xr[i1]) {
      int t = i1;
      i1 = i2;
      i2 = t;
    }
    for (int i = 3; i < D; i++) {
      if (xr[i] > xr[i2]) {
        i2 = i;
        if (xr[i2] > xr[i1]) {
          int t = i1;
          i1 = i2;
          i2 = t;
        }
        if (xr[i1] > xr[i0]) {
          int t = i0;
          i0 = i1;
          i1 = t;
        }
      }
    }
    vr[0] = xr[i0];
    vr[1] = xr[i1];
    vr[2] = xr[i2];
    ir[0] = i0;
    ir[1] = i1;
    ir[2] = i2;
  }
}
BENCH_MAIN_ARRAY3_BYTES(
    T002_Ops_015, OP15, 4096, 8192, 16384, int D = 64; int R = n / D;
    double *x = malloc((size_t)R * D * sizeof(double));
    double *vals = malloc((size_t)R * 3 * sizeof(double));
    int32_t *idx = malloc((size_t)R * 3 * sizeof(int32_t));
    unsigned char *digest = malloc((size_t)R * 3 *
                                   (sizeof(double) + sizeof(int32_t)));
    size_t digest_bytes = (size_t)R * 3 * (sizeof(double) + sizeof(int32_t)),
    bench_fill_array(x, (size_t)R *D, bench_seed(15));
    , kernel_run(R, D, x, vals, idx); {
      unsigned char *p = digest;
      for (int r = 0; r < R; r++) {
        double *vr = vals + r * 3;
        int32_t *ir = idx + r * 3;
        memcpy(p, &vr[0], sizeof(double));
        p += sizeof(double);
        memcpy(p, &ir[0], 4);
        p += 4;
        memcpy(p, &vr[1], 8);
        p += 8;
        memcpy(p, &ir[1], 4);
        p += 4;
        memcpy(p, &vr[2], 8);
        p += 8;
        memcpy(p, &ir[2], 4);
        p += 4;
      }
    },
                                      digest, digest_bytes, free(x);
    free(vals); free(idx); free(digest))
