
#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, double *y) {
  const double k = 0.7978845608028654;
  const double c = 0.044715;

  for (int i = 0; i < n; i++) {
    double v = x[i];
    double u = v + c * v * v * v;
    double t = tanh(k * u);
    y[i] = 0.5 * v * (1.0 + t);
  }
}
BENCH_MAIN_ARRAY3_D(T002_Ops_002, OP02, 4096, 16384, 65536,
                    double *x = malloc(n * sizeof(double));
                    double *y = malloc(n * sizeof(double)),
                    bench_fill_array(x, n, bench_seed(2));
                    , kernel_run(n, x, y), y, n, free(x); free(y))
