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

char *name = "Main:bigenough2 from A";

double f_if(float x, float y, float z) {
        float r28999 = x;
        float r29000 = y;
        float r29001 = z;
        float r29002 = r29001 + r28999;
        float r29003 = r29000 * r29002;
        float r29004 = r28999 + r29003;
        return r29004;
}

double f_id(double x, double y, double z) {
        double r29005 = x;
        double r29006 = y;
        double r29007 = z;
        double r29008 = r29007 + r29005;
        double r29009 = r29006 * r29008;
        double r29010 = r29005 + r29009;
        return r29010;
}


double f_of(float x, float y, float z) {
        float r29011 = x;
        float r29012 = y;
        float r29013 = z;
        float r29014 = r29013 + r29011;
        float r29015 = r29012 * r29014;
        float r29016 = r29011 + r29015;
        return r29016;
}

double f_od(double x, double y, double z) {
        double r29017 = x;
        double r29018 = y;
        double r29019 = z;
        double r29020 = r29019 + r29017;
        double r29021 = r29018 * r29020;
        double r29022 = r29017 + r29021;
        return r29022;
}

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

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r29023);
        mpfr_init(r29024);
        mpfr_init(r29025);
        mpfr_init(r29026);
        mpfr_init(r29027);
        mpfr_init(r29028);
}

double f_im(double x, double y, double z) {
        mpfr_set_d(r29023, x, MPFR_RNDN);
        mpfr_set_d(r29024, y, MPFR_RNDN);
        mpfr_set_d(r29025, z, MPFR_RNDN);
        mpfr_add(r29026, r29025, r29023, MPFR_RNDN);
        mpfr_mul(r29027, r29024, r29026, MPFR_RNDN);
        mpfr_add(r29028, r29023, r29027, MPFR_RNDN);
        return mpfr_get_d(r29028, MPFR_RNDN);
}

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

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r29029);
        mpfr_init(r29030);
        mpfr_init(r29031);
        mpfr_init(r29032);
        mpfr_init(r29033);
        mpfr_init(r29034);
}

double f_fm(double x, double y, double z) {
        mpfr_set_d(r29029, x, MPFR_RNDN);
        mpfr_set_d(r29030, y, MPFR_RNDN);
        mpfr_set_d(r29031, z, MPFR_RNDN);
        mpfr_add(r29032, r29031, r29029, MPFR_RNDN);
        mpfr_mul(r29033, r29030, r29032, MPFR_RNDN);
        mpfr_add(r29034, r29029, r29033, MPFR_RNDN);
        return mpfr_get_d(r29034, MPFR_RNDN);
}

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

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r29035);
        mpfr_init(r29036);
        mpfr_init(r29037);
        mpfr_init(r29038);
        mpfr_init(r29039);
        mpfr_init(r29040);
}

double f_dm(double x, double y, double z) {
        mpfr_set_d(r29035, x, MPFR_RNDN);
        mpfr_set_d(r29036, y, MPFR_RNDN);
        mpfr_set_d(r29037, z, MPFR_RNDN);
        mpfr_add(r29038, r29037, r29035, MPFR_RNDN);
        mpfr_mul(r29039, r29036, r29038, MPFR_RNDN);
        mpfr_add(r29040, r29035, r29039, MPFR_RNDN);
        return mpfr_get_d(r29040, MPFR_RNDN);
}

