#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#define GSEED 0x517cc1b7u
static inline uint32_t mix32_g(uint32_t x) {
  x ^= GSEED;
  x ^= x >> 16;
  x *= 0x7feb352dU;
  x ^= x >> 15;
  x *= 0x846ca68bU;
  x ^= x >> 16;
  return x;
}
static size_t next_pow2_g(size_t x) {
  size_t p = 1;
  while (p < x)
    p <<= 1;
  return p;
}
static double gb_run(int n, const int *keys, const double *vals) {
  size_t need = (size_t)((n * 10) / 7 + 1);
  size_t cap = next_pow2_g(need);
  int *hkeys = (int *)malloc(cap * sizeof(int));
  double *hagg = (double *)malloc(cap * sizeof(double));
  unsigned char *hused = (unsigned char *)malloc(cap * sizeof(unsigned char));
  if (!hkeys || !hagg || !hused) {
    if (hkeys)
      free(hkeys);
    if (hagg)
      free(hagg);
    if (hused)
      free(hused);
    return 0.0;
  }
  memset(hused, 0, cap * sizeof(unsigned char));
  for (int i = 0; i < n; i++) {
    int key = keys[i];
    double val = vals[i];
    size_t idx = (size_t)(mix32_g((uint32_t)key) & (uint32_t)(cap - 1));
    while (hused[idx] && hkeys[idx] != key)
      idx = (idx + 1) & (cap - 1);
    if (hused[idx]) {
      hagg[idx] += val;
    } else {
      hused[idx] = 1;
      hkeys[idx] = key;
      hagg[idx] = val;
    }
  }
  double total = 0.0;
  for (size_t i = 0; i < cap; i++) {
    if (hused[i])
      total += hagg[i];
  }
  free(hkeys);
  free(hagg);
  free(hused);
  double ans = 0.0;

  ans = total;
  return ans;
}
BENCH_MAIN_SCALAR3(
    T004_Module_053, GBAGG, 4096, 16384, 65536,
    int *keys = (int *)malloc((size_t)n * sizeof(int));
    double *vals = (double *)malloc((size_t)n * sizeof(double));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        keys[i] = (int)(bench_rng_next(&rng) & 0x3FFFu);
        vals[i] = bench_rng_double_signed(&rng);
      }
    },
    ans_scalar = gb_run(n, keys, vals), ans_scalar, free(keys);
    free(vals);)
