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

char *name = "Quadratic roots, wide range";

double f_if(float a, float b, float c) {
        float r20899 = b;
        float r20900 = -r20899;
        float r20901 = r20899 * r20899;
        float r20902 = 4;
        float r20903 = a;
        float r20904 = r20902 * r20903;
        float r20905 = c;
        float r20906 = r20904 * r20905;
        float r20907 = r20901 - r20906;
        float r20908 = sqrt(r20907);
        float r20909 = r20900 + r20908;
        float r20910 = 2;
        float r20911 = r20910 * r20903;
        float r20912 = r20909 / r20911;
        return r20912;
}

double f_id(double a, double b, double c) {
        double r20913 = b;
        double r20914 = -r20913;
        double r20915 = r20913 * r20913;
        double r20916 = 4;
        double r20917 = a;
        double r20918 = r20916 * r20917;
        double r20919 = c;
        double r20920 = r20918 * r20919;
        double r20921 = r20915 - r20920;
        double r20922 = sqrt(r20921);
        double r20923 = r20914 + r20922;
        double r20924 = 2;
        double r20925 = r20924 * r20917;
        double r20926 = r20923 / r20925;
        return r20926;
}


double f_of(float a, float b, float c) {
        float r20927 = 4;
        float r20928 = 2;
        float r20929 = r20927 / r20928;
        float r20930 = c;
        float r20931 = b;
        float r20932 = -r20931;
        float r20933 = r20931 * r20931;
        float r20934 = a;
        float r20935 = r20930 * r20934;
        float r20936 = r20935 * r20927;
        float r20937 = r20933 - r20936;
        float r20938 = sqrt(r20937);
        float r20939 = r20932 - r20938;
        float r20940 = r20930 / r20939;
        float r20941 = r20929 * r20940;
        return r20941;
}

double f_od(double a, double b, double c) {
        double r20942 = 4;
        double r20943 = 2;
        double r20944 = r20942 / r20943;
        double r20945 = c;
        double r20946 = b;
        double r20947 = -r20946;
        double r20948 = r20946 * r20946;
        double r20949 = a;
        double r20950 = r20945 * r20949;
        double r20951 = r20950 * r20942;
        double r20952 = r20948 - r20951;
        double r20953 = sqrt(r20952);
        double r20954 = r20947 - r20953;
        double r20955 = r20945 / r20954;
        double r20956 = r20944 * r20955;
        return r20956;
}

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 r20957, r20958, r20959, r20960, r20961, r20962, r20963, r20964, r20965, r20966, r20967, r20968, r20969, r20970;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(912);
        mpfr_init(r20957);
        mpfr_init(r20958);
        mpfr_init(r20959);
        mpfr_init_set_str(r20960, "4", 10, MPFR_RNDN);
        mpfr_init(r20961);
        mpfr_init(r20962);
        mpfr_init(r20963);
        mpfr_init(r20964);
        mpfr_init(r20965);
        mpfr_init(r20966);
        mpfr_init(r20967);
        mpfr_init_set_str(r20968, "2", 10, MPFR_RNDN);
        mpfr_init(r20969);
        mpfr_init(r20970);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r20957, b, MPFR_RNDN);
        mpfr_neg(r20958, r20957, MPFR_RNDN);
        mpfr_mul(r20959, r20957, r20957, MPFR_RNDN);
        ;
        mpfr_set_d(r20961, a, MPFR_RNDN);
        mpfr_mul(r20962, r20960, r20961, MPFR_RNDN);
        mpfr_set_d(r20963, c, MPFR_RNDN);
        mpfr_mul(r20964, r20962, r20963, MPFR_RNDN);
        mpfr_sub(r20965, r20959, r20964, MPFR_RNDN);
        mpfr_sqrt(r20966, r20965, MPFR_RNDN);
        mpfr_add(r20967, r20958, r20966, MPFR_RNDN);
        ;
        mpfr_mul(r20969, r20968, r20961, MPFR_RNDN);
        mpfr_div(r20970, r20967, r20969, MPFR_RNDN);
        return mpfr_get_d(r20970, MPFR_RNDN);
}

static mpfr_t r20971, r20972, r20973, r20974, r20975, r20976, r20977, r20978, r20979, r20980, r20981, r20982, r20983, r20984, r20985;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(912);
        mpfr_init_set_str(r20971, "4", 10, MPFR_RNDN);
        mpfr_init_set_str(r20972, "2", 10, MPFR_RNDN);
        mpfr_init(r20973);
        mpfr_init(r20974);
        mpfr_init(r20975);
        mpfr_init(r20976);
        mpfr_init(r20977);
        mpfr_init(r20978);
        mpfr_init(r20979);
        mpfr_init(r20980);
        mpfr_init(r20981);
        mpfr_init(r20982);
        mpfr_init(r20983);
        mpfr_init(r20984);
        mpfr_init(r20985);
}

double f_fm(double a, double b, double c) {
        ;
        ;
        mpfr_div(r20973, r20971, r20972, MPFR_RNDN);
        mpfr_set_d(r20974, c, MPFR_RNDN);
        mpfr_set_d(r20975, b, MPFR_RNDN);
        mpfr_neg(r20976, r20975, MPFR_RNDN);
        mpfr_mul(r20977, r20975, r20975, MPFR_RNDN);
        mpfr_set_d(r20978, a, MPFR_RNDN);
        mpfr_mul(r20979, r20974, r20978, MPFR_RNDN);
        mpfr_mul(r20980, r20979, r20971, MPFR_RNDN);
        mpfr_sub(r20981, r20977, r20980, MPFR_RNDN);
        mpfr_sqrt(r20982, r20981, MPFR_RNDN);
        mpfr_sub(r20983, r20976, r20982, MPFR_RNDN);
        mpfr_div(r20984, r20974, r20983, MPFR_RNDN);
        mpfr_mul(r20985, r20973, r20984, MPFR_RNDN);
        return mpfr_get_d(r20985, MPFR_RNDN);
}

static mpfr_t r20986, r20987, r20988, r20989, r20990, r20991, r20992, r20993, r20994, r20995, r20996, r20997, r20998, r20999, r21000;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(912);
        mpfr_init_set_str(r20986, "4", 10, MPFR_RNDN);
        mpfr_init_set_str(r20987, "2", 10, MPFR_RNDN);
        mpfr_init(r20988);
        mpfr_init(r20989);
        mpfr_init(r20990);
        mpfr_init(r20991);
        mpfr_init(r20992);
        mpfr_init(r20993);
        mpfr_init(r20994);
        mpfr_init(r20995);
        mpfr_init(r20996);
        mpfr_init(r20997);
        mpfr_init(r20998);
        mpfr_init(r20999);
        mpfr_init(r21000);
}

double f_dm(double a, double b, double c) {
        ;
        ;
        mpfr_div(r20988, r20986, r20987, MPFR_RNDN);
        mpfr_set_d(r20989, c, MPFR_RNDN);
        mpfr_set_d(r20990, b, MPFR_RNDN);
        mpfr_neg(r20991, r20990, MPFR_RNDN);
        mpfr_mul(r20992, r20990, r20990, MPFR_RNDN);
        mpfr_set_d(r20993, a, MPFR_RNDN);
        mpfr_mul(r20994, r20989, r20993, MPFR_RNDN);
        mpfr_mul(r20995, r20994, r20986, MPFR_RNDN);
        mpfr_sub(r20996, r20992, r20995, MPFR_RNDN);
        mpfr_sqrt(r20997, r20996, MPFR_RNDN);
        mpfr_sub(r20998, r20991, r20997, MPFR_RNDN);
        mpfr_div(r20999, r20989, r20998, MPFR_RNDN);
        mpfr_mul(r21000, r20988, r20999, MPFR_RNDN);
        return mpfr_get_d(r21000, MPFR_RNDN);
}

