
#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 *seq = (int *)malloc((size_t)n * sizeof(int));
  int *tmp = (int *)malloc((size_t)n * sizeof(int));
  if (!seq || !tmp) {
    if (seq)
      free(seq);
    if (tmp)
      free(tmp);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < n; i++) {
    seq[i] = (int)((1103515245u * (unsigned)i + 12345u) & 0xFFFFu);
  }
  unsigned long long checksum = 0ULL;
  int Q = 16;
  for (int t = 0; t < Q; t++) {
    int l = (t * 37 + 11) % n;
    int r = (t * 97 + 7) % n;
    if (l > r) {
      int tmpx = l;
      l = r;
      r = tmpx;
    }
    int idx = 0;
    for (int i = l; i <= r; i++) {
      tmp[idx++] = seq[i];
    }
    for (int i = 0; i < l; i++) {
      tmp[idx++] = seq[i];
    }
    for (int i = r + 1; i < n; i++) {
      tmp[idx++] = seq[i];
    }
    for (int i = 0; i < n; i++) {
      seq[i] = tmp[i];
    }
    unsigned long long acc = 0ULL;
    for (int i = 0; i < n; i++) {
      acc += (unsigned long long)(unsigned int)seq[i] *
             (unsigned long long)(i + 1);
    }
    checksum += acc;
  }
  double ans_double = 0.0;

  ans_double = (double)checksum;

  *ans_out = ans_double;
  free(seq);
  free(tmp);
}
BENCH_MAIN_SCALAR3(T003_Code_054, TREAPSP, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
