
#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 *stk = (int *)malloc((size_t)(2 * n) * sizeof(int));
  if (!stk) {
    *ans_out = 0.0;
    return;
  }
  int k = 0;
  for (int i = 0; i < n; i++) {
    while (k >= 2) {
      int a = stk[k - 2];
      int b = stk[k - 1];
      int c = i;
      double cross =
          (px[b] - px[a]) * (py[c] - py[a]) - (py[b] - py[a]) * (px[c] - px[a]);
      if (cross <= 0.0) {
        k--;
      } else {
        break;
      }
    }
    stk[k++] = i;
  }
  int t = k + 1;
  for (int i = n - 2; i >= 0; i--) {
    while (k >= t) {
      int a = stk[k - 2];
      int b = stk[k - 1];
      int c = i;
      double cross =
          (px[b] - px[a]) * (py[c] - py[a]) - (py[b] - py[a]) * (px[c] - px[a]);
      if (cross <= 0.0) {
        k--;
      } else {
        break;
      }
    }
    stk[k++] = i;
  }
  if (k > 1)
    k--;
  double per = 0.0;
  for (int i = 0; i < k; i++) {
    int a = stk[i];
    int b = stk[(i + 1) % k];
    double dx = px[a] - px[b];
    double dy = py[a] - py[b];
    per += sqrt(dx * dx + dy * dy);
  }
  double ans_double = 0.0;

  ans_double = per;

  *ans_out = ans_double;
  free(stk);
}
BENCH_MAIN_SCALAR3(
    T003_Code_043, HULL, 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;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < n; i++) {
        px[i] = (double)i;
        double r = bench_rng_double_signed(&rng);
        py[i] = r * 100.0;
      }
    },
    kernel_run(n, px, py, &ans_scalar), ans_scalar, free(px);
    free(py);)
