#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
static inline int32_t delta_step(int32_t cur, int32_t prev) {
  return cur - prev;
}
static inline uint32_t zigzag32(int32_t v) {
  return ((uint32_t)v << 1) ^ (uint32_t)(v >> 31);
}
static inline void varint_write(uint32_t v, uint8_t *out, size_t *pos) {
  while (v >= 0x80u) {
    out[*pos] = (uint8_t)((v & 0x7Fu) | 0x80u);
    (*pos)++;
    v >>= 7;
  }
  out[*pos] = (uint8_t)(v & 0x7Fu);
  (*pos)++;
}
static size_t delta_varint_encode(const int32_t *in, int n, uint8_t *outbuf) {
  size_t pos = 0;
  if (n <= 0)
    return 0;
  int32_t prev = in[0];
  uint32_t zz0 = zigzag32(prev);
  varint_write(zz0, outbuf, &pos);
  for (int i = 1; i < n; i++) {
    int32_t d = delta_step(in[i], prev);
    uint32_t zz = zigzag32(d);
    varint_write(zz, outbuf, &pos);
    prev = in[i];
  }
  return pos;
}
static double pipeline_run(int n, const int32_t *arr, uint8_t *encbuf) {
  size_t used = delta_varint_encode(arr, n, encbuf);
  uint64_t acc = 0;
  for (size_t i = 0; i < used; i++)
    acc = (acc + (uint64_t)encbuf[i]) & 0xFFFFFFFFFFFFull;
  double v = 0.0;

  v = (double)acc;
  return v;
}
BENCH_MAIN_SCALAR3(
    T004_Module_040, DELTAVAR, 4096, 16384, 65536,
    int32_t *arr = (int32_t *)malloc((size_t)n * sizeof(int32_t));
    uint8_t *encbuf = (uint8_t *)malloc((size_t)n * 8); double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++)
        arr[i] = (int32_t)(bench_rng_next(&rng));
    },
    ans_scalar = pipeline_run(n, arr, encbuf), ans_scalar, free(arr);
    free(encbuf);)
