#include "bench_harness.h"
#include "bench_utils.h"
#include <math.h>
#include <stdint.h>
#include <stdlib.h>
#include <string.h>
static inline double run_pagerank(int n, const int *in_rowptr,
                                  const int *in_colind, const int *outdeg,
                                  double *pr, double *pr_next) {
  const double damp = 0.85;
  double invn = 1.0 / (double)n;
  double *cur = pr;
  double *nxt = pr_next;
  for (int i = 0; i < n; i++) {
    cur[i] = invn;
  }
  for (int it = 0; it < 20; it++) {
    for (int i = 0; i < n; i++) {
      double s = 0.0;
      int a = in_rowptr[i];
      int b = in_rowptr[i + 1];
      for (int k = a; k < b; k++) {
        int src = in_colind[k];
        s += cur[src] / (double)outdeg[src];
      }
      nxt[i] = (1.0 - damp) * invn + damp * s;
    }
    double *swp = cur;
    cur = nxt;
    nxt = swp;
  }
  double sumv = 0.0;
  for (int i = 0; i < n; i++) {
    sumv += cur[i];
  }
  double outv = 0.0;
  outv = sumv;
  return outv;
}
BENCH_MAIN_SCALAR3(
    T004_Module_046, PR, 4096, 16384, 65536, int KOUT = 4;
    int edges_cap = n * KOUT;
    int *out_rowptr = (int *)malloc((size_t)(n + 1) * sizeof(int));
    int *out_colind = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *outdeg = (int *)malloc((size_t)n * sizeof(int));
    int *indeg = (int *)malloc((size_t)n * sizeof(int));
    int *in_rowptr = (int *)malloc((size_t)(n + 1) * sizeof(int));
    int *in_colind = (int *)malloc((size_t)edges_cap * sizeof(int));
    int *fillpos = (int *)malloc((size_t)n * sizeof(int));
    double *pr = (double *)malloc((size_t)n * sizeof(double));
    double *pr_next = (double *)malloc((size_t)n * sizeof(double));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      int pos = 0;
      for (int i = 0; i < n; i++) {
        out_rowptr[i] = pos;
        for (int k = 0; k < KOUT; k++) {
          int v = (int)(bench_rng_next(&rng) % (unsigned long long)n);
          out_colind[pos++] = v;
        }
        outdeg[i] = KOUT;
      }
      out_rowptr[n] = pos;
      for (int i = 0; i < n; i++)
        indeg[i] = 0;
      for (int u = 0; u < n; u++) {
        int a = out_rowptr[u];
        int b = out_rowptr[u + 1];
        for (int k = a; k < b; k++) {
          int v = out_colind[k];
          indeg[v]++;
        }
      }
      int acc = 0;
      for (int i = 0; i < n; i++) {
        in_rowptr[i] = acc;
        acc += indeg[i];
      }
      in_rowptr[n] = acc;
      for (int i = 0; i < n; i++)
        fillpos[i] = in_rowptr[i];
      for (int u = 0; u < n; u++) {
        int a = out_rowptr[u];
        int b = out_rowptr[u + 1];
        for (int k = a; k < b; k++) {
          int v = out_colind[k];
          int p = fillpos[v]++;
          in_colind[p] = u;
        }
      }
    },
    ans_scalar = run_pagerank(n, in_rowptr, in_colind, outdeg, pr, pr_next),
    ans_scalar, free(out_rowptr);
    free(out_colind); free(outdeg); free(indeg); free(in_rowptr);
    free(in_colind); free(fillpos); free(pr); free(pr_next);)
