
#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void kernel_run(int n, const uint32_t *piles, double *ans_out) {
  if (n < 1)
    n = 1;
  int *sg = (int *)malloc((size_t)n * sizeof(int));
  if (!sg) {
    *ans_out = 0.0;
    return;
  }
  sg[0] = 0;
  for (int i = 1; i < n; i++) {
    int used0 = 0, used1 = 0, used2 = 0, used3 = 0;
    {
      int g1 = sg[i - 1];
      if (g1 == 0)
        used0 = 1;
      else if (g1 == 1)
        used1 = 1;
      else if (g1 == 2)
        used2 = 1;
      else if (g1 == 3)
        used3 = 1;
    }
    if (i >= 2) {
      int g2 = sg[i - 2];
      if (g2 == 0)
        used0 = 1;
      else if (g2 == 1)
        used1 = 1;
      else if (g2 == 2)
        used2 = 1;
      else if (g2 == 3)
        used3 = 1;
      {
        int g3 = sg[i / 2];
        if (g3 == 0)
          used0 = 1;
        else if (g3 == 1)
          used1 = 1;
        else if (g3 == 2)
          used2 = 1;
        else if (g3 == 3)
          used3 = 1;
      }
    }
    int gval;
    if (!used0)
      gval = 0;
    else if (!used1)
      gval = 1;
    else if (!used2)
      gval = 2;
    else
      gval = 3;
    sg[i] = gval;
  }
  unsigned int xor_total = 0U;
  for (int i = 0; i < n; i++) {
    uint32_t sz = piles[i] % (uint32_t)n;
    xor_total ^= (unsigned int)sg[sz];
  }
  double ans_double = 0.0;

  ans_double = (double)xor_total;

  *ans_out = ans_double;
  free(sg);
}
BENCH_MAIN_SCALAR3(
    T003_Code_042, SGAME, 4096, 16384, 65536,
    uint32_t *piles = (uint32_t *)malloc((size_t)n * sizeof(uint32_t));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        piles[i] = (uint32_t)(bench_rng_next(&rng));
      }
    },
    kernel_run(n, piles, &ans_scalar), ans_scalar, free(piles);)
