
#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, const double *x, const double *t, double *y,
                double beta) {

  for (int i = 0; i < n; i++) {
    double d = x[i] - t[i];
    double ad = fabs(d);
    if (ad < beta)
      y[i] = 0.5 * d * d / beta;
    else
      y[i] = ad - 0.5 * beta;
  }
}
BENCH_MAIN_ARRAY3_D(T002_Ops_025, OP25, 4096, 16384, 65536,
                    double *x = malloc(n * sizeof(double));
                    double *t = malloc(n * sizeof(double));
                    double *y = malloc(n * sizeof(double)),
                    bench_fill_array(x, n, bench_seed(25) ^ 0x1234);
                    bench_fill_array(t, n, bench_seed(25) ^ 0x5678);
                    , kernel_run(n, x, t, y, 1.0), y, n, free(x); free(t);
                    free(y))
