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

char *name = "FastMath test2";

double f_if(float d1, float d2) {
        float r28993 = d1;
        float r28994 = 10;
        float r28995 = r28993 * r28994;
        float r28996 = d2;
        float r28997 = r28993 * r28996;
        float r28998 = r28995 + r28997;
        float r28999 = 20;
        float r29000 = r28993 * r28999;
        float r29001 = r28998 + r29000;
        return r29001;
}

double f_id(double d1, double d2) {
        double r29002 = d1;
        double r29003 = 10;
        double r29004 = r29002 * r29003;
        double r29005 = d2;
        double r29006 = r29002 * r29005;
        double r29007 = r29004 + r29006;
        double r29008 = 20;
        double r29009 = r29002 * r29008;
        double r29010 = r29007 + r29009;
        return r29010;
}


double f_of(float d1, float d2) {
        float r29011 = d1;
        float r29012 = d2;
        float r29013 = 10;
        float r29014 = r29012 + r29013;
        float r29015 = 20;
        float r29016 = r29014 + r29015;
        float r29017 = r29011 * r29016;
        return r29017;
}

double f_od(double d1, double d2) {
        double r29018 = d1;
        double r29019 = d2;
        double r29020 = 10;
        double r29021 = r29019 + r29020;
        double r29022 = 20;
        double r29023 = r29021 + r29022;
        double r29024 = r29018 * r29023;
        return r29024;
}

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 r29025, r29026, r29027, r29028, r29029, r29030, r29031, r29032, r29033;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r29025);
        mpfr_init_set_str(r29026, "10", 10, MPFR_RNDN);
        mpfr_init(r29027);
        mpfr_init(r29028);
        mpfr_init(r29029);
        mpfr_init(r29030);
        mpfr_init_set_str(r29031, "20", 10, MPFR_RNDN);
        mpfr_init(r29032);
        mpfr_init(r29033);
}

double f_im(double d1, double d2) {
        mpfr_set_d(r29025, d1, MPFR_RNDN);
        ;
        mpfr_mul(r29027, r29025, r29026, MPFR_RNDN);
        mpfr_set_d(r29028, d2, MPFR_RNDN);
        mpfr_mul(r29029, r29025, r29028, MPFR_RNDN);
        mpfr_add(r29030, r29027, r29029, MPFR_RNDN);
        ;
        mpfr_mul(r29032, r29025, r29031, MPFR_RNDN);
        mpfr_add(r29033, r29030, r29032, MPFR_RNDN);
        return mpfr_get_d(r29033, MPFR_RNDN);
}

static mpfr_t r29034, r29035, r29036, r29037, r29038, r29039, r29040;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r29034);
        mpfr_init(r29035);
        mpfr_init_set_str(r29036, "10", 10, MPFR_RNDN);
        mpfr_init(r29037);
        mpfr_init_set_str(r29038, "20", 10, MPFR_RNDN);
        mpfr_init(r29039);
        mpfr_init(r29040);
}

double f_fm(double d1, double d2) {
        mpfr_set_d(r29034, d1, MPFR_RNDN);
        mpfr_set_d(r29035, d2, MPFR_RNDN);
        ;
        mpfr_add(r29037, r29035, r29036, MPFR_RNDN);
        ;
        mpfr_add(r29039, r29037, r29038, MPFR_RNDN);
        mpfr_mul(r29040, r29034, r29039, MPFR_RNDN);
        return mpfr_get_d(r29040, MPFR_RNDN);
}

static mpfr_t r29041, r29042, r29043, r29044, r29045, r29046, r29047;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r29041);
        mpfr_init(r29042);
        mpfr_init_set_str(r29043, "10", 10, MPFR_RNDN);
        mpfr_init(r29044);
        mpfr_init_set_str(r29045, "20", 10, MPFR_RNDN);
        mpfr_init(r29046);
        mpfr_init(r29047);
}

double f_dm(double d1, double d2) {
        mpfr_set_d(r29041, d1, MPFR_RNDN);
        mpfr_set_d(r29042, d2, MPFR_RNDN);
        ;
        mpfr_add(r29044, r29042, r29043, MPFR_RNDN);
        ;
        mpfr_add(r29046, r29044, r29045, MPFR_RNDN);
        mpfr_mul(r29047, r29041, r29046, MPFR_RNDN);
        return mpfr_get_d(r29047, MPFR_RNDN);
}

