#include <tgmath.h>
#include <gmp.h>
#include <mpfr.h>
#include <stdio.h>
#include <stdbool.h>

char *name = "Main:i from ";

double f_if(float x) {
        float r28964 = x;
        float r28965 = r28964 + r28964;
        float r28966 = r28965 + r28964;
        float r28967 = r28966 + r28964;
        float r28968 = r28967 + r28964;
        return r28968;
}

double f_id(double x) {
        double r28969 = x;
        double r28970 = r28969 + r28969;
        double r28971 = r28970 + r28969;
        double r28972 = r28971 + r28969;
        double r28973 = r28972 + r28969;
        return r28973;
}


double f_of(float x) {
        float r28974 = x;
        float r28975 = r28974 + r28974;
        float r28976 = r28975 + r28974;
        float r28977 = r28976 + r28974;
        float r28978 = r28977 + r28974;
        return r28978;
}

double f_od(double x) {
        double r28979 = x;
        double r28980 = r28979 + r28979;
        double r28981 = r28980 + r28979;
        double r28982 = r28981 + r28979;
        double r28983 = r28982 + r28979;
        return r28983;
}

void mpfr_fmod2(mpfr_t r, mpfr_t n, mpfr_t d, mpfr_rnd_t rmd) {
        mpfr_fmod(r, n, d, rmd);
        if (mpfr_cmp_ui(r, 0) < 0) mpfr_add(r, r, d, rmd);
}


static mpfr_t r28984, r28985, r28986, r28987, r28988;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r28984);
        mpfr_init(r28985);
        mpfr_init(r28986);
        mpfr_init(r28987);
        mpfr_init(r28988);
}

double f_im(double x) {
        mpfr_set_d(r28984, x, MPFR_RNDN);
        mpfr_add(r28985, r28984, r28984, MPFR_RNDN);
        mpfr_add(r28986, r28985, r28984, MPFR_RNDN);
        mpfr_add(r28987, r28986, r28984, MPFR_RNDN);
        mpfr_add(r28988, r28987, r28984, MPFR_RNDN);
        return mpfr_get_d(r28988, MPFR_RNDN);
}

static mpfr_t r28989, r28990, r28991, r28992, r28993;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r28989);
        mpfr_init(r28990);
        mpfr_init(r28991);
        mpfr_init(r28992);
        mpfr_init(r28993);
}

double f_fm(double x) {
        mpfr_set_d(r28989, x, MPFR_RNDN);
        mpfr_add(r28990, r28989, r28989, MPFR_RNDN);
        mpfr_add(r28991, r28990, r28989, MPFR_RNDN);
        mpfr_add(r28992, r28991, r28989, MPFR_RNDN);
        mpfr_add(r28993, r28992, r28989, MPFR_RNDN);
        return mpfr_get_d(r28993, MPFR_RNDN);
}

static mpfr_t r28994, r28995, r28996, r28997, r28998;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r28994);
        mpfr_init(r28995);
        mpfr_init(r28996);
        mpfr_init(r28997);
        mpfr_init(r28998);
}

double f_dm(double x) {
        mpfr_set_d(r28994, x, MPFR_RNDN);
        mpfr_add(r28995, r28994, r28994, MPFR_RNDN);
        mpfr_add(r28996, r28995, r28994, MPFR_RNDN);
        mpfr_add(r28997, r28996, r28994, MPFR_RNDN);
        mpfr_add(r28998, r28997, r28994, MPFR_RNDN);
        return mpfr_get_d(r28998, MPFR_RNDN);
}

