
#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 *polyx, const double *polyy,
                const double *qx, const double *qy, double *ans_out) {
  const int POLY_M = 64;
  long long inside_cnt = 0;
  for (int qi = 0; qi < n; qi++) {
    double x0 = qx[qi];
    double y0 = qy[qi];
    int inside = 0;
    for (int i = 0; i < POLY_M; i++) {
      int j = (i + 1 == POLY_M) ? 0 : (i + 1);
      double xi = polyx[i];
      double yi = polyy[i];
      double xj = polyx[j];
      double yj = polyy[j];
      int cond1 = ((yi > y0) != (yj > y0));
      if (cond1) {
        double x_int = xi + (xj - xi) * ((y0 - yi) / (yj - yi));
        if (x0 < x_int) {
          inside = !inside;
        }
      }
    }
    if (inside)
      inside_cnt++;
  }
  double ans_double = 0.0;

  ans_double = (double)inside_cnt;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_048, PINPOLY, 4096, 16384, 65536,
    double *polyx = (double *)malloc((size_t)64 * sizeof(double));
    double *polyy = (double *)malloc((size_t)64 * sizeof(double));
    double *qx = (double *)malloc((size_t)n * sizeof(double));
    double *qy = (double *)malloc((size_t)n * sizeof(double));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      const int POLY_M = 64;
      const double TWO_PI = 6.28318530717958647692;
      for (int i = 0; i < POLY_M; i++) {
        double ang = (TWO_PI * (double)i) / (double)POLY_M;
        polyx[i] = cos(ang) * 100.0;
        polyy[i] = sin(ang) * 100.0;
      }
      for (int i = 0; i < n; i++) {
        double rx = bench_rng_double_signed(&rng);
        double ry = bench_rng_double_signed(&rng);
        qx[i] = rx * 150.0;
        qy[i] = ry * 150.0;
      }
    },
    kernel_run(n, polyx, polyy, qx, qy, &ans_scalar), ans_scalar, free(polyx);
    free(polyy); free(qx); free(qy);)
