#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 *s, double *y) {
  int *pi = (int *)malloc((size_t)n * sizeof(int));
  if (!pi) {
    y[0] = 0.0;
    y[1] = 0.0;
    return;
  }
  double last_period = 0.0;
  double last_borders = 0.0;

  if (n > 0)
    pi[0] = 0;
  for (int i = 1; i < n; i++) {
    int j = pi[i - 1];
    while (j > 0 && s[i] != s[j]) {
      j = pi[j - 1];
    }
    if (s[i] == s[j])
      j++;
    pi[i] = j;
  }
  int p = n > 0 ? (n - pi[n - 1]) : 0;
  int min_period = (p > 0 && (n % p == 0)) ? p : n;
  int cnt_borders = 0;
  if (n > 0) {
    int k = pi[n - 1];
    while (k > 0) {
      cnt_borders++;
      if (k > 0)
        k = pi[k - 1];
    }
  }
  last_period = (double)min_period;
  last_borders = (double)cnt_borders;

  y[0] = last_period;
  y[1] = last_borders;
  free(pi);
}
BENCH_MAIN_ARRAY3_D(
    T003_Code_009, KMPPER, 4096, 16384, 65536,
    unsigned char *s = (unsigned char *)malloc((size_t)n *
                                               sizeof(unsigned char));
    double *y = (double *)malloc(2 * sizeof(double));
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        s[i] = (unsigned char)('a' + (bench_rng_next(&rng) % 26ULL));
      }
    },
    kernel_run(n, s, y), y, 2, free(s);
    free(y);)
