#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 = 30;
        float r29012 = d2;
        float r29013 = r29011 + r29012;
        float r29014 = d1;
        float r29015 = r29013 * r29014;
        return r29015;
}

double f_od(double d1, double d2) {
        double r29016 = 30;
        double r29017 = d2;
        double r29018 = r29016 + r29017;
        double r29019 = d1;
        double r29020 = r29018 * r29019;
        return r29020;
}

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 r29021, r29022, r29023, r29024, r29025, r29026, r29027, r29028, r29029;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r29021);
        mpfr_init_set_str(r29022, "10", 10, MPFR_RNDN);
        mpfr_init(r29023);
        mpfr_init(r29024);
        mpfr_init(r29025);
        mpfr_init(r29026);
        mpfr_init_set_str(r29027, "20", 10, MPFR_RNDN);
        mpfr_init(r29028);
        mpfr_init(r29029);
}

double f_im(double d1, double d2) {
        mpfr_set_d(r29021, d1, MPFR_RNDN);
        ;
        mpfr_mul(r29023, r29021, r29022, MPFR_RNDN);
        mpfr_set_d(r29024, d2, MPFR_RNDN);
        mpfr_mul(r29025, r29021, r29024, MPFR_RNDN);
        mpfr_add(r29026, r29023, r29025, MPFR_RNDN);
        ;
        mpfr_mul(r29028, r29021, r29027, MPFR_RNDN);
        mpfr_add(r29029, r29026, r29028, MPFR_RNDN);
        return mpfr_get_d(r29029, MPFR_RNDN);
}

static mpfr_t r29030, r29031, r29032, r29033, r29034;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init_set_str(r29030, "30", 10, MPFR_RNDN);
        mpfr_init(r29031);
        mpfr_init(r29032);
        mpfr_init(r29033);
        mpfr_init(r29034);
}

double f_fm(double d1, double d2) {
        ;
        mpfr_set_d(r29031, d2, MPFR_RNDN);
        mpfr_add(r29032, r29030, r29031, MPFR_RNDN);
        mpfr_set_d(r29033, d1, MPFR_RNDN);
        mpfr_mul(r29034, r29032, r29033, MPFR_RNDN);
        return mpfr_get_d(r29034, MPFR_RNDN);
}

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

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init_set_str(r29035, "30", 10, MPFR_RNDN);
        mpfr_init(r29036);
        mpfr_init(r29037);
        mpfr_init(r29038);
        mpfr_init(r29039);
}

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

