#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdlib.h>
static inline uint8_t clip_u8_int(int v) {
  if (v < 0)
    v = 0;
  if (v > 255)
    v = 255;
  return (uint8_t)v;
}
static inline void rct_forward_frame(int n, const uint8_t *R, const uint8_t *G,
                                     const uint8_t *B, uint8_t *Yc, int16_t *Co,
                                     int16_t *Cg) {
  for (int i = 0; i < n; i++) {
    int r = (int)R[i];
    int g = (int)G[i];
    int b = (int)B[i];
    int y = (r + (g << 1) + b) >> 2;
    int co = r - g;
    int cg = b - g;
    Yc[i] = clip_u8_int(y);
    Co[i] = (int16_t)co;
    Cg[i] = (int16_t)cg;
  }
}
static double pipeline_run(int n, const uint8_t *R, const uint8_t *G,
                           const uint8_t *B, uint8_t *Yc, int16_t *Co,
                           int16_t *Cg) {

  rct_forward_frame(n, R, G, B, Yc, Co, Cg);

  double acc = 0.0;
  for (int i = 0; i < n; i++) {
    int co = (int)Co[i];
    int cg = (int)Cg[i];
    int ay = (int)Yc[i];
    if (co < 0)
      co = -co;
    if (cg < 0)
      cg = -cg;
    acc += (double)ay + (double)co + (double)cg;
  }
  return acc;
}
BENCH_MAIN_SCALAR3(
    T004_Module_017, RCTPK, 4096, 16384, 65536,
    uint8_t *R = (uint8_t *)malloc((size_t)n * sizeof(uint8_t));
    uint8_t *G = (uint8_t *)malloc((size_t)n * sizeof(uint8_t));
    uint8_t *B = (uint8_t *)malloc((size_t)n * sizeof(uint8_t));
    uint8_t *Yc = (uint8_t *)malloc((size_t)n * sizeof(uint8_t));
    int16_t *Co = (int16_t *)malloc((size_t)n * sizeof(int16_t));
    int16_t *Cg = (int16_t *)malloc((size_t)n * sizeof(int16_t));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        R[i] = (uint8_t)(bench_rng_next(&rng) & 0xFFu);
        G[i] = (uint8_t)(bench_rng_next(&rng) & 0xFFu);
        B[i] = (uint8_t)(bench_rng_next(&rng) & 0xFFu);
        Yc[i] = 0;
        Co[i] = 0;
        Cg[i] = 0;
      }
    },
    ans_scalar = pipeline_run(n, R, G, B, Yc, Co, Cg), ans_scalar, free(R);
    free(G); free(B); free(Yc); free(Co); free(Cg);)
