#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 n, double *x, const double *v) {
  int ii = n;
  int ipntp = 0;
  do {
    int ipnt = ipntp;
    ipntp += ii;
    ii /= 2;
    int i = ipntp - 1;
    for (int k = ipnt + 1; k < ipntp; k += 2) {
      i++;
      x[i] = x[k] - v[k] * x[k - 1] - v[k + 1] * x[k + 1];
    }
  } while (ii > 0);
}

BENCH_MAIN_ARRAY3_D(T001_Loops_002, 02, 256, 512, 1024, int cap = 2 * n + 8;
                    double *x = malloc((size_t)cap * sizeof(double));
                    double *v = malloc((size_t)cap * sizeof(double)),
                    bench_fill_array(x, cap, bench_seed(10) ^ 0x9911);
                    bench_fill_array(v, cap, bench_seed(10) ^ 0x9922),
                    kernel_run(n, x, v), x, cap, free(x);
                    free(v);)