
#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, double *ans_out) {
  if (n < 2)
    n = 2;
  int LOG = 1;
  while ((1 << LOG) <= n)
    LOG++;
  int *arr = (int *)malloc((size_t)n * sizeof(int));
  int *lg = (int *)malloc((size_t)(n + 1) * sizeof(int));
  int *stMin = (int *)malloc((size_t)(LOG * n) * sizeof(int));
  int *stMax = (int *)malloc((size_t)(LOG * n) * sizeof(int));
  if (!arr || !lg || !stMin || !stMax) {
    if (arr)
      free(arr);
    if (lg)
      free(lg);
    if (stMin)
      free(stMin);
    if (stMax)
      free(stMax);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < n; i++) {
    unsigned int v = (unsigned int)(((unsigned)i * 1234567u +
                                     (unsigned)n * 89123u + 13579u) %
                                    100000u);
    arr[i] = (int)v;
  }
  lg[0] = 0;
  lg[1] = 0;
  for (int i = 2; i <= n; i++)
    lg[i] = lg[i >> 1] + 1;
  for (int i = 0; i < n; i++) {
    stMin[i] = arr[i];
    stMax[i] = arr[i];
  }
  for (int k = 1; k < LOG; k++) {
    int len = 1 << k;
    int half = len >> 1;
    int basePrev = (k - 1) * n;
    int baseCur = k * n;
    for (int i = 0; i + len - 1 < n; i++) {
      int v1 = stMin[basePrev + i];
      int v2 = stMin[basePrev + i + half];
      stMin[baseCur + i] = (v1 < v2 ? v1 : v2);
      int w1 = stMax[basePrev + i];
      int w2 = stMax[basePrev + i + half];
      stMax[baseCur + i] = (w1 > w2 ? w1 : w2);
    }
  }
  unsigned long long checksum = 0ULL;
  for (int i = 0; i < n; i++) {
    int l = i;
    int r = (i * 73 + 7) % n;
    if (l > r) {
      int tmp = l;
      l = r;
      r = tmp;
    }
    int len = r - l + 1;
    int kk = lg[len];
    int len2 = 1 << kk;
    int baseK = kk * n;
    int mn1 = stMin[baseK + l];
    int mn2 = stMin[baseK + (r - len2 + 1)];
    int mn = (mn1 < mn2 ? mn1 : mn2);
    int mx1 = stMax[baseK + l];
    int mx2 = stMax[baseK + (r - len2 + 1)];
    int mx = (mx1 > mx2 ? mx1 : mx2);
    checksum += (unsigned long long)((long long)mx - (long long)mn);
  }
  double ans_double = 0.0;

  ans_double = (double)checksum;

  *ans_out = ans_double;
  free(arr);
  free(lg);
  free(stMin);
  free(stMax);
}
BENCH_MAIN_SCALAR3(T003_Code_055, SPTBL, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
