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

char *name = "FastMath repmul";

double f_if(float d1) {
        float r28959 = d1;
        float r28960 = r28959 * r28959;
        float r28961 = r28960 * r28959;
        float r28962 = r28961 * r28959;
        return r28962;
}

double f_id(double d1) {
        double r28963 = d1;
        double r28964 = r28963 * r28963;
        double r28965 = r28964 * r28963;
        double r28966 = r28965 * r28963;
        return r28966;
}


double f_of(float d1) {
        float r28967 = d1;
        float r28968 = 3;
        float r28969 = 1;
        float r28970 = r28968 + r28969;
        float r28971 = pow(r28967, r28970);
        return r28971;
}

double f_od(double d1) {
        double r28972 = d1;
        double r28973 = 3;
        double r28974 = 1;
        double r28975 = r28973 + r28974;
        double r28976 = pow(r28972, r28975);
        return r28976;
}

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 r28977, r28978, r28979, r28980;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r28977);
        mpfr_init(r28978);
        mpfr_init(r28979);
        mpfr_init(r28980);
}

double f_im(double d1) {
        mpfr_set_d(r28977, d1, MPFR_RNDN);
        mpfr_mul(r28978, r28977, r28977, MPFR_RNDN);
        mpfr_mul(r28979, r28978, r28977, MPFR_RNDN);
        mpfr_mul(r28980, r28979, r28977, MPFR_RNDN);
        return mpfr_get_d(r28980, MPFR_RNDN);
}

static mpfr_t r28981, r28982, r28983, r28984, r28985;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r28981);
        mpfr_init_set_str(r28982, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r28983, "1", 10, MPFR_RNDN);
        mpfr_init(r28984);
        mpfr_init(r28985);
}

double f_fm(double d1) {
        mpfr_set_d(r28981, d1, MPFR_RNDN);
        ;
        ;
        mpfr_add(r28984, r28982, r28983, MPFR_RNDN);
        mpfr_pow(r28985, r28981, r28984, MPFR_RNDN);
        return mpfr_get_d(r28985, MPFR_RNDN);
}

static mpfr_t r28986, r28987, r28988, r28989, r28990;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r28986);
        mpfr_init_set_str(r28987, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r28988, "1", 10, MPFR_RNDN);
        mpfr_init(r28989);
        mpfr_init(r28990);
}

double f_dm(double d1) {
        mpfr_set_d(r28986, d1, MPFR_RNDN);
        ;
        ;
        mpfr_add(r28989, r28987, r28988, MPFR_RNDN);
        mpfr_pow(r28990, r28986, r28989, MPFR_RNDN);
        return mpfr_get_d(r28990, MPFR_RNDN);
}

