
#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 H, int W, const double *x, double *y) {
  int OH = H / 2, OW = W / 2;

  for (int i = 0; i < OH; i++) {
    for (int j = 0; j < OW; j++) {
      int r = i * 2, c = j * 2;
      double s = x[r * W + c] + x[r * W + c + 1] + x[(r + 1) * W + c] +
                 x[(r + 1) * W + c + 1];
      y[i * OW + j] = s * 0.25;
    }
  }
}
BENCH_MAIN_ARRAY3_D(
    T002_Ops_017, OP17, 4096, 16384, 65536,
    int H = (case_id == 1 ? 64 : (case_id == 2 ? 128 : 256));
    int W = H; double *x = malloc((size_t)H * W * sizeof(double));
    double *y = malloc((size_t)(H / 2) * (W / 2) * sizeof(double)),
    bench_fill_array(x, (size_t)H *W, bench_seed(17));
    , kernel_run(H, W, x, y), y, (size_t)(H / 2) * (W / 2), free(x); free(y))
