
#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, const int *eu, const int *ev, const int *ew,
                double *ans_out) {
  const int LOG = 17;
  int m = n - 1;
  int *head = (int *)malloc((size_t)n * sizeof(int));
  int *to = (int *)malloc((size_t)(2 * m) * sizeof(int));
  int *nxt = (int *)malloc((size_t)(2 * m) * sizeof(int));
  int *wt = (int *)malloc((size_t)(2 * m) * sizeof(int));
  int *parent = (int *)malloc((size_t)n * sizeof(int));
  int *depth = (int *)malloc((size_t)n * sizeof(int));
  int *wpar = (int *)malloc((size_t)n * sizeof(int));
  int *q = (int *)malloc((size_t)n * sizeof(int));
  int *up = (int *)malloc((size_t)(LOG * n) * sizeof(int));
  long long *sw = (long long *)malloc((size_t)(LOG * n) * sizeof(long long));
  if (!head || !to || !nxt || !wt || !parent || !depth || !wpar || !q || !up ||
      !sw) {
    if (head)
      free(head);
    if (to)
      free(to);
    if (nxt)
      free(nxt);
    if (wt)
      free(wt);
    if (parent)
      free(parent);
    if (depth)
      free(depth);
    if (wpar)
      free(wpar);
    if (q)
      free(q);
    if (up)
      free(up);
    if (sw)
      free(sw);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < n; i++)
    head[i] = -1;
  int ei = 0;
  for (int i = 0; i < m; i++) {
    int a = eu[i];
    int b = ev[i];
    int w = ew[i];
    to[ei] = b;
    wt[ei] = w;
    nxt[ei] = head[a];
    head[a] = ei;
    ei++;
    to[ei] = a;
    wt[ei] = w;
    nxt[ei] = head[b];
    head[b] = ei;
    ei++;
  }
  parent[0] = 0;
  depth[0] = 0;
  wpar[0] = 0;
  int qh = 0, qt = 0;
  q[qt++] = 0;
  while (qh < qt) {
    int v = q[qh++];
    for (int e = head[v]; e != -1; e = nxt[e]) {
      int u = to[e];
      if (u == parent[v])
        continue;
      parent[u] = v;
      depth[u] = depth[v] + 1;
      wpar[u] = wt[e];
      q[qt++] = u;
    }
  }
  for (int v = 0; v < n; v++) {
    up[v] = parent[v];
    sw[v] = (long long)wpar[v];
  }
  for (int k = 1; k < LOG; k++) {
    int base_prev = (k - 1) * n;
    int base_cur = k * n;
    for (int v = 0; v < n; v++) {
      int mid = up[base_prev + v];
      up[base_cur + v] = up[base_prev + mid];
      sw[base_cur + v] = sw[base_prev + v] + sw[base_prev + mid];
    }
  }
  long long acc = 0;
  for (int t = 0; t < n; t++) {
    int u = t;
    int maxstep = depth[u] + 1;
    int steps =
        (int)((unsigned long long)(t * 11 + 7U) % (unsigned long long)maxstep);
    int cur = u;
    int kk = steps;
    long long sumw_path = 0;
    int bitpos = 0;
    while (kk) {
      if (kk & 1) {
        sumw_path += sw[bitpos * n + cur];
        cur = up[bitpos * n + cur];
      }
      kk >>= 1;
      bitpos++;
      if (bitpos >= LOG)
        break;
    }
    acc += sumw_path + (long long)cur;
  }
  double ans_double = 0.0;

  ans_double = (double)acc;

  *ans_out = ans_double;
  free(head);
  free(to);
  free(nxt);
  free(wt);
  free(parent);
  free(depth);
  free(wpar);
  free(q);
  free(up);
  free(sw);
}
BENCH_MAIN_SCALAR3(
    T003_Code_027, KTHANC, 4096, 16384, 65536,
    int *eu = (int *)malloc((size_t)(n - 1) * sizeof(int));
    int *ev = (int *)malloc((size_t)(n - 1) * sizeof(int));
    int *ew = (int *)malloc((size_t)(n - 1) * sizeof(int));
    double ans_scalar = 0.0;
    ,
    {
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 1; i < n; i++) {
        int p = (int)(bench_rng_next(&rng) % (unsigned long long)i);
        eu[i - 1] = i;
        ev[i - 1] = p;
        ew[i - 1] = (int)(bench_rng_next(&rng) % 100ULL) + 1;
      }
    },
    kernel_run(n, eu, ev, ew, &ans_scalar), ans_scalar, free(eu);
    free(ev); free(ew);)
