
#include "bench_harness.h"
#include "bench_utils.h"
#include <float.h>
#include <stdint.h>
#include <stdlib.h>
void kernel_run(int rows, int cols, const double *x, double eps, double *y) {

  for (int r = 0; r < rows; r++) {
    double mn = DBL_MAX;
    double mx = -DBL_MAX;
    for (int c = 0; c < cols; c++) {
      double v = x[r * cols + c];
      if (v < mn)
        mn = v;
      if (v > mx)
        mx = v;
    }
    double denom = (mx - mn) + eps;
    for (int c = 0; c < cols; c++) {
      int idx = r * cols + c;
      y[idx] = (x[idx] - mn) / denom;
    }
  }
}
BENCH_MAIN_ARRAY3_D(
    T002_Ops_049, OP79, 16384, 32768, 65536,
    int rows = (case_id == 1 ? 128 : (case_id == 2 ? 256 : 512));
    int cols = 128; double *x = malloc((size_t)n * sizeof(double));
    double *y = malloc((size_t)n * sizeof(double));
    double eps = 1e-9, bench_fill_array(x, (size_t)n, bench_seed(79));
    , kernel_run(rows, cols, x, eps, y), y, (size_t)n, free(x); free(y))
