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

char *name = "FastMath test5";

double f_if(float d1) {
        float r26512 = d1;
        float r26513 = r26512 * r26512;
        float r26514 = r26512 * r26513;
        float r26515 = r26514 * r26512;
        float r26516 = r26515 * r26512;
        float r26517 = r26516 * r26513;
        float r26518 = r26517 * r26512;
        float r26519 = r26512 * r26518;
        float r26520 = r26519 * r26512;
        return r26520;
}

double f_id(double d1) {
        double r26521 = d1;
        double r26522 = r26521 * r26521;
        double r26523 = r26521 * r26522;
        double r26524 = r26523 * r26521;
        double r26525 = r26524 * r26521;
        double r26526 = r26525 * r26522;
        double r26527 = r26526 * r26521;
        double r26528 = r26521 * r26527;
        double r26529 = r26528 * r26521;
        return r26529;
}


double f_of(float d1) {
        float r26530 = d1;
        float r26531 = 3;
        float r26532 = 2;
        float r26533 = r26531 + r26532;
        float r26534 = r26533 + r26533;
        float r26535 = pow(r26530, r26534);
        return r26535;
}

double f_od(double d1) {
        double r26536 = d1;
        double r26537 = 3;
        double r26538 = 2;
        double r26539 = r26537 + r26538;
        double r26540 = r26539 + r26539;
        double r26541 = pow(r26536, r26540);
        return r26541;
}

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 r26542, r26543, r26544, r26545, r26546, r26547, r26548, r26549, r26550;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(336);
        mpfr_init(r26542);
        mpfr_init(r26543);
        mpfr_init(r26544);
        mpfr_init(r26545);
        mpfr_init(r26546);
        mpfr_init(r26547);
        mpfr_init(r26548);
        mpfr_init(r26549);
        mpfr_init(r26550);
}

double f_im(double d1) {
        mpfr_set_d(r26542, d1, MPFR_RNDN);
        mpfr_mul(r26543, r26542, r26542, MPFR_RNDN);
        mpfr_mul(r26544, r26542, r26543, MPFR_RNDN);
        mpfr_mul(r26545, r26544, r26542, MPFR_RNDN);
        mpfr_mul(r26546, r26545, r26542, MPFR_RNDN);
        mpfr_mul(r26547, r26546, r26543, MPFR_RNDN);
        mpfr_mul(r26548, r26547, r26542, MPFR_RNDN);
        mpfr_mul(r26549, r26542, r26548, MPFR_RNDN);
        mpfr_mul(r26550, r26549, r26542, MPFR_RNDN);
        return mpfr_get_d(r26550, MPFR_RNDN);
}

static mpfr_t r26551, r26552, r26553, r26554, r26555, r26556;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(336);
        mpfr_init(r26551);
        mpfr_init_set_str(r26552, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r26553, "2", 10, MPFR_RNDN);
        mpfr_init(r26554);
        mpfr_init(r26555);
        mpfr_init(r26556);
}

double f_fm(double d1) {
        mpfr_set_d(r26551, d1, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26554, r26552, r26553, MPFR_RNDN);
        mpfr_add(r26555, r26554, r26554, MPFR_RNDN);
        mpfr_pow(r26556, r26551, r26555, MPFR_RNDN);
        return mpfr_get_d(r26556, MPFR_RNDN);
}

static mpfr_t r26557, r26558, r26559, r26560, r26561, r26562;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(336);
        mpfr_init(r26557);
        mpfr_init_set_str(r26558, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r26559, "2", 10, MPFR_RNDN);
        mpfr_init(r26560);
        mpfr_init(r26561);
        mpfr_init(r26562);
}

double f_dm(double d1) {
        mpfr_set_d(r26557, d1, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26560, r26558, r26559, MPFR_RNDN);
        mpfr_add(r26561, r26560, r26560, MPFR_RNDN);
        mpfr_pow(r26562, r26557, r26561, MPFR_RNDN);
        return mpfr_get_d(r26562, MPFR_RNDN);
}

