
#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 double *x, uint8_t *y, double scale, int zp) {

  for (int i = 0; i < n; i++) {
    double r = x[i] / scale + (double)zp;
    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_026, OP26, 4096, 16384, 65536,
                        double *x = malloc(n * sizeof(double));
                        uint8_t *y = malloc(n * sizeof(uint8_t)),
                        bench_fill_array(x, n, bench_seed(26));
                        , kernel_run(n, x, y, 0.05, 128), y,
                        (size_t)n * sizeof(uint8_t), free(x);
                        free(y))
