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

char *name = "The quadratic formula (r1)";

double f_if(float a, float b, float c) {
        float r17838 = b;
        float r17839 = -r17838;
        float r17840 = r17838 * r17838;
        float r17841 = 4.0f;
        float r17842 = a;
        float r17843 = r17841 * r17842;
        float r17844 = c;
        float r17845 = r17843 * r17844;
        float r17846 = r17840 - r17845;
        float r17847 = sqrt(r17846);
        float r17848 = r17839 + r17847;
        float r17849 = 2.0f;
        float r17850 = r17849 * r17842;
        float r17851 = r17848 / r17850;
        return r17851;
}

double f_id(double a, double b, double c) {
        double r17852 = b;
        double r17853 = -r17852;
        double r17854 = r17852 * r17852;
        double r17855 = 4.0;
        double r17856 = a;
        double r17857 = r17855 * r17856;
        double r17858 = c;
        double r17859 = r17857 * r17858;
        double r17860 = r17854 - r17859;
        double r17861 = sqrt(r17860);
        double r17862 = r17853 + r17861;
        double r17863 = 2.0;
        double r17864 = r17863 * r17856;
        double r17865 = r17862 / r17864;
        return r17865;
}


double f_of(float a, float b, float c) {
        float r17866 = b;
        float r17867 = -71884515311616.0f;
        bool r17868 = r17866 <= r17867;
        float r17869 = c;
        float r17870 = r17869 / r17866;
        float r17871 = a;
        float r17872 = r17866 / r17871;
        float r17873 = r17870 - r17872;
        float r17874 = 3.5037975311279297f;
        bool r17875 = r17866 <= r17874;
        float r17876 = -r17866;
        float r17877 = r17866 * r17866;
        float r17878 = 4.0f;
        float r17879 = r17878 * r17871;
        float r17880 = r17879 * r17869;
        float r17881 = r17877 - r17880;
        float r17882 = sqrt(r17881);
        float r17883 = r17876 + r17882;
        float r17884 = 1.0f;
        float r17885 = 2.0f;
        float r17886 = r17885 * r17871;
        float r17887 = r17884 / r17886;
        float r17888 = r17883 * r17887;
        float r17889 = r17878 / r17885;
        float r17890 = r17889 * r17869;
        float r17891 = r17871 * r17885;
        float r17892 = fma(r17891, r17870, r17876);
        float r17893 = r17892 - r17866;
        float r17894 = r17890 / r17893;
        float r17895 = r17875 ? r17888 : r17894;
        float r17896 = r17868 ? r17873 : r17895;
        return r17896;
}

double f_od(double a, double b, double c) {
        double r17897 = b;
        double r17898 = -71884515311616.0;
        bool r17899 = r17897 <= r17898;
        double r17900 = c;
        double r17901 = r17900 / r17897;
        double r17902 = a;
        double r17903 = r17897 / r17902;
        double r17904 = r17901 - r17903;
        double r17905 = 3.5037975311279297;
        bool r17906 = r17897 <= r17905;
        double r17907 = -r17897;
        double r17908 = r17897 * r17897;
        double r17909 = 4.0;
        double r17910 = r17909 * r17902;
        double r17911 = r17910 * r17900;
        double r17912 = r17908 - r17911;
        double r17913 = sqrt(r17912);
        double r17914 = r17907 + r17913;
        double r17915 = 1.0;
        double r17916 = 2.0;
        double r17917 = r17916 * r17902;
        double r17918 = r17915 / r17917;
        double r17919 = r17914 * r17918;
        double r17920 = r17909 / r17916;
        double r17921 = r17920 * r17900;
        double r17922 = r17902 * r17916;
        double r17923 = fma(r17922, r17901, r17907);
        double r17924 = r17923 - r17897;
        double r17925 = r17921 / r17924;
        double r17926 = r17906 ? r17919 : r17925;
        double r17927 = r17899 ? r17904 : r17926;
        return r17927;
}

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 r17928, r17929, r17930, r17931, r17932, r17933, r17934, r17935, r17936, r17937, r17938, r17939, r17940, r17941;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init(r17928);
        mpfr_init(r17929);
        mpfr_init(r17930);
        mpfr_init_set_str(r17931, "4", 10, MPFR_RNDN);
        mpfr_init(r17932);
        mpfr_init(r17933);
        mpfr_init(r17934);
        mpfr_init(r17935);
        mpfr_init(r17936);
        mpfr_init(r17937);
        mpfr_init(r17938);
        mpfr_init_set_str(r17939, "2", 10, MPFR_RNDN);
        mpfr_init(r17940);
        mpfr_init(r17941);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r17928, b, MPFR_RNDN);
        mpfr_neg(r17929, r17928, MPFR_RNDN);
        mpfr_sqr(r17930, r17928, MPFR_RNDN);
        ;
        mpfr_set_d(r17932, a, MPFR_RNDN);
        mpfr_mul(r17933, r17931, r17932, MPFR_RNDN);
        mpfr_set_d(r17934, c, MPFR_RNDN);
        mpfr_mul(r17935, r17933, r17934, MPFR_RNDN);
        mpfr_sub(r17936, r17930, r17935, MPFR_RNDN);
        mpfr_sqrt(r17937, r17936, MPFR_RNDN);
        mpfr_add(r17938, r17929, r17937, MPFR_RNDN);
        ;
        mpfr_mul(r17940, r17939, r17932, MPFR_RNDN);
        mpfr_div(r17941, r17938, r17940, MPFR_RNDN);
        return mpfr_get_d(r17941, MPFR_RNDN);
}

static mpfr_t r17942, r17943, r17944, r17945, r17946, r17947, r17948, r17949, r17950, r17951, r17952, r17953, r17954, r17955, r17956, r17957, r17958, r17959, r17960, r17961, r17962, r17963, r17964, r17965, r17966, r17967, r17968, r17969, r17970, r17971, r17972;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17942);
        mpfr_init_set_str(r17943, "-7.1884515f+13", 10, MPFR_RNDN);
        mpfr_init(r17944);
        mpfr_init(r17945);
        mpfr_init(r17946);
        mpfr_init(r17947);
        mpfr_init(r17948);
        mpfr_init(r17949);
        mpfr_init_set_str(r17950, "3.5037975f0", 10, MPFR_RNDN);
        mpfr_init(r17951);
        mpfr_init(r17952);
        mpfr_init(r17953);
        mpfr_init_set_str(r17954, "4", 10, MPFR_RNDN);
        mpfr_init(r17955);
        mpfr_init(r17956);
        mpfr_init(r17957);
        mpfr_init(r17958);
        mpfr_init(r17959);
        mpfr_init_set_str(r17960, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r17961, "2", 10, MPFR_RNDN);
        mpfr_init(r17962);
        mpfr_init(r17963);
        mpfr_init(r17964);
        mpfr_init(r17965);
        mpfr_init(r17966);
        mpfr_init(r17967);
        mpfr_init(r17968);
        mpfr_init(r17969);
        mpfr_init(r17970);
        mpfr_init(r17971);
        mpfr_init(r17972);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r17942, b, MPFR_RNDN);
        ;
        mpfr_set_si(r17944, mpfr_cmp(r17942, r17943) <= 0, MPFR_RNDN);
        mpfr_set_d(r17945, c, MPFR_RNDN);
        mpfr_div(r17946, r17945, r17942, MPFR_RNDN);
        mpfr_set_d(r17947, a, MPFR_RNDN);
        mpfr_div(r17948, r17942, r17947, MPFR_RNDN);
        mpfr_sub(r17949, r17946, r17948, MPFR_RNDN);
        ;
        mpfr_set_si(r17951, mpfr_cmp(r17942, r17950) <= 0, MPFR_RNDN);
        mpfr_neg(r17952, r17942, MPFR_RNDN);
        mpfr_sqr(r17953, r17942, MPFR_RNDN);
        ;
        mpfr_mul(r17955, r17954, r17947, MPFR_RNDN);
        mpfr_mul(r17956, r17955, r17945, MPFR_RNDN);
        mpfr_sub(r17957, r17953, r17956, MPFR_RNDN);
        mpfr_sqrt(r17958, r17957, MPFR_RNDN);
        mpfr_add(r17959, r17952, r17958, MPFR_RNDN);
        ;
        ;
        mpfr_mul(r17962, r17961, r17947, MPFR_RNDN);
        mpfr_div(r17963, r17960, r17962, MPFR_RNDN);
        mpfr_mul(r17964, r17959, r17963, MPFR_RNDN);
        mpfr_div(r17965, r17954, r17961, MPFR_RNDN);
        mpfr_mul(r17966, r17965, r17945, MPFR_RNDN);
        mpfr_mul(r17967, r17947, r17961, MPFR_RNDN);
        mpfr_fma(r17968, r17967, r17946, r17952, MPFR_RNDN);
        mpfr_sub(r17969, r17968, r17942, MPFR_RNDN);
        mpfr_div(r17970, r17966, r17969, MPFR_RNDN);
        if (mpfr_get_si(r17951, MPFR_RNDN)) { mpfr_set(r17971, r17964, MPFR_RNDN); } else { mpfr_set(r17971, r17970, MPFR_RNDN); };
        if (mpfr_get_si(r17944, MPFR_RNDN)) { mpfr_set(r17972, r17949, MPFR_RNDN); } else { mpfr_set(r17972, r17971, MPFR_RNDN); };
        return mpfr_get_d(r17972, MPFR_RNDN);
}

static mpfr_t r17973, r17974, r17975, r17976, r17977, r17978, r17979, r17980, r17981, r17982, r17983, r17984, r17985, r17986, r17987, r17988, r17989, r17990, r17991, r17992, r17993, r17994, r17995, r17996, r17997, r17998, r17999, r18000, r18001, r18002, r18003;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17973);
        mpfr_init_set_str(r17974, "-7.1884515f+13", 10, MPFR_RNDN);
        mpfr_init(r17975);
        mpfr_init(r17976);
        mpfr_init(r17977);
        mpfr_init(r17978);
        mpfr_init(r17979);
        mpfr_init(r17980);
        mpfr_init_set_str(r17981, "3.5037975f0", 10, MPFR_RNDN);
        mpfr_init(r17982);
        mpfr_init(r17983);
        mpfr_init(r17984);
        mpfr_init_set_str(r17985, "4", 10, MPFR_RNDN);
        mpfr_init(r17986);
        mpfr_init(r17987);
        mpfr_init(r17988);
        mpfr_init(r17989);
        mpfr_init(r17990);
        mpfr_init_set_str(r17991, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r17992, "2", 10, MPFR_RNDN);
        mpfr_init(r17993);
        mpfr_init(r17994);
        mpfr_init(r17995);
        mpfr_init(r17996);
        mpfr_init(r17997);
        mpfr_init(r17998);
        mpfr_init(r17999);
        mpfr_init(r18000);
        mpfr_init(r18001);
        mpfr_init(r18002);
        mpfr_init(r18003);
}

double f_dm(double a, double b, double c) {
        mpfr_set_d(r17973, b, MPFR_RNDN);
        ;
        mpfr_set_si(r17975, mpfr_cmp(r17973, r17974) <= 0, MPFR_RNDN);
        mpfr_set_d(r17976, c, MPFR_RNDN);
        mpfr_div(r17977, r17976, r17973, MPFR_RNDN);
        mpfr_set_d(r17978, a, MPFR_RNDN);
        mpfr_div(r17979, r17973, r17978, MPFR_RNDN);
        mpfr_sub(r17980, r17977, r17979, MPFR_RNDN);
        ;
        mpfr_set_si(r17982, mpfr_cmp(r17973, r17981) <= 0, MPFR_RNDN);
        mpfr_neg(r17983, r17973, MPFR_RNDN);
        mpfr_sqr(r17984, r17973, MPFR_RNDN);
        ;
        mpfr_mul(r17986, r17985, r17978, MPFR_RNDN);
        mpfr_mul(r17987, r17986, r17976, MPFR_RNDN);
        mpfr_sub(r17988, r17984, r17987, MPFR_RNDN);
        mpfr_sqrt(r17989, r17988, MPFR_RNDN);
        mpfr_add(r17990, r17983, r17989, MPFR_RNDN);
        ;
        ;
        mpfr_mul(r17993, r17992, r17978, MPFR_RNDN);
        mpfr_div(r17994, r17991, r17993, MPFR_RNDN);
        mpfr_mul(r17995, r17990, r17994, MPFR_RNDN);
        mpfr_div(r17996, r17985, r17992, MPFR_RNDN);
        mpfr_mul(r17997, r17996, r17976, MPFR_RNDN);
        mpfr_mul(r17998, r17978, r17992, MPFR_RNDN);
        mpfr_fma(r17999, r17998, r17977, r17983, MPFR_RNDN);
        mpfr_sub(r18000, r17999, r17973, MPFR_RNDN);
        mpfr_div(r18001, r17997, r18000, MPFR_RNDN);
        if (mpfr_get_si(r17982, MPFR_RNDN)) { mpfr_set(r18002, r17995, MPFR_RNDN); } else { mpfr_set(r18002, r18001, MPFR_RNDN); };
        if (mpfr_get_si(r17975, MPFR_RNDN)) { mpfr_set(r18003, r17980, MPFR_RNDN); } else { mpfr_set(r18003, r18002, MPFR_RNDN); };
        return mpfr_get_d(r18003, MPFR_RNDN);
}

