
#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdlib.h>
static inline uint64_t prng_from_index(uint64_t idx) {
  uint64_t x = idx * 0x9e3779b97f4a7c15ULL;
  x ^= x >> 12;
  x ^= x << 25;
  x ^= x >> 27;
  return x * 2685821657736338717ULL;
}
void kernel_run(int n, const double *x, double keep_prob, double *y) {
  long double full = (long double)18446744073709551615.0L;
  unsigned long long thresh = (unsigned long long)(keep_prob * full);
  double inv_keep = 1.0 / keep_prob;

  for (int i = 0; i < n; i++) {
    uint64_t r = prng_from_index((uint64_t)i);
    if (r <= thresh) {
      y[i] = x[i] * inv_keep;
    } else {
      y[i] = 0.0;
    }
  }
}
BENCH_MAIN_ARRAY3_D(T002_Ops_038, OP68, 4096, 16384, 65536,
                    double *x = malloc((size_t)n * sizeof(double));
                    double *y = malloc((size_t)n * sizeof(double));
                    double keep_prob = 0.8,
                    bench_fill_array(x, (size_t)n, bench_seed(68));
                    , kernel_run(n, x, keep_prob, y), y, (size_t)n, free(x);
                    free(y))
