
#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 *w, const double *x, const double *u,
                const double *v) {

  for (int k = 0; k < n; k++) {
    double y = u[k] / v[k];
    w[k] = x[k] / (exp(y) - 1.0);
  }
}
BENCH_MAIN_ARRAY3_D(
    T001_Loops_014, 22, 256, 1024, 4096,
    double *x = malloc((size_t)n * sizeof(double));
    double *u = malloc((size_t)n * sizeof(double));
    double *v = malloc((size_t)n * sizeof(double));
    double *w = malloc((size_t)n * sizeof(double)),
    {
      bench_fill_array(x, n, bench_seed(14) ^ 0xaaaa0001);
      bench_fill_array(u, n, bench_seed(14) ^ 0xbbbb0002);
      bench_fill_array_pos(v, n, bench_seed(14) ^ 0xcccc0003);
      double expmax = 20.0;
      u[n - 1] = 0.99 * expmax * v[n - 1];
    },
    kernel_run(n, w, x, u, v), w, n, free(x);
    free(u); free(v); free(w))
