#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
static int gclass(uint16_t cp) {
  if (cp == 0x000D)
    return 0;
  if (cp == 0x000A)
    return 1;
  if (cp == 0x0301)
    return 2;
  return 3;
}
static int break_here(int prevc, int curc) {
  if (prevc < 0)
    return 1;
  if (prevc == 0 && curc == 1)
    return 0;
  if (prevc == 0 || prevc == 1)
    return 1;
  if (curc == 2)
    return 0;
  if (curc == 1 || curc == 0)
    return 1;
  return 1;
}
static int count_graphemes_line(const uint16_t *s, int len) {
  int count = 0;
  int prev = -1;
  for (int i = 0; i < len; i++) {
    int c = gclass(s[i]);
    if (break_here(prev, c))
      count++;
    prev = c;
  }
  return count;
}
static double pipeline_run(const uint16_t *lines, int total_u16) {
  double outv = 0.0;

  uint64_t acc = 1469598103934665603ULL;
  int pos = 0;
  while (pos < total_u16) {
    int L = lines[pos++];
    if (L < 0)
      L = 0;
    if (L > 32)
      L = 32;
    if (pos + L > total_u16)
      break;
    int c = count_graphemes_line(lines + pos, L);
    acc ^= ((uint64_t)c + 0x9e3779b97f4a7c15ULL * (uint64_t)L);
    pos += L;
  }
  outv += (double)acc;

  return outv;
}
BENCH_MAIN_SCALAR3(
    T004_Module_030, GSEG, 4096, 16384, 65536,
    uint16_t *lines = (uint16_t *)malloc((size_t)n * 8 * sizeof(uint16_t));
    int total_u16 = 0; double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      total_u16 = 0;
      for (int i = 0; i < n; i++) {
        uint16_t seq[32];
        int L = 1 + (int)(bench_rng_next(&rng) % 8ULL);
        for (int k = 0; k < L; k++) {
          unsigned long long r = bench_rng_next(&rng);
          switch (r & 3ULL) {
          case 0:
            seq[k] = 0x000D;
            break;
          case 1:
            seq[k] = 0x000A;
            break;
          case 2:
            seq[k] = 0x0301;
            break;
          default:
            seq[k] = 0x0061;
            break;
          }
        }
        if (total_u16 + 1 + L < (int)(n * 8)) {
          lines[total_u16++] = (uint16_t)L;
          for (int k = 0; k < L; k++)
            lines[total_u16++] = seq[k];
        } else
          break;
      }
    },
    ans_scalar = pipeline_run(lines, total_u16);
    , ans_scalar, free(lines);)
