
#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 *perm, double *ans_out) {
  int *bit = (int *)malloc((size_t)(n + 2) * sizeof(int));
  if (!bit) {
    *ans_out = 0.0;
    return;
  }
  memset(bit, 0, (size_t)(n + 2) * sizeof(int));
  long long inv_count = 0;
  for (int i = 0; i < n; i++) {
    int v = perm[i];
    long long le_cnt = 0;
    int p = v + 1;
    while (p > 0) {
      le_cnt += (long long)bit[p];
      p -= p & -p;
    }
    long long seen = (long long)i;
    inv_count += (seen - le_cnt);
    p = v + 1;
    while (p <= n) {
      bit[p] += 1;
      p += p & -p;
    }
  }
  double ans_double = 0.0;

  ans_double = (double)inv_count;

  *ans_out = ans_double;
  free(bit);
}
BENCH_MAIN_SCALAR3(
    T003_Code_046, SWEEPSEG, 4096, 16384, 65536,
    int *perm = (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++) {
        perm[i] = i;
      }
      for (int i = n - 1; i > 0; i--) {
        int j = (int)(bench_rng_next(&rng) % (unsigned long long)(i + 1));
        int tmp = perm[i];
        perm[i] = perm[j];
        perm[j] = tmp;
      }
    },
    kernel_run(n, perm, &ans_scalar), ans_scalar, free(perm);)
