
#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, double *xx, const double *y, const double *z,
                const double *w, const double *u, const double *v,
                const double *vx, const double *g, double s, double t,
                double dk) {

  for (int k = 0; k < n; k++) {
    double di = y[k] - g[k] / (xx[k] + dk);
    double dn = 0.2;
    if (di != 0.0) {
      double tmp = z[k] / di;
      if (t < tmp)
        tmp = t;
      if (s > tmp)
        tmp = s;
      dn = tmp;
    }
    x[k] = ((w[k] + v[k] * dn) * xx[k] + u[k]) / (vx[k] + v[k] * dn);
    xx[k + 1] = (x[k] - xx[k]) * dn + xx[k];
  }
}
BENCH_MAIN_ARRAY3_D(
    T001_Loops_012, 20, 256, 1024, 4096,
    double *x = malloc((size_t)n * sizeof(double));
    double *xx = malloc((size_t)(n + 1) * sizeof(double));
    double *y = malloc((size_t)n * sizeof(double));
    double *z = malloc((size_t)n * sizeof(double));
    double *w = malloc((size_t)n * sizeof(double));
    double *u = malloc((size_t)n * sizeof(double));
    double *v = malloc((size_t)n * sizeof(double));
    double *vx = malloc((size_t)n * sizeof(double));
    double *g = malloc((size_t)n * sizeof(double)),
    bench_fill_array(x, n, bench_seed(13) ^ 0x5151);
    bench_fill_array(xx, n + 1, bench_seed(13) ^ 0x5252);
    bench_fill_array(y, n, bench_seed(13) ^ 0x5353);
    bench_fill_array(z, n, bench_seed(13) ^ 0x5454);
    bench_fill_array(w, n, bench_seed(13) ^ 0x5555);
    bench_fill_array(u, n, bench_seed(13) ^ 0x5656);
    bench_fill_array(v, n, bench_seed(13) ^ 0x5757);
    bench_fill_array(vx, n, bench_seed(13) ^ 0x5858);
    bench_fill_array(g, n, bench_seed(13) ^ 0x5959);
    , kernel_run(n, x, xx, y, z, w, u, v, vx, g, 0.01, 0.9, 0.001), x, n,
    free(x);
    free(xx); free(y); free(z); free(w); free(u); free(v); free(vx); free(g))
