#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 r25411 = b;
        float r25412 = -r25411;
        float r25413 = r25411 * r25411;
        float r25414 = 4;
        float r25415 = a;
        float r25416 = r25414 * r25415;
        float r25417 = c;
        float r25418 = r25416 * r25417;
        float r25419 = r25413 - r25418;
        float r25420 = sqrt(r25419);
        float r25421 = r25412 + r25420;
        float r25422 = 2;
        float r25423 = r25422 * r25415;
        float r25424 = r25421 / r25423;
        return r25424;
}

double f_id(double a, double b, double c) {
        double r25425 = b;
        double r25426 = -r25425;
        double r25427 = r25425 * r25425;
        double r25428 = 4;
        double r25429 = a;
        double r25430 = r25428 * r25429;
        double r25431 = c;
        double r25432 = r25430 * r25431;
        double r25433 = r25427 - r25432;
        double r25434 = sqrt(r25433);
        double r25435 = r25426 + r25434;
        double r25436 = 2;
        double r25437 = r25436 * r25429;
        double r25438 = r25435 / r25437;
        return r25438;
}


double f_of(float a, float b, float c) {
        float r25439 = b;
        float r25440 = -1.3628056667376623e+154;
        bool r25441 = r25439 <= r25440;
        float r25442 = c;
        float r25443 = r25442 / r25439;
        float r25444 = 1;
        float r25445 = r25443 / r25444;
        float r25446 = r25439 + r25439;
        float r25447 = 2;
        float r25448 = a;
        float r25449 = r25447 * r25448;
        float r25450 = r25446 / r25449;
        float r25451 = r25445 - r25450;
        float r25452 = 4.284496431235526e-145;
        bool r25453 = r25439 <= r25452;
        float r25454 = -r25439;
        float r25455 = r25439 * r25439;
        float r25456 = 4;
        float r25457 = r25456 * r25448;
        float r25458 = r25442 * r25457;
        float r25459 = r25455 - r25458;
        float r25460 = sqrt(r25459);
        float r25461 = r25454 + r25460;
        float r25462 = r25461 / r25449;
        float r25463 = 6.619815002390032e+34;
        bool r25464 = r25439 <= r25463;
        float r25465 = r25454 - r25460;
        float r25466 = r25458 / r25465;
        float r25467 = r25466 / r25449;
        float r25468 = -r25442;
        float r25469 = r25468 / r25439;
        float r25470 = r25464 ? r25467 : r25469;
        float r25471 = r25453 ? r25462 : r25470;
        float r25472 = r25441 ? r25451 : r25471;
        return r25472;
}

double f_od(double a, double b, double c) {
        double r25473 = b;
        double r25474 = -1.3628056667376623e+154;
        bool r25475 = r25473 <= r25474;
        double r25476 = c;
        double r25477 = r25476 / r25473;
        double r25478 = 1;
        double r25479 = r25477 / r25478;
        double r25480 = r25473 + r25473;
        double r25481 = 2;
        double r25482 = a;
        double r25483 = r25481 * r25482;
        double r25484 = r25480 / r25483;
        double r25485 = r25479 - r25484;
        double r25486 = 4.284496431235526e-145;
        bool r25487 = r25473 <= r25486;
        double r25488 = -r25473;
        double r25489 = r25473 * r25473;
        double r25490 = 4;
        double r25491 = r25490 * r25482;
        double r25492 = r25476 * r25491;
        double r25493 = r25489 - r25492;
        double r25494 = sqrt(r25493);
        double r25495 = r25488 + r25494;
        double r25496 = r25495 / r25483;
        double r25497 = 6.619815002390032e+34;
        bool r25498 = r25473 <= r25497;
        double r25499 = r25488 - r25494;
        double r25500 = r25492 / r25499;
        double r25501 = r25500 / r25483;
        double r25502 = -r25476;
        double r25503 = r25502 / r25473;
        double r25504 = r25498 ? r25501 : r25503;
        double r25505 = r25487 ? r25496 : r25504;
        double r25506 = r25475 ? r25485 : r25505;
        return r25506;
}

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 r25507, r25508, r25509, r25510, r25511, r25512, r25513, r25514, r25515, r25516, r25517, r25518, r25519, r25520;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init(r25509);
        mpfr_init_set_str(r25510, "4", 10, MPFR_RNDN);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
        mpfr_init(r25516);
        mpfr_init(r25517);
        mpfr_init_set_str(r25518, "2", 10, MPFR_RNDN);
        mpfr_init(r25519);
        mpfr_init(r25520);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25507, b, MPFR_RNDN);
        mpfr_neg(r25508, r25507, MPFR_RNDN);
        mpfr_mul(r25509, r25507, r25507, MPFR_RNDN);
        ;
        mpfr_set_d(r25511, a, MPFR_RNDN);
        mpfr_mul(r25512, r25510, r25511, MPFR_RNDN);
        mpfr_set_d(r25513, c, MPFR_RNDN);
        mpfr_mul(r25514, r25512, r25513, MPFR_RNDN);
        mpfr_sub(r25515, r25509, r25514, MPFR_RNDN);
        mpfr_sqrt(r25516, r25515, MPFR_RNDN);
        mpfr_add(r25517, r25508, r25516, MPFR_RNDN);
        ;
        mpfr_mul(r25519, r25518, r25511, MPFR_RNDN);
        mpfr_div(r25520, r25517, r25519, MPFR_RNDN);
        return mpfr_get_d(r25520, MPFR_RNDN);
}

static mpfr_t r25521, r25522, r25523, r25524, r25525, r25526, r25527, r25528, r25529, r25530, r25531, r25532, r25533, r25534, r25535, r25536, r25537, r25538, r25539, r25540, r25541, r25542, r25543, r25544, r25545, r25546, r25547, r25548, r25549, r25550, r25551, r25552, r25553, r25554;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25521);
        mpfr_init_set_str(r25522, "-1.3628056667376623e+154", 10, MPFR_RNDN);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init_set_str(r25526, "1", 10, MPFR_RNDN);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init_set_str(r25529, "2", 10, MPFR_RNDN);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init_set_str(r25534, "4.284496431235526e-145", 10, MPFR_RNDN);
        mpfr_init(r25535);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init_set_str(r25538, "4", 10, MPFR_RNDN);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init_set_str(r25545, "6.619815002390032e+34", 10, MPFR_RNDN);
        mpfr_init(r25546);
        mpfr_init(r25547);
        mpfr_init(r25548);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
        mpfr_init(r25552);
        mpfr_init(r25553);
        mpfr_init(r25554);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r25521, b, MPFR_RNDN);
        ;
        mpfr_set_si(r25523, mpfr_cmp(r25521, r25522) <= 0, MPFR_RNDN);
        mpfr_set_d(r25524, c, MPFR_RNDN);
        mpfr_div(r25525, r25524, r25521, MPFR_RNDN);
        ;
        mpfr_div(r25527, r25525, r25526, MPFR_RNDN);
        mpfr_add(r25528, r25521, r25521, MPFR_RNDN);
        ;
        mpfr_set_d(r25530, a, MPFR_RNDN);
        mpfr_mul(r25531, r25529, r25530, MPFR_RNDN);
        mpfr_div(r25532, r25528, r25531, MPFR_RNDN);
        mpfr_sub(r25533, r25527, r25532, MPFR_RNDN);
        ;
        mpfr_set_si(r25535, mpfr_cmp(r25521, r25534) <= 0, MPFR_RNDN);
        mpfr_neg(r25536, r25521, MPFR_RNDN);
        mpfr_mul(r25537, r25521, r25521, MPFR_RNDN);
        ;
        mpfr_mul(r25539, r25538, r25530, MPFR_RNDN);
        mpfr_mul(r25540, r25524, r25539, MPFR_RNDN);
        mpfr_sub(r25541, r25537, r25540, MPFR_RNDN);
        mpfr_sqrt(r25542, r25541, MPFR_RNDN);
        mpfr_add(r25543, r25536, r25542, MPFR_RNDN);
        mpfr_div(r25544, r25543, r25531, MPFR_RNDN);
        ;
        mpfr_set_si(r25546, mpfr_cmp(r25521, r25545) <= 0, MPFR_RNDN);
        mpfr_sub(r25547, r25536, r25542, MPFR_RNDN);
        mpfr_div(r25548, r25540, r25547, MPFR_RNDN);
        mpfr_div(r25549, r25548, r25531, MPFR_RNDN);
        mpfr_neg(r25550, r25524, MPFR_RNDN);
        mpfr_div(r25551, r25550, r25521, MPFR_RNDN);
        if (mpfr_get_si(r25546, MPFR_RNDN)) { mpfr_set(r25552, r25549, MPFR_RNDN); } else { mpfr_set(r25552, r25551, MPFR_RNDN); };
        if (mpfr_get_si(r25535, MPFR_RNDN)) { mpfr_set(r25553, r25544, MPFR_RNDN); } else { mpfr_set(r25553, r25552, MPFR_RNDN); };
        if (mpfr_get_si(r25523, MPFR_RNDN)) { mpfr_set(r25554, r25533, MPFR_RNDN); } else { mpfr_set(r25554, r25553, MPFR_RNDN); };
        return mpfr_get_d(r25554, MPFR_RNDN);
}

static mpfr_t r25555, r25556, r25557, r25558, r25559, r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568, r25569, r25570, r25571, r25572, r25573, r25574, r25575, r25576, r25577, r25578, r25579, r25580, r25581, r25582, r25583, r25584, r25585, r25586, r25587, r25588;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25555);
        mpfr_init_set_str(r25556, "-1.3628056667376623e+154", 10, MPFR_RNDN);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
        mpfr_init_set_str(r25560, "1", 10, MPFR_RNDN);
        mpfr_init(r25561);
        mpfr_init(r25562);
        mpfr_init_set_str(r25563, "2", 10, MPFR_RNDN);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init(r25567);
        mpfr_init_set_str(r25568, "4.284496431235526e-145", 10, MPFR_RNDN);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init(r25571);
        mpfr_init_set_str(r25572, "4", 10, MPFR_RNDN);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init(r25576);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init_set_str(r25579, "6.619815002390032e+34", 10, MPFR_RNDN);
        mpfr_init(r25580);
        mpfr_init(r25581);
        mpfr_init(r25582);
        mpfr_init(r25583);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init(r25586);
        mpfr_init(r25587);
        mpfr_init(r25588);
}

double f_dm(double a, double b, double c) {
        mpfr_set_d(r25555, b, MPFR_RNDN);
        ;
        mpfr_set_si(r25557, mpfr_cmp(r25555, r25556) <= 0, MPFR_RNDN);
        mpfr_set_d(r25558, c, MPFR_RNDN);
        mpfr_div(r25559, r25558, r25555, MPFR_RNDN);
        ;
        mpfr_div(r25561, r25559, r25560, MPFR_RNDN);
        mpfr_add(r25562, r25555, r25555, MPFR_RNDN);
        ;
        mpfr_set_d(r25564, a, MPFR_RNDN);
        mpfr_mul(r25565, r25563, r25564, MPFR_RNDN);
        mpfr_div(r25566, r25562, r25565, MPFR_RNDN);
        mpfr_sub(r25567, r25561, r25566, MPFR_RNDN);
        ;
        mpfr_set_si(r25569, mpfr_cmp(r25555, r25568) <= 0, MPFR_RNDN);
        mpfr_neg(r25570, r25555, MPFR_RNDN);
        mpfr_mul(r25571, r25555, r25555, MPFR_RNDN);
        ;
        mpfr_mul(r25573, r25572, r25564, MPFR_RNDN);
        mpfr_mul(r25574, r25558, r25573, MPFR_RNDN);
        mpfr_sub(r25575, r25571, r25574, MPFR_RNDN);
        mpfr_sqrt(r25576, r25575, MPFR_RNDN);
        mpfr_add(r25577, r25570, r25576, MPFR_RNDN);
        mpfr_div(r25578, r25577, r25565, MPFR_RNDN);
        ;
        mpfr_set_si(r25580, mpfr_cmp(r25555, r25579) <= 0, MPFR_RNDN);
        mpfr_sub(r25581, r25570, r25576, MPFR_RNDN);
        mpfr_div(r25582, r25574, r25581, MPFR_RNDN);
        mpfr_div(r25583, r25582, r25565, MPFR_RNDN);
        mpfr_neg(r25584, r25558, MPFR_RNDN);
        mpfr_div(r25585, r25584, r25555, MPFR_RNDN);
        if (mpfr_get_si(r25580, MPFR_RNDN)) { mpfr_set(r25586, r25583, MPFR_RNDN); } else { mpfr_set(r25586, r25585, MPFR_RNDN); };
        if (mpfr_get_si(r25569, MPFR_RNDN)) { mpfr_set(r25587, r25578, MPFR_RNDN); } else { mpfr_set(r25587, r25586, MPFR_RNDN); };
        if (mpfr_get_si(r25557, MPFR_RNDN)) { mpfr_set(r25588, r25567, MPFR_RNDN); } else { mpfr_set(r25588, r25587, MPFR_RNDN); };
        return mpfr_get_d(r25588, MPFR_RNDN);
}

