#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 unsigned char *b, double *ans_out) {
  double ans_double = 0.0;
  const int KZ = 5;

  int left = 0;
  int zeros = 0;
  int best = 0;
  for (int right = 0; right < n; right++) {
    if (b[right] == 0)
      zeros++;
    while (zeros > KZ) {
      if (b[left] == 0)
        zeros--;
      left++;
    }
    int len = right - left + 1;
    if (len > best)
      best = len;
  }
  ans_double = (double)best;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_001, K0FLIP, 4096, 16384, 65536,
    unsigned char *b = (unsigned char *)malloc((size_t)n *
                                               sizeof(unsigned char));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        b[i] = (unsigned char)(bench_rng_next(&rng) & 1ULL);
      }
    },
    kernel_run(n, b, &ans_scalar), ans_scalar, free(b);)
