#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
static inline uint32_t zigzag_encode32(int32_t v) {
  return ((uint32_t)v << 1) ^ (uint32_t)(v >> 31);
}
static inline int32_t zigzag_decode32(uint32_t x) {
  return (int32_t)((x >> 1) ^ (uint32_t)(-(int32_t)(x & 1)));
}
static int encode_varint32(uint32_t v, uint8_t *out) {
  int pos = 0;
  while (v >= 0x80U) {
    out[pos++] = (uint8_t)((v & 0x7FU) | 0x80U);
    v >>= 7;
  }
  out[pos++] = (uint8_t)v;
  return pos;
}
static int decode_varint32(const uint8_t *buf, int len, int *idx,
                           uint32_t *out) {
  uint32_t result = 0;
  int shift = 0;
  while (*idx < len && shift < 35) {
    uint8_t b = buf[(*idx)++];
    result |= (uint32_t)(b & 0x7FU) << shift;
    if (!(b & 0x80U)) {
      *out = result;
      return 1;
    }
    shift += 7;
  }
  return 0;
}
static double pipeline_run(const uint8_t *msg, int msg_len) {
  uint64_t total = 0;

  int idx = 0;
  uint64_t sum1 = 0;
  uint64_t sum2 = 0;
  uint64_t sum3 = 0;
  uint64_t sum4 = 0;
  while (idx < msg_len) {
    uint32_t key = 0;
    if (!decode_varint32(msg, msg_len, &idx, &key))
      break;
    uint32_t field_no = key >> 3;
    uint32_t wire = key & 7U;
    if (wire != 0U)
      break;
    uint32_t raw = 0;
    if (!decode_varint32(msg, msg_len, &idx, &raw))
      break;
    int32_t val = zigzag_decode32(raw);
    switch (field_no) {
    case 1:
      sum1 += (uint64_t)(int64_t)val;
      break;
    case 2:
      sum2 += (uint64_t)(int64_t)val;
      break;
    case 3:
      sum3 += (uint64_t)(int64_t)val;
      break;
    case 4:
      sum4 += (uint64_t)(int64_t)val;
      break;
    default:
      break;
    }
  }
  uint64_t mix = sum1 + 3ULL * sum2 + 5ULL * sum3 + 7ULL * sum4;
  total ^= mix * 0x9e3779b97f4a7c15ULL;

  return (double)total;
}
BENCH_MAIN_SCALAR3(
    T004_Module_022, PBDEC, 4096, 16384, 65536,
    uint8_t *msg = (uint8_t *)malloc((size_t)n * 12);
    int msg_len = 0; double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      msg_len = 0;
      for (int i = 0; i < n; i++) {
        uint32_t field_no = (uint32_t)((i % 4) + 1);
        int32_t sval =
            (int32_t)((int32_t)(bench_rng_next(&rng) & 1023ULL) - 512);
        uint32_t key = (field_no << 3) | 0U;
        uint8_t tmp[16];
        int klen = encode_varint32(key, tmp);
        if (msg_len + klen + 10 >= n * 12)
          break;
        memcpy(msg + msg_len, tmp, (size_t)klen);
        msg_len += klen;
        uint32_t zz = zigzag_encode32(sval);
        int vlen = encode_varint32(zz, tmp);
        memcpy(msg + msg_len, tmp, (size_t)vlen);
        msg_len += vlen;
      }
    },
    ans_scalar = pipeline_run(msg, msg_len);
    , ans_scalar, free(msg);)
