#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 *dist_in, double *ans_out) {
  (void)n;
  const int M = 16;
  int total_states = 1 << M;
  int *dist = (int *)malloc((size_t)M * (size_t)M * sizeof(int));
  int *dp = (int *)malloc((size_t)total_states * (size_t)M * sizeof(int));
  if (!dist || !dp) {
    if (dist)
      free(dist);
    if (dp)
      free(dp);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i < M * M; i++)
    dist[i] = dist_in[i];
  const int INF = 1000000000;
  for (int i = 0; i < total_states * M; i++)
    dp[i] = INF;
  dp[(1 << 0) * M + 0] = 0;
  for (int mask = 0; mask < total_states; mask++) {
    if (!(mask & 1))
      continue;
    for (int j = 0; j < M; j++) {
      if (!(mask & (1 << j)))
        continue;
      int cur = dp[mask * M + j];
      if (cur >= INF)
        continue;
      for (int nxt = 0; nxt < M; nxt++) {
        if (mask & (1 << nxt))
          continue;
        int newmask = mask | (1 << nxt);
        int cand = cur + dist[j * M + nxt];
        if (cand < dp[newmask * M + nxt]) {
          dp[newmask * M + nxt] = cand;
        }
      }
    }
  }
  int full_mask = (1 << M) - 1;
  int best = INF;
  for (int j = 0; j < M; j++) {
    int cand = dp[full_mask * M + j] + dist[j * M + 0];
    if (cand < best)
      best = cand;
  }
  double base_ans = (double)best;
  double ans_double = 0.0;

  ans_double = base_ans;

  *ans_out = ans_double;
  free(dist);
  free(dp);
}
BENCH_MAIN_SCALAR3(
    T003_Code_034, TSP, 4096, 16384, 65536,
    int *dist = (int *)malloc((size_t)(16 * 16) * sizeof(int));
    double ans_scalar = 0.0;
    ,
    {
      const int M = 16;
      bench_rng64_t rng = bench_rng_init(seed);
      for (int i = 0; i < M; i++) {
        for (int j = 0; j < M; j++) {
          if (i == j) {
            dist[i * M + j] = 0;
          } else if (j < i) {
            dist[i * M + j] = dist[j * M + i];
          } else {
            int w = (int)(bench_rng_next(&rng) % 99ULL) + 1;
            dist[i * M + j] = w;
          }
        }
      }
    },
    kernel_run(n, dist, &ans_scalar), ans_scalar, free(dist);)
