
#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 *y, const double *z,
                const double *u, double r, double t) {

  for (int k = 0; k < n; k++) {
    x[k] = u[k] + r * (z[k] + r * y[k]) +
           t * (u[k + 3] + r * (u[k + 2] + r * u[k + 1]) +
                t * (u[k + 6] + r * (u[k + 5] + r * u[k + 4])));
  }
}
BENCH_MAIN_ARRAY3_D(T001_Loops_006, 07, 256, 1024, 4096,
                    double *x = malloc((size_t)n * sizeof(double));
                    double *y = malloc((size_t)n * sizeof(double));
                    double *z = malloc((size_t)n * sizeof(double));
                    double *u = malloc((size_t)(n + 7) * sizeof(double)),
                    bench_fill_array(x, n, bench_seed(5) ^ 0x11110000);
                    bench_fill_array(y, n, bench_seed(5) ^ 0x22220000);
                    bench_fill_array(z, n, bench_seed(5) ^ 0x33330000);
                    bench_fill_array(u, n + 7, bench_seed(5) ^ 0x44440000),
                    kernel_run(n, x, y, z, u, 0.9, 0.7), x, n, free(x);
                    free(y); free(z); free(u))
