
#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void kernel_run(int n, const uint8_t *x, uint8_t *y, double s1, int zp1,
                double s2, int zp2) {

  for (int i = 0; i < n; i++) {
    double r = ((int)x[i] - zp1) * (s1 / s2) + zp2;
    double fl = floor(r);
    double fr = r - fl;
    double q;
    if (fr > 0.5)
      q = ceil(r);
    else if (fr < 0.5)
      q = fl;
    else {
      q = ((fmod(fl, 2.0) == 0.0) ? fl : ceil(r));
    }
    if (q < 0.0)
      q = 0.0;
    else if (q > 255.0)
      q = 255.0;
    y[i] = (uint8_t)(q + 0.0);
  }
}
BENCH_MAIN_ARRAY3_BYTES(
    T002_Ops_028, OP28, 4096, 16384, 65536,
    uint8_t *x = malloc(n * sizeof(uint8_t));
    uint8_t *y = malloc(n * sizeof(uint8_t)),
    {
      bench_rng64_t rng = bench_rng_init(bench_seed(28));
      for (int i = 0; i < n; i++)
        x[i] = (uint8_t)(bench_rng_next(&rng) & 255);
    },
    kernel_run(n, x, y, 0.05, 128, 0.04, 120), y, (size_t)n * sizeof(uint8_t),
    free(x);
    free(y))
