
#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 *px, const double *py, double *ans_out) {
  int m = n;
  int j = 1;
  double best_d2 = 0.0;
  for (int i = 0; i < m; i++) {
    int ni = (i + 1 == m) ? 0 : (i + 1);
    for (;;) {
      int nj = (j + 1 == m) ? 0 : (j + 1);
      double ax = px[ni] - px[i];
      double ay = py[ni] - py[i];
      double bx = px[nj] - px[i];
      double by = py[nj] - py[i];
      double cx = px[j] - px[i];
      double cy = py[j] - py[i];
      double cross1 = ax * by - ay * bx;
      double cross0 = ax * cy - ay * cx;
      if (cross1 > cross0) {
        j = nj;
      } else {
        break;
      }
    }
    double dx = px[i] - px[j];
    double dy = py[i] - py[j];
    double d2 = dx * dx + dy * dy;
    if (d2 > best_d2)
      best_d2 = d2;
    dx = px[ni] - px[j];
    dy = py[ni] - py[j];
    d2 = dx * dx + dy * dy;
    if (d2 > best_d2)
      best_d2 = d2;
  }
  double diameter = sqrt(best_d2);
  double ans_double = 0.0;

  ans_double = diameter;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(
    T003_Code_045, RCAL, 4096, 16384, 65536,
    double *px = (double *)malloc((size_t)n * sizeof(double));
    double *py = (double *)malloc((size_t)n * sizeof(double));
    double ans_scalar = 0.0;
    ,
    {
      const double TWO_PI = 6.28318530717958647692;
      for (int i = 0; i < n; i++) {
        double ang = (TWO_PI * (double)i) / (double)n;
        px[i] = cos(ang) * 100.0;
        py[i] = sin(ang) * 100.0;
      }
    },
    kernel_run(n, px, py, &ans_scalar), ans_scalar, free(px);
    free(py);)
