
#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) {
  const unsigned long long MOD = 1000000007ULL;
  long long T = (long long)n * 10LL;
  if (T < 0)
    T = 0;
  unsigned long long ansVal;
  if (T == 0) {
    ansVal = 0ULL;
  } else if (T == 1) {
    ansVal = 1ULL;
  } else if (T == 2) {
    ansVal = 1ULL;
  } else {
    unsigned long long baseM[9];
    unsigned long long resM[9];
    unsigned long long tmpM[9];
    baseM[0] = 1ULL;
    baseM[1] = 1ULL;
    baseM[2] = 1ULL;
    baseM[3] = 1ULL;
    baseM[4] = 0ULL;
    baseM[5] = 0ULL;
    baseM[6] = 0ULL;
    baseM[7] = 1ULL;
    baseM[8] = 0ULL;
    resM[0] = 1ULL;
    resM[1] = 0ULL;
    resM[2] = 0ULL;
    resM[3] = 0ULL;
    resM[4] = 1ULL;
    resM[5] = 0ULL;
    resM[6] = 0ULL;
    resM[7] = 0ULL;
    resM[8] = 1ULL;
    unsigned long long e = (unsigned long long)(T - 2LL);
    while (e > 0ULL) {
      if (e & 1ULL) {
        for (int i = 0; i < 3; i++) {
          for (int j = 0; j < 3; j++) {
            unsigned long long s = 0ULL;
            for (int k = 0; k < 3; k++) {
              __uint128_t prod =
                  (__uint128_t)resM[i * 3 + k] * baseM[k * 3 + j];
              unsigned long long addv = (unsigned long long)(prod % MOD);
              s += addv;
              if (s >= (1ULL << 61)) {
                s %= MOD;
              }
            }
            tmpM[i * 3 + j] = s % MOD;
          }
        }
        for (int t = 0; t < 9; t++)
          resM[t] = tmpM[t];
      }
      for (int i2 = 0; i2 < 3; i2++) {
        for (int j2 = 0; j2 < 3; j2++) {
          unsigned long long s2 = 0ULL;
          for (int k2 = 0; k2 < 3; k2++) {
            __uint128_t prod2 =
                (__uint128_t)baseM[i2 * 3 + k2] * baseM[k2 * 3 + j2];
            unsigned long long addv2 = (unsigned long long)(prod2 % MOD);
            s2 += addv2;
            if (s2 >= (1ULL << 61)) {
              s2 %= MOD;
            }
          }
          tmpM[i2 * 3 + j2] = s2 % MOD;
        }
      }
      for (int t2 = 0; t2 < 9; t2++)
        baseM[t2] = tmpM[t2];
      e >>= 1ULL;
    }
    unsigned long long v0 = 1ULL;
    unsigned long long v1 = 1ULL;
    unsigned long long v2 = 0ULL;
    __uint128_t acc0 = (__uint128_t)resM[0] * v0 + (__uint128_t)resM[1] * v1 +
                       (__uint128_t)resM[2] * v2;
    unsigned long long val0 = (unsigned long long)(acc0 % MOD);
    ansVal = val0;
  }
  double ans_double = 0.0;

  ans_double = (double)ansVal;

  *ans_out = ans_double;
}
BENCH_MAIN_SCALAR3(T003_Code_041, KITAMASA, 4096, 16384, 65536,
                   double ans_scalar = 0.0;
                   , ;, kernel_run(n, &ans_scalar), ans_scalar, ;)
