
#include "bench_harness.h"
#include "bench_utils.h"
#include <stdint.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void kernel_run(int n, const int *x, const int *y, const int *z,
                double *ans_out) {
  int m = n;
  if (m > 4096)
    m = 4096;
  long long cnt_pairs = 0;
  for (int i = 0; i < m; i++) {
    for (int j = i + 1; j < m; j++) {
      int xi = x[i];
      int yi = y[i];
      int zi = z[i];
      int xj = x[j];
      int yj = y[j];
      int zj = z[j];
      int i_dom_j = (xi <= xj && yi <= yj && zi <= zj);
      int j_dom_i = (xj <= xi && yj <= yi && zj <= zi);
      if (i_dom_j || j_dom_i) {
        cnt_pairs++;
      }
    }
  }
  double ans_double = 0.0;

  ans_double = (double)cnt_pairs;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_058, CDQ3D, 4096, 16384, 65536,
    int *x = (int *)malloc((size_t)n * sizeof(int));
    int *y = (int *)malloc((size_t)n * sizeof(int));
    int *z = (int *)malloc((size_t)n * sizeof(int)); double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        x[i] = (int)(bench_rng_next(&rng) & 1023ULL);
        y[i] = (int)(bench_rng_next(&rng) & 1023ULL);
        z[i] = (int)(bench_rng_next(&rng) & 1023ULL);
      }
    },
    kernel_run(n, x, y, z, &ans_scalar), ans_scalar, free(x);
    free(y); free(z);)
