
#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, double *ans_out) {
  if (n < 2)
    n = 2;
  int N = n;
  int *is_comp = (int *)malloc((size_t)(N + 1) * sizeof(int));
  int *primes = (int *)malloc((size_t)(N + 1) * sizeof(int));
  int *phi = (int *)malloc((size_t)(N + 1) * sizeof(int));
  int *mu = (int *)malloc((size_t)(N + 1) * sizeof(int));
  if (!is_comp || !primes || !phi || !mu) {
    if (is_comp)
      free(is_comp);
    if (primes)
      free(primes);
    if (phi)
      free(phi);
    if (mu)
      free(mu);
    *ans_out = 0.0;
    return;
  }
  for (int i = 0; i <= N; i++) {
    is_comp[i] = 0;
    phi[i] = 0;
    mu[i] = 0;
  }
  int pcnt = 0;
  phi[1] = 1;
  mu[1] = 1;
  for (int i = 2; i <= N; i++) {
    if (!is_comp[i]) {
      primes[pcnt++] = i;
      phi[i] = i - 1;
      mu[i] = -1;
    }
    for (int pi = 0; pi < pcnt; pi++) {
      int p = primes[pi];
      long long ip = (long long)i * (long long)p;
      if (ip > N)
        break;
      is_comp[ip] = 1;
      if (i % p == 0) {
        phi[ip] = phi[i] * p;
        mu[ip] = 0;
        break;
      } else {
        phi[ip] = phi[i] * (p - 1);
        mu[ip] = -mu[i];
      }
    }
  }
  long long sumPhi = 0LL;
  long long mobScore = 0LL;
  for (int i = 1; i <= N; i++) {
    sumPhi += (long long)phi[i];
    mobScore += (long long)mu[i] * (long long)i;
  }
  long long totalScore = sumPhi + mobScore;
  double ans_double = 0.0;

  ans_double = (double)totalScore;

  *ans_out = ans_double;
  free(is_comp);
  free(primes);
  free(phi);
  free(mu);
}
BENCH_MAIN_SCALAR3(T003_Code_040, SIEVE, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
