
#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 *a = (int *)malloc((size_t)n * sizeof(int));
  if (!a) {
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < n; i++) {
    unsigned int v =
        (unsigned int)((1103515245u * ((unsigned)i + 123u) + 12345u) & 0x7FFFu);
    a[i] = (int)v;
  }
  unsigned long long checksum = 0ULL;
  int OPS = 64;
  for (int t = 0; t < OPS; t++) {
    int l = (t * 37 + 11) % n;
    int r = (t * 131 + 7) % n;
    if (l > r) {
      int tmp = l;
      l = r;
      r = tmp;
    }
    int typ = t & 3;
    if (typ == 0) {
      int delta = (int)((t * 17 + 3) % 11) - 5;
      for (int i = l; i <= r; i++) {
        a[i] += delta;
      }
    } else if (typ == 1) {
      int capv = (int)((t * 97 + 23) % 1000);
      for (int i = l; i <= r; i++) {
        if (a[i] > capv)
          a[i] = capv;
      }
    } else if (typ == 2) {
      int floorv = (int)((t * 89 + 19) % 1000);
      for (int i = l; i <= r; i++) {
        if (a[i] < floorv)
          a[i] = floorv;
      }
    } else {
      long long s = 0;
      for (int i = l; i <= r; i++) {
        s += (long long)a[i];
      }
      checksum += (unsigned long long)(s & 0xFFFFFFFFULL);
    }
  }
  double ans_double = 0.0;

  ans_double = (double)checksum;

  *ans_out = ans_double;
  free(a);
}
BENCH_MAIN_SCALAR3(T003_Code_050, SGBEATS, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
