
#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, double *ans_out) {
  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 *dist0 = (int *)malloc((size_t)n * sizeof(int));
  int *distA = (int *)malloc((size_t)n * sizeof(int));
  int *distB = (int *)malloc((size_t)n * sizeof(int));
  int *q = (int *)malloc((size_t)n * sizeof(int));
  if (!head || !to || !nxt || !dist0 || !distA || !distB || !q) {
    if (head)
      free(head);
    if (to)
      free(to);
    if (nxt)
      free(nxt);
    if (dist0)
      free(dist0);
    if (distA)
      free(distA);
    if (distB)
      free(distB);
    if (q)
      free(q);
    *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];
    to[ei] = b;
    nxt[ei] = head[a];
    head[a] = ei;
    ei++;
    to[ei] = a;
    nxt[ei] = head[b];
    head[b] = ei;
    ei++;
  }
  for (int i = 0; i < n; i++)
    dist0[i] = -1;
  int qh = 0, qt = 0;
  dist0[0] = 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 (dist0[u] == -1) {
        dist0[u] = dist0[v] + 1;
        q[qt++] = u;
      }
    }
  }
  int nodeA = 0;
  for (int i = 1; i < n; i++) {
    if (dist0[i] > dist0[nodeA])
      nodeA = i;
  }
  for (int i = 0; i < n; i++)
    distA[i] = -1;
  qh = 0;
  qt = 0;
  distA[nodeA] = 0;
  q[qt++] = nodeA;
  while (qh < qt) {
    int v = q[qh++];
    for (int e = head[v]; e != -1; e = nxt[e]) {
      int u = to[e];
      if (distA[u] == -1) {
        distA[u] = distA[v] + 1;
        q[qt++] = u;
      }
    }
  }
  int nodeB = nodeA;
  for (int i = 0; i < n; i++) {
    if (distA[i] > distA[nodeB])
      nodeB = i;
  }
  for (int i = 0; i < n; i++)
    distB[i] = -1;
  qh = 0;
  qt = 0;
  distB[nodeB] = 0;
  q[qt++] = nodeB;
  while (qh < qt) {
    int v = q[qh++];
    for (int e = head[v]; e != -1; e = nxt[e]) {
      int u = to[e];
      if (distB[u] == -1) {
        distB[u] = distB[v] + 1;
        q[qt++] = u;
      }
    }
  }
  long long total = 0;
  for (int i = 0; i < n; i++) {
    int da = distA[i];
    int db = distB[i];
    if (db > da)
      da = db;
    total += (long long)da;
  }
  double ans_double = 0.0;

  ans_double = (double)total;

  *ans_out = ans_double;
  free(head);
  free(to);
  free(nxt);
  free(dist0);
  free(distA);
  free(distB);
  free(q);
}
BENCH_MAIN_SCALAR3(
    T003_Code_028, DIAMQ, 4096, 16384, 65536,
    int *eu = (int *)malloc((size_t)(n - 1) * sizeof(int));
    int *ev = (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;
      }
    },
    kernel_run(n, eu, ev, &ans_scalar), ans_scalar, free(eu);
    free(ev);)
