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

char *name = "FastMath test3";

double f_if(float d1, float d2, float d3) {
        float r20822 = d1;
        float r20823 = 3.0f;
        float r20824 = r20822 * r20823;
        float r20825 = d2;
        float r20826 = r20822 * r20825;
        float r20827 = r20824 + r20826;
        float r20828 = d3;
        float r20829 = r20822 * r20828;
        float r20830 = r20827 + r20829;
        return r20830;
}

double f_id(double d1, double d2, double d3) {
        double r20831 = d1;
        double r20832 = 3.0;
        double r20833 = r20831 * r20832;
        double r20834 = d2;
        double r20835 = r20831 * r20834;
        double r20836 = r20833 + r20835;
        double r20837 = d3;
        double r20838 = r20831 * r20837;
        double r20839 = r20836 + r20838;
        return r20839;
}


double f_of(float d1, float d2, float d3) {
        float r20840 = d1;
        float r20841 = 3.0f;
        float r20842 = d2;
        float r20843 = r20841 + r20842;
        float r20844 = d3;
        float r20845 = r20843 + r20844;
        float r20846 = r20840 * r20845;
        return r20846;
}

double f_od(double d1, double d2, double d3) {
        double r20847 = d1;
        double r20848 = 3.0;
        double r20849 = d2;
        double r20850 = r20848 + r20849;
        double r20851 = d3;
        double r20852 = r20850 + r20851;
        double r20853 = r20847 * r20852;
        return r20853;
}

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 r20854, r20855, r20856, r20857, r20858, r20859, r20860, r20861, r20862;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init(r20854);
        mpfr_init_set_str(r20855, "3", 10, MPFR_RNDN);
        mpfr_init(r20856);
        mpfr_init(r20857);
        mpfr_init(r20858);
        mpfr_init(r20859);
        mpfr_init(r20860);
        mpfr_init(r20861);
        mpfr_init(r20862);
}

double f_im(double d1, double d2, double d3) {
        mpfr_set_d(r20854, d1, MPFR_RNDN);
        ;
        mpfr_mul(r20856, r20854, r20855, MPFR_RNDN);
        mpfr_set_d(r20857, d2, MPFR_RNDN);
        mpfr_mul(r20858, r20854, r20857, MPFR_RNDN);
        mpfr_add(r20859, r20856, r20858, MPFR_RNDN);
        mpfr_set_d(r20860, d3, MPFR_RNDN);
        mpfr_mul(r20861, r20854, r20860, MPFR_RNDN);
        mpfr_add(r20862, r20859, r20861, MPFR_RNDN);
        return mpfr_get_d(r20862, MPFR_RNDN);
}

static mpfr_t r20863, r20864, r20865, r20866, r20867, r20868, r20869;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r20863);
        mpfr_init_set_str(r20864, "3", 10, MPFR_RNDN);
        mpfr_init(r20865);
        mpfr_init(r20866);
        mpfr_init(r20867);
        mpfr_init(r20868);
        mpfr_init(r20869);
}

double f_fm(double d1, double d2, double d3) {
        mpfr_set_d(r20863, d1, MPFR_RNDN);
        ;
        mpfr_set_d(r20865, d2, MPFR_RNDN);
        mpfr_add(r20866, r20864, r20865, MPFR_RNDN);
        mpfr_set_d(r20867, d3, MPFR_RNDN);
        mpfr_add(r20868, r20866, r20867, MPFR_RNDN);
        mpfr_mul(r20869, r20863, r20868, MPFR_RNDN);
        return mpfr_get_d(r20869, MPFR_RNDN);
}

static mpfr_t r20870, r20871, r20872, r20873, r20874, r20875, r20876;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r20870);
        mpfr_init_set_str(r20871, "3", 10, MPFR_RNDN);
        mpfr_init(r20872);
        mpfr_init(r20873);
        mpfr_init(r20874);
        mpfr_init(r20875);
        mpfr_init(r20876);
}

double f_dm(double d1, double d2, double d3) {
        mpfr_set_d(r20870, d1, MPFR_RNDN);
        ;
        mpfr_set_d(r20872, d2, MPFR_RNDN);
        mpfr_add(r20873, r20871, r20872, MPFR_RNDN);
        mpfr_set_d(r20874, d3, MPFR_RNDN);
        mpfr_add(r20875, r20873, r20874, MPFR_RNDN);
        mpfr_mul(r20876, r20870, r20875, MPFR_RNDN);
        return mpfr_get_d(r20876, MPFR_RNDN);
}

