#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
#define K_HASH 4
#define SALT1 0x1234abcdU
#define SALT2 0x9e3779b9U
static inline uint32_t mix32_b(uint32_t x) {
  x ^= x >> 16;
  x *= 0x7feb352dU;
  x ^= x >> 15;
  x *= 0x846ca68bU;
  x ^= x >> 16;
  return x;
}
static uint32_t next_pow2_u32(uint32_t x) {
  uint32_t p = 1;
  while (p < x)
    p <<= 1;
  return p;
}
static inline void bf_set(uint32_t *bits, uint32_t idx) {
  bits[idx >> 5] |= (uint32_t)1u << (idx & 31);
}
static inline int bf_test(const uint32_t *bits, uint32_t idx) {
  return (bits[idx >> 5] & ((uint32_t)1u << (idx & 31))) != 0;
}
static double bf_run(int n, const int *keys) {
  int n_ins = n / 2;
  if (n_ins < 1)
    n_ins = 1;
  uint32_t need_bits = (uint32_t)(n_ins * 8);
  if (need_bits < 8U)
    need_bits = 8U;
  uint32_t m_bits = next_pow2_u32(need_bits);
  uint32_t nwords = (m_bits + 31U) >> 5;
  uint32_t *bits = (uint32_t *)calloc((size_t)nwords, sizeof(uint32_t));
  if (!bits)
    return 0.0;
  for (int i = 0; i < n_ins; i++) {
    uint32_t k = (uint32_t)keys[i];
    uint32_t h1 = mix32_b(k ^ SALT1);
    uint32_t h2 = (mix32_b(k ^ SALT2) | 1U);
    for (int t = 0; t < K_HASH; t++) {
      uint32_t idx = (h1 + (uint32_t)t * h2) & (m_bits - 1U);
      bf_set(bits, idx);
    }
  }
  long long hits = 0;
  for (int i = 0; i < n; i++) {
    uint32_t k = (uint32_t)keys[i];
    uint32_t h1 = mix32_b(k ^ SALT1);
    uint32_t h2 = (mix32_b(k ^ SALT2) | 1U);
    int ok = 1;
    for (int t = 0; t < K_HASH; t++) {
      uint32_t idx = (h1 + (uint32_t)t * h2) & (m_bits - 1U);
      if (!bf_test(bits, idx)) {
        ok = 0;
        break;
      }
    }
    if (ok)
      hits++;
  }
  free(bits);
  double ans_once = (double)hits;
  double ans = 0.0;

  ans = ans_once;
  return ans;
}
BENCH_MAIN_SCALAR3(
    T004_Module_055, BFILT, 4096, 16384, 65536,
    int *keys = (int *)malloc((size_t)n * sizeof(int));
    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) & 0xFFFFFFFFu);
      }
    },
    ans_scalar = bf_run(n, keys), ans_scalar, free(keys);)
