#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 r26114 = d1;
        float r26115 = 10;
        float r26116 = r26114 * r26115;
        float r26117 = d2;
        float r26118 = r26114 * r26117;
        float r26119 = r26116 + r26118;
        float r26120 = 20;
        float r26121 = r26114 * r26120;
        float r26122 = r26119 + r26121;
        return r26122;
}

double f_id(double d1, double d2) {
        double r26123 = d1;
        double r26124 = 10;
        double r26125 = r26123 * r26124;
        double r26126 = d2;
        double r26127 = r26123 * r26126;
        double r26128 = r26125 + r26127;
        double r26129 = 20;
        double r26130 = r26123 * r26129;
        double r26131 = r26128 + r26130;
        return r26131;
}


double f_of(float d1, float d2) {
        float r26132 = d2;
        float r26133 = 10;
        float r26134 = r26132 + r26133;
        float r26135 = 20;
        float r26136 = r26134 + r26135;
        float r26137 = d1;
        float r26138 = r26136 * r26137;
        return r26138;
}

double f_od(double d1, double d2) {
        double r26139 = d2;
        double r26140 = 10;
        double r26141 = r26139 + r26140;
        double r26142 = 20;
        double r26143 = r26141 + r26142;
        double r26144 = d1;
        double r26145 = r26143 * r26144;
        return r26145;
}

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 r26146, r26147, r26148, r26149, r26150, r26151, r26152, r26153, r26154;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1424);
        mpfr_init(r26146);
        mpfr_init_set_str(r26147, "10", 10, MPFR_RNDN);
        mpfr_init(r26148);
        mpfr_init(r26149);
        mpfr_init(r26150);
        mpfr_init(r26151);
        mpfr_init_set_str(r26152, "20", 10, MPFR_RNDN);
        mpfr_init(r26153);
        mpfr_init(r26154);
}

double f_im(double d1, double d2) {
        mpfr_set_d(r26146, d1, MPFR_RNDN);
        ;
        mpfr_mul(r26148, r26146, r26147, MPFR_RNDN);
        mpfr_set_d(r26149, d2, MPFR_RNDN);
        mpfr_mul(r26150, r26146, r26149, MPFR_RNDN);
        mpfr_add(r26151, r26148, r26150, MPFR_RNDN);
        ;
        mpfr_mul(r26153, r26146, r26152, MPFR_RNDN);
        mpfr_add(r26154, r26151, r26153, MPFR_RNDN);
        return mpfr_get_d(r26154, MPFR_RNDN);
}

static mpfr_t r26155, r26156, r26157, r26158, r26159, r26160, r26161;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r26155);
        mpfr_init_set_str(r26156, "10", 10, MPFR_RNDN);
        mpfr_init(r26157);
        mpfr_init_set_str(r26158, "20", 10, MPFR_RNDN);
        mpfr_init(r26159);
        mpfr_init(r26160);
        mpfr_init(r26161);
}

double f_fm(double d1, double d2) {
        mpfr_set_d(r26155, d2, MPFR_RNDN);
        ;
        mpfr_add(r26157, r26155, r26156, MPFR_RNDN);
        ;
        mpfr_add(r26159, r26157, r26158, MPFR_RNDN);
        mpfr_set_d(r26160, d1, MPFR_RNDN);
        mpfr_mul(r26161, r26159, r26160, MPFR_RNDN);
        return mpfr_get_d(r26161, MPFR_RNDN);
}

static mpfr_t r26162, r26163, r26164, r26165, r26166, r26167, r26168;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r26162);
        mpfr_init_set_str(r26163, "10", 10, MPFR_RNDN);
        mpfr_init(r26164);
        mpfr_init_set_str(r26165, "20", 10, MPFR_RNDN);
        mpfr_init(r26166);
        mpfr_init(r26167);
        mpfr_init(r26168);
}

double f_dm(double d1, double d2) {
        mpfr_set_d(r26162, d2, MPFR_RNDN);
        ;
        mpfr_add(r26164, r26162, r26163, MPFR_RNDN);
        ;
        mpfr_add(r26166, r26164, r26165, MPFR_RNDN);
        mpfr_set_d(r26167, d1, MPFR_RNDN);
        mpfr_mul(r26168, r26166, r26167, MPFR_RNDN);
        return mpfr_get_d(r26168, MPFR_RNDN);
}

