#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 r25292 = b;
        float r25293 = -r25292;
        float r25294 = r25292 * r25292;
        float r25295 = 4;
        float r25296 = a;
        float r25297 = r25295 * r25296;
        float r25298 = c;
        float r25299 = r25297 * r25298;
        float r25300 = r25294 - r25299;
        float r25301 = sqrt(r25300);
        float r25302 = r25293 + r25301;
        float r25303 = 2;
        float r25304 = r25303 * r25296;
        float r25305 = r25302 / r25304;
        return r25305;
}

double f_id(double a, double b, double c) {
        double r25306 = b;
        double r25307 = -r25306;
        double r25308 = r25306 * r25306;
        double r25309 = 4;
        double r25310 = a;
        double r25311 = r25309 * r25310;
        double r25312 = c;
        double r25313 = r25311 * r25312;
        double r25314 = r25308 - r25313;
        double r25315 = sqrt(r25314);
        double r25316 = r25307 + r25315;
        double r25317 = 2;
        double r25318 = r25317 * r25310;
        double r25319 = r25316 / r25318;
        return r25319;
}


double f_of(float a, float b, float c) {
        float r25320 = b;
        float r25321 = 4.54571802761373e-290;
        bool r25322 = r25320 <= r25321;
        float r25323 = 4;
        float r25324 = a;
        float r25325 = r25323 * r25324;
        float r25326 = c;
        float r25327 = -r25326;
        float r25328 = r25320 * r25320;
        float r25329 = fma(r25325, r25327, r25328);
        float r25330 = sqrt(r25329);
        float r25331 = 2;
        float r25332 = r25331 * r25324;
        float r25333 = r25330 / r25332;
        float r25334 = r25320 / r25332;
        float r25335 = r25333 - r25334;
        float r25336 = 5.345900402976386e+129;
        bool r25337 = r25320 <= r25336;
        float r25338 = r25323 * r25327;
        float r25339 = 1;
        float r25340 = r25339 / r25331;
        float r25341 = r25338 * r25340;
        float r25342 = fma(r25327, r25325, r25328);
        float r25343 = sqrt(r25342);
        float r25344 = r25343 + r25320;
        float r25345 = r25341 / r25344;
        float r25346 = cbrt(r25345);
        float r25347 = r25346 * r25346;
        float r25348 = r25347 * r25346;
        float r25349 = r25326 * r25324;
        float r25350 = -r25323;
        float r25351 = r25349 * r25350;
        float r25352 = r25320 + r25320;
        float r25353 = r25351 / r25352;
        float r25354 = r25353 / r25332;
        float r25355 = r25337 ? r25348 : r25354;
        float r25356 = r25322 ? r25335 : r25355;
        return r25356;
}

double f_od(double a, double b, double c) {
        double r25357 = b;
        double r25358 = 4.54571802761373e-290;
        bool r25359 = r25357 <= r25358;
        double r25360 = 4;
        double r25361 = a;
        double r25362 = r25360 * r25361;
        double r25363 = c;
        double r25364 = -r25363;
        double r25365 = r25357 * r25357;
        double r25366 = fma(r25362, r25364, r25365);
        double r25367 = sqrt(r25366);
        double r25368 = 2;
        double r25369 = r25368 * r25361;
        double r25370 = r25367 / r25369;
        double r25371 = r25357 / r25369;
        double r25372 = r25370 - r25371;
        double r25373 = 5.345900402976386e+129;
        bool r25374 = r25357 <= r25373;
        double r25375 = r25360 * r25364;
        double r25376 = 1;
        double r25377 = r25376 / r25368;
        double r25378 = r25375 * r25377;
        double r25379 = fma(r25364, r25362, r25365);
        double r25380 = sqrt(r25379);
        double r25381 = r25380 + r25357;
        double r25382 = r25378 / r25381;
        double r25383 = cbrt(r25382);
        double r25384 = r25383 * r25383;
        double r25385 = r25384 * r25383;
        double r25386 = r25363 * r25361;
        double r25387 = -r25360;
        double r25388 = r25386 * r25387;
        double r25389 = r25357 + r25357;
        double r25390 = r25388 / r25389;
        double r25391 = r25390 / r25369;
        double r25392 = r25374 ? r25385 : r25391;
        double r25393 = r25359 ? r25372 : r25392;
        return r25393;
}

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 r25394, r25395, r25396, r25397, r25398, r25399, r25400, r25401, r25402, r25403, r25404, r25405, r25406, r25407;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25394);
        mpfr_init(r25395);
        mpfr_init(r25396);
        mpfr_init_set_str(r25397, "4", 10, MPFR_RNDN);
        mpfr_init(r25398);
        mpfr_init(r25399);
        mpfr_init(r25400);
        mpfr_init(r25401);
        mpfr_init(r25402);
        mpfr_init(r25403);
        mpfr_init(r25404);
        mpfr_init_set_str(r25405, "2", 10, MPFR_RNDN);
        mpfr_init(r25406);
        mpfr_init(r25407);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25394, b, MPFR_RNDN);
        mpfr_neg(r25395, r25394, MPFR_RNDN);
        mpfr_mul(r25396, r25394, r25394, MPFR_RNDN);
        ;
        mpfr_set_d(r25398, a, MPFR_RNDN);
        mpfr_mul(r25399, r25397, r25398, MPFR_RNDN);
        mpfr_set_d(r25400, c, MPFR_RNDN);
        mpfr_mul(r25401, r25399, r25400, MPFR_RNDN);
        mpfr_sub(r25402, r25396, r25401, MPFR_RNDN);
        mpfr_sqrt(r25403, r25402, MPFR_RNDN);
        mpfr_add(r25404, r25395, r25403, MPFR_RNDN);
        ;
        mpfr_mul(r25406, r25405, r25398, MPFR_RNDN);
        mpfr_div(r25407, r25404, r25406, MPFR_RNDN);
        return mpfr_get_d(r25407, MPFR_RNDN);
}

static mpfr_t r25408, r25409, r25410, r25411, r25412, r25413, r25414, r25415, r25416, r25417, r25418, r25419, r25420, r25421, r25422, r25423, r25424, r25425, r25426, r25427, r25428, r25429, r25430, r25431, r25432, r25433, r25434, r25435, r25436, r25437, r25438, r25439, r25440, r25441, r25442, r25443, r25444;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25408);
        mpfr_init_set_str(r25409, "4.54571802761373e-290", 10, MPFR_RNDN);
        mpfr_init(r25410);
        mpfr_init_set_str(r25411, "4", 10, MPFR_RNDN);
        mpfr_init(r25412);
        mpfr_init(r25413);
        mpfr_init(r25414);
        mpfr_init(r25415);
        mpfr_init(r25416);
        mpfr_init(r25417);
        mpfr_init(r25418);
        mpfr_init_set_str(r25419, "2", 10, MPFR_RNDN);
        mpfr_init(r25420);
        mpfr_init(r25421);
        mpfr_init(r25422);
        mpfr_init(r25423);
        mpfr_init_set_str(r25424, "5.345900402976386e+129", 10, MPFR_RNDN);
        mpfr_init(r25425);
        mpfr_init(r25426);
        mpfr_init_set_str(r25427, "1", 10, MPFR_RNDN);
        mpfr_init(r25428);
        mpfr_init(r25429);
        mpfr_init(r25430);
        mpfr_init(r25431);
        mpfr_init(r25432);
        mpfr_init(r25433);
        mpfr_init(r25434);
        mpfr_init(r25435);
        mpfr_init(r25436);
        mpfr_init(r25437);
        mpfr_init(r25438);
        mpfr_init(r25439);
        mpfr_init(r25440);
        mpfr_init(r25441);
        mpfr_init(r25442);
        mpfr_init(r25443);
        mpfr_init(r25444);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r25408, b, MPFR_RNDN);
        ;
        mpfr_set_si(r25410, mpfr_cmp(r25408, r25409) <= 0, MPFR_RNDN);
        ;
        mpfr_set_d(r25412, a, MPFR_RNDN);
        mpfr_mul(r25413, r25411, r25412, MPFR_RNDN);
        mpfr_set_d(r25414, c, MPFR_RNDN);
        mpfr_neg(r25415, r25414, MPFR_RNDN);
        mpfr_mul(r25416, r25408, r25408, MPFR_RNDN);
        mpfr_fma(r25417, r25413, r25415, r25416, MPFR_RNDN);
        mpfr_sqrt(r25418, r25417, MPFR_RNDN);
        ;
        mpfr_mul(r25420, r25419, r25412, MPFR_RNDN);
        mpfr_div(r25421, r25418, r25420, MPFR_RNDN);
        mpfr_div(r25422, r25408, r25420, MPFR_RNDN);
        mpfr_sub(r25423, r25421, r25422, MPFR_RNDN);
        ;
        mpfr_set_si(r25425, mpfr_cmp(r25408, r25424) <= 0, MPFR_RNDN);
        mpfr_mul(r25426, r25411, r25415, MPFR_RNDN);
        ;
        mpfr_div(r25428, r25427, r25419, MPFR_RNDN);
        mpfr_mul(r25429, r25426, r25428, MPFR_RNDN);
        mpfr_fma(r25430, r25415, r25413, r25416, MPFR_RNDN);
        mpfr_sqrt(r25431, r25430, MPFR_RNDN);
        mpfr_add(r25432, r25431, r25408, MPFR_RNDN);
        mpfr_div(r25433, r25429, r25432, MPFR_RNDN);
        mpfr_cbrt(r25434, r25433, MPFR_RNDN);
        mpfr_mul(r25435, r25434, r25434, MPFR_RNDN);
        mpfr_mul(r25436, r25435, r25434, MPFR_RNDN);
        mpfr_mul(r25437, r25414, r25412, MPFR_RNDN);
        mpfr_neg(r25438, r25411, MPFR_RNDN);
        mpfr_mul(r25439, r25437, r25438, MPFR_RNDN);
        mpfr_add(r25440, r25408, r25408, MPFR_RNDN);
        mpfr_div(r25441, r25439, r25440, MPFR_RNDN);
        mpfr_div(r25442, r25441, r25420, MPFR_RNDN);
        if (mpfr_get_si(r25425, MPFR_RNDN)) { mpfr_set(r25443, r25436, MPFR_RNDN); } else { mpfr_set(r25443, r25442, MPFR_RNDN); };
        if (mpfr_get_si(r25410, MPFR_RNDN)) { mpfr_set(r25444, r25423, MPFR_RNDN); } else { mpfr_set(r25444, r25443, MPFR_RNDN); };
        return mpfr_get_d(r25444, MPFR_RNDN);
}

static mpfr_t r25445, r25446, r25447, r25448, r25449, r25450, r25451, r25452, r25453, r25454, r25455, r25456, r25457, r25458, r25459, r25460, r25461, r25462, r25463, r25464, r25465, r25466, r25467, r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25445);
        mpfr_init_set_str(r25446, "4.54571802761373e-290", 10, MPFR_RNDN);
        mpfr_init(r25447);
        mpfr_init_set_str(r25448, "4", 10, MPFR_RNDN);
        mpfr_init(r25449);
        mpfr_init(r25450);
        mpfr_init(r25451);
        mpfr_init(r25452);
        mpfr_init(r25453);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init_set_str(r25456, "2", 10, MPFR_RNDN);
        mpfr_init(r25457);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init(r25460);
        mpfr_init_set_str(r25461, "5.345900402976386e+129", 10, MPFR_RNDN);
        mpfr_init(r25462);
        mpfr_init(r25463);
        mpfr_init_set_str(r25464, "1", 10, MPFR_RNDN);
        mpfr_init(r25465);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init(r25469);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init(r25477);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init(r25481);
}

double f_dm(double a, double b, double c) {
        mpfr_set_d(r25445, b, MPFR_RNDN);
        ;
        mpfr_set_si(r25447, mpfr_cmp(r25445, r25446) <= 0, MPFR_RNDN);
        ;
        mpfr_set_d(r25449, a, MPFR_RNDN);
        mpfr_mul(r25450, r25448, r25449, MPFR_RNDN);
        mpfr_set_d(r25451, c, MPFR_RNDN);
        mpfr_neg(r25452, r25451, MPFR_RNDN);
        mpfr_mul(r25453, r25445, r25445, MPFR_RNDN);
        mpfr_fma(r25454, r25450, r25452, r25453, MPFR_RNDN);
        mpfr_sqrt(r25455, r25454, MPFR_RNDN);
        ;
        mpfr_mul(r25457, r25456, r25449, MPFR_RNDN);
        mpfr_div(r25458, r25455, r25457, MPFR_RNDN);
        mpfr_div(r25459, r25445, r25457, MPFR_RNDN);
        mpfr_sub(r25460, r25458, r25459, MPFR_RNDN);
        ;
        mpfr_set_si(r25462, mpfr_cmp(r25445, r25461) <= 0, MPFR_RNDN);
        mpfr_mul(r25463, r25448, r25452, MPFR_RNDN);
        ;
        mpfr_div(r25465, r25464, r25456, MPFR_RNDN);
        mpfr_mul(r25466, r25463, r25465, MPFR_RNDN);
        mpfr_fma(r25467, r25452, r25450, r25453, MPFR_RNDN);
        mpfr_sqrt(r25468, r25467, MPFR_RNDN);
        mpfr_add(r25469, r25468, r25445, MPFR_RNDN);
        mpfr_div(r25470, r25466, r25469, MPFR_RNDN);
        mpfr_cbrt(r25471, r25470, MPFR_RNDN);
        mpfr_mul(r25472, r25471, r25471, MPFR_RNDN);
        mpfr_mul(r25473, r25472, r25471, MPFR_RNDN);
        mpfr_mul(r25474, r25451, r25449, MPFR_RNDN);
        mpfr_neg(r25475, r25448, MPFR_RNDN);
        mpfr_mul(r25476, r25474, r25475, MPFR_RNDN);
        mpfr_add(r25477, r25445, r25445, MPFR_RNDN);
        mpfr_div(r25478, r25476, r25477, MPFR_RNDN);
        mpfr_div(r25479, r25478, r25457, MPFR_RNDN);
        if (mpfr_get_si(r25462, MPFR_RNDN)) { mpfr_set(r25480, r25473, MPFR_RNDN); } else { mpfr_set(r25480, r25479, MPFR_RNDN); };
        if (mpfr_get_si(r25447, MPFR_RNDN)) { mpfr_set(r25481, r25460, MPFR_RNDN); } else { mpfr_set(r25481, r25480, MPFR_RNDN); };
        return mpfr_get_d(r25481, MPFR_RNDN);
}

