#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
static inline double run_bc(int n, const int *rowptr, const int *colind,
                            double *bc, int *dist, double *sigma, double *delta,
                            int *queue, int *stack_arr) {
  const int NUM_SRC = 4;
  for (int i = 0; i < n; i++) {
    bc[i] = 0.0;
  }
  for (int sidx = 0; sidx < NUM_SRC; sidx++) {
    int s = (int)(((long long)sidx * (long long)n) / (long long)NUM_SRC);
    for (int i = 0; i < n; i++) {
      dist[i] = -1;
      sigma[i] = 0.0;
      delta[i] = 0.0;
    }
    int qh = 0;
    int qt = 0;
    int sp = 0;
    dist[s] = 0;
    sigma[s] = 1.0;
    queue[qt++] = s;
    while (qh < qt) {
      int v = queue[qh++];
      stack_arr[sp++] = v;
      int a = rowptr[v];
      int b = rowptr[v + 1];
      for (int e = a; e < b; e++) {
        int w = colind[e];
        if (dist[w] < 0) {
          dist[w] = dist[v] + 1;
          queue[qt++] = w;
        }
        if (dist[w] == dist[v] + 1) {
          sigma[w] += sigma[v];
        }
      }
    }
    for (int idx = sp - 1; idx >= 0; idx--) {
      int w = stack_arr[idx];
      int a = rowptr[w];
      int b = rowptr[w + 1];
      for (int e = a; e < b; e++) {
        int v = colind[e];
        if (dist[v] == dist[w] - 1 && dist[v] >= 0) {
          double c = (sigma[v] / sigma[w]) * (1.0 + delta[w]);
          delta[v] += c;
        }
      }
      if (w != s) {
        bc[w] += delta[w];
      }
    }
  }
  double sum_bc = 0.0;
  for (int i = 0; i < n; i++) {
    sum_bc += bc[i];
  }
  double outv = 0.0;
  outv = sum_bc;
  return outv;
}
BENCH_MAIN_SCALAR3(
    T004_Module_047, BC, 4096, 16384, 65536, int DEG = 4;
    int edges_cap = n * DEG * 2;
    int *temp_u = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *temp_v = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *degcnt = (int *)malloc((size_t)n * sizeof(int));
    int *rowptr = (int *)malloc((size_t)(n + 1) * sizeof(int));
    int *colind = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *cursor = (int *)malloc((size_t)n * sizeof(int));
    int *dist = (int *)malloc((size_t)n * sizeof(int));
    double *sigma = (double *)malloc((size_t)n * sizeof(double));
    double *delta = (double *)malloc((size_t)n * sizeof(double));
    double *bc = (double *)malloc((size_t)n * sizeof(double));
    int *queue = (int *)malloc((size_t)n * sizeof(int));
    int *stack_arr = (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++)
        degcnt[i] = 0;
      int idx = 0;
      for (int u = 0; u < n; u++) {
        for (int k = 0; k < DEG; k++) {
          int v = (int)(bench_rng_next(&rng) % (unsigned long long)n);
          temp_u[idx] = u;
          temp_v[idx] = v;
          degcnt[u]++;
          idx++;
          temp_u[idx] = v;
          temp_v[idx] = u;
          degcnt[v]++;
          idx++;
        }
      }
      int E = idx;
      int acc = 0;
      for (int i = 0; i < n; i++) {
        rowptr[i] = acc;
        acc += degcnt[i];
      }
      rowptr[n] = acc;
      for (int i = 0; i < n; i++)
        cursor[i] = rowptr[i];
      for (int e = 0; e < E; e++) {
        int u = temp_u[e];
        int v = temp_v[e];
        int p = cursor[u]++;
        colind[p] = v;
      }
    },
    ans_scalar = run_bc(n, rowptr, colind, bc, dist, sigma, delta, queue,
                        stack_arr),
    ans_scalar, free(temp_u);
    free(temp_v); free(degcnt); free(rowptr); free(colind); free(cursor);
    free(dist); free(sigma); free(delta); free(bc); free(queue);
    free(stack_arr);)
