#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 r25395 = b;
        float r25396 = -r25395;
        float r25397 = r25395 * r25395;
        float r25398 = 4;
        float r25399 = a;
        float r25400 = r25398 * r25399;
        float r25401 = c;
        float r25402 = r25400 * r25401;
        float r25403 = r25397 - r25402;
        float r25404 = sqrt(r25403);
        float r25405 = r25396 + r25404;
        float r25406 = 2;
        float r25407 = r25406 * r25399;
        float r25408 = r25405 / r25407;
        return r25408;
}

double f_id(double a, double b, double c) {
        double r25409 = b;
        double r25410 = -r25409;
        double r25411 = r25409 * r25409;
        double r25412 = 4;
        double r25413 = a;
        double r25414 = r25412 * r25413;
        double r25415 = c;
        double r25416 = r25414 * r25415;
        double r25417 = r25411 - r25416;
        double r25418 = sqrt(r25417);
        double r25419 = r25410 + r25418;
        double r25420 = 2;
        double r25421 = r25420 * r25413;
        double r25422 = r25419 / r25421;
        return r25422;
}


double f_of(float a, float b, float c) {
        float r25423 = 4;
        float r25424 = a;
        float r25425 = r25423 * r25424;
        float r25426 = c;
        float r25427 = -r25426;
        float r25428 = b;
        float r25429 = r25428 * r25428;
        float r25430 = fma(r25425, r25427, r25429);
        float r25431 = sqrt(r25430);
        float r25432 = r25431 - r25428;
        float r25433 = sqrt(r25432);
        float r25434 = r25433 * r25433;
        float r25435 = 2;
        float r25436 = r25435 * r25424;
        float r25437 = r25434 / r25436;
        float r25438 = -4.642350045119559e+305;
        bool r25439 = r25437 <= r25438;
        float r25440 = -r25423;
        float r25441 = r25440 / r25435;
        float r25442 = r25428 + r25428;
        float r25443 = r25426 / r25442;
        float r25444 = r25441 * r25443;
        float r25445 = -2.1928611911715794e-262;
        bool r25446 = r25437 <= r25445;
        float r25447 = r25432 / r25436;
        float r25448 = 1.647971180806912e-274;
        bool r25449 = r25437 <= r25448;
        float r25450 = 7.249139874405658e+279;
        bool r25451 = r25437 <= r25450;
        float r25452 = r25451 ? r25447 : r25444;
        float r25453 = r25449 ? r25444 : r25452;
        float r25454 = r25446 ? r25447 : r25453;
        float r25455 = r25439 ? r25444 : r25454;
        return r25455;
}

double f_od(double a, double b, double c) {
        double r25456 = 4;
        double r25457 = a;
        double r25458 = r25456 * r25457;
        double r25459 = c;
        double r25460 = -r25459;
        double r25461 = b;
        double r25462 = r25461 * r25461;
        double r25463 = fma(r25458, r25460, r25462);
        double r25464 = sqrt(r25463);
        double r25465 = r25464 - r25461;
        double r25466 = sqrt(r25465);
        double r25467 = r25466 * r25466;
        double r25468 = 2;
        double r25469 = r25468 * r25457;
        double r25470 = r25467 / r25469;
        double r25471 = -4.642350045119559e+305;
        bool r25472 = r25470 <= r25471;
        double r25473 = -r25456;
        double r25474 = r25473 / r25468;
        double r25475 = r25461 + r25461;
        double r25476 = r25459 / r25475;
        double r25477 = r25474 * r25476;
        double r25478 = -2.1928611911715794e-262;
        bool r25479 = r25470 <= r25478;
        double r25480 = r25465 / r25469;
        double r25481 = 1.647971180806912e-274;
        bool r25482 = r25470 <= r25481;
        double r25483 = 7.249139874405658e+279;
        bool r25484 = r25470 <= r25483;
        double r25485 = r25484 ? r25480 : r25477;
        double r25486 = r25482 ? r25477 : r25485;
        double r25487 = r25479 ? r25480 : r25486;
        double r25488 = r25472 ? r25477 : r25487;
        return r25488;
}

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 r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3408);
        mpfr_init(r25489);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init_set_str(r25492, "4", 10, MPFR_RNDN);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init_set_str(r25500, "2", 10, MPFR_RNDN);
        mpfr_init(r25501);
        mpfr_init(r25502);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25489, b, MPFR_RNDN);
        mpfr_neg(r25490, r25489, MPFR_RNDN);
        mpfr_mul(r25491, r25489, r25489, MPFR_RNDN);
        ;
        mpfr_set_d(r25493, a, MPFR_RNDN);
        mpfr_mul(r25494, r25492, r25493, MPFR_RNDN);
        mpfr_set_d(r25495, c, MPFR_RNDN);
        mpfr_mul(r25496, r25494, r25495, MPFR_RNDN);
        mpfr_sub(r25497, r25491, r25496, MPFR_RNDN);
        mpfr_sqrt(r25498, r25497, MPFR_RNDN);
        mpfr_add(r25499, r25490, r25498, MPFR_RNDN);
        ;
        mpfr_mul(r25501, r25500, r25493, MPFR_RNDN);
        mpfr_div(r25502, r25499, r25501, MPFR_RNDN);
        return mpfr_get_d(r25502, MPFR_RNDN);
}

static mpfr_t r25503, r25504, r25505, r25506, r25507, r25508, r25509, r25510, r25511, r25512, r25513, r25514, r25515, r25516, r25517, r25518, r25519, r25520, r25521, r25522, r25523, r25524, r25525, r25526, r25527, r25528, r25529, r25530, r25531, r25532, r25533, r25534, r25535;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3408);
        mpfr_init_set_str(r25503, "4", 10, MPFR_RNDN);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init(r25509);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init_set_str(r25515, "2", 10, MPFR_RNDN);
        mpfr_init(r25516);
        mpfr_init(r25517);
        mpfr_init_set_str(r25518, "-4.642350045119559e+305", 10, MPFR_RNDN);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init_set_str(r25525, "-2.1928611911715794e-262", 10, MPFR_RNDN);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init_set_str(r25528, "1.647971180806912e-274", 10, MPFR_RNDN);
        mpfr_init(r25529);
        mpfr_init_set_str(r25530, "7.249139874405658e+279", 10, MPFR_RNDN);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init(r25535);
}

double f_fm(double a, double b, double c) {
        ;
        mpfr_set_d(r25504, a, MPFR_RNDN);
        mpfr_mul(r25505, r25503, r25504, MPFR_RNDN);
        mpfr_set_d(r25506, c, MPFR_RNDN);
        mpfr_neg(r25507, r25506, MPFR_RNDN);
        mpfr_set_d(r25508, b, MPFR_RNDN);
        mpfr_mul(r25509, r25508, r25508, MPFR_RNDN);
        mpfr_fma(r25510, r25505, r25507, r25509, MPFR_RNDN);
        mpfr_sqrt(r25511, r25510, MPFR_RNDN);
        mpfr_sub(r25512, r25511, r25508, MPFR_RNDN);
        mpfr_sqrt(r25513, r25512, MPFR_RNDN);
        mpfr_mul(r25514, r25513, r25513, MPFR_RNDN);
        ;
        mpfr_mul(r25516, r25515, r25504, MPFR_RNDN);
        mpfr_div(r25517, r25514, r25516, MPFR_RNDN);
        ;
        mpfr_set_si(r25519, mpfr_cmp(r25517, r25518) <= 0, MPFR_RNDN);
        mpfr_neg(r25520, r25503, MPFR_RNDN);
        mpfr_div(r25521, r25520, r25515, MPFR_RNDN);
        mpfr_add(r25522, r25508, r25508, MPFR_RNDN);
        mpfr_div(r25523, r25506, r25522, MPFR_RNDN);
        mpfr_mul(r25524, r25521, r25523, MPFR_RNDN);
        ;
        mpfr_set_si(r25526, mpfr_cmp(r25517, r25525) <= 0, MPFR_RNDN);
        mpfr_div(r25527, r25512, r25516, MPFR_RNDN);
        ;
        mpfr_set_si(r25529, mpfr_cmp(r25517, r25528) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25531, mpfr_cmp(r25517, r25530) <= 0, MPFR_RNDN);
        if (mpfr_get_si(r25531, MPFR_RNDN)) { mpfr_set(r25532, r25527, MPFR_RNDN); } else { mpfr_set(r25532, r25524, MPFR_RNDN); };
        if (mpfr_get_si(r25529, MPFR_RNDN)) { mpfr_set(r25533, r25524, MPFR_RNDN); } else { mpfr_set(r25533, r25532, MPFR_RNDN); };
        if (mpfr_get_si(r25526, MPFR_RNDN)) { mpfr_set(r25534, r25527, MPFR_RNDN); } else { mpfr_set(r25534, r25533, MPFR_RNDN); };
        if (mpfr_get_si(r25519, MPFR_RNDN)) { mpfr_set(r25535, r25524, MPFR_RNDN); } else { mpfr_set(r25535, r25534, MPFR_RNDN); };
        return mpfr_get_d(r25535, MPFR_RNDN);
}

static mpfr_t r25536, r25537, r25538, r25539, r25540, r25541, r25542, r25543, r25544, r25545, r25546, r25547, r25548, r25549, r25550, r25551, r25552, r25553, r25554, r25555, r25556, r25557, r25558, r25559, r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3408);
        mpfr_init_set_str(r25536, "4", 10, MPFR_RNDN);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init(r25546);
        mpfr_init(r25547);
        mpfr_init_set_str(r25548, "2", 10, MPFR_RNDN);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init_set_str(r25551, "-4.642350045119559e+305", 10, MPFR_RNDN);
        mpfr_init(r25552);
        mpfr_init(r25553);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init(r25556);
        mpfr_init(r25557);
        mpfr_init_set_str(r25558, "-2.1928611911715794e-262", 10, MPFR_RNDN);
        mpfr_init(r25559);
        mpfr_init(r25560);
        mpfr_init_set_str(r25561, "1.647971180806912e-274", 10, MPFR_RNDN);
        mpfr_init(r25562);
        mpfr_init_set_str(r25563, "7.249139874405658e+279", 10, MPFR_RNDN);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init(r25567);
        mpfr_init(r25568);
}

double f_dm(double a, double b, double c) {
        ;
        mpfr_set_d(r25537, a, MPFR_RNDN);
        mpfr_mul(r25538, r25536, r25537, MPFR_RNDN);
        mpfr_set_d(r25539, c, MPFR_RNDN);
        mpfr_neg(r25540, r25539, MPFR_RNDN);
        mpfr_set_d(r25541, b, MPFR_RNDN);
        mpfr_mul(r25542, r25541, r25541, MPFR_RNDN);
        mpfr_fma(r25543, r25538, r25540, r25542, MPFR_RNDN);
        mpfr_sqrt(r25544, r25543, MPFR_RNDN);
        mpfr_sub(r25545, r25544, r25541, MPFR_RNDN);
        mpfr_sqrt(r25546, r25545, MPFR_RNDN);
        mpfr_mul(r25547, r25546, r25546, MPFR_RNDN);
        ;
        mpfr_mul(r25549, r25548, r25537, MPFR_RNDN);
        mpfr_div(r25550, r25547, r25549, MPFR_RNDN);
        ;
        mpfr_set_si(r25552, mpfr_cmp(r25550, r25551) <= 0, MPFR_RNDN);
        mpfr_neg(r25553, r25536, MPFR_RNDN);
        mpfr_div(r25554, r25553, r25548, MPFR_RNDN);
        mpfr_add(r25555, r25541, r25541, MPFR_RNDN);
        mpfr_div(r25556, r25539, r25555, MPFR_RNDN);
        mpfr_mul(r25557, r25554, r25556, MPFR_RNDN);
        ;
        mpfr_set_si(r25559, mpfr_cmp(r25550, r25558) <= 0, MPFR_RNDN);
        mpfr_div(r25560, r25545, r25549, MPFR_RNDN);
        ;
        mpfr_set_si(r25562, mpfr_cmp(r25550, r25561) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25564, mpfr_cmp(r25550, r25563) <= 0, MPFR_RNDN);
        if (mpfr_get_si(r25564, MPFR_RNDN)) { mpfr_set(r25565, r25560, MPFR_RNDN); } else { mpfr_set(r25565, r25557, MPFR_RNDN); };
        if (mpfr_get_si(r25562, MPFR_RNDN)) { mpfr_set(r25566, r25557, MPFR_RNDN); } else { mpfr_set(r25566, r25565, MPFR_RNDN); };
        if (mpfr_get_si(r25559, MPFR_RNDN)) { mpfr_set(r25567, r25560, MPFR_RNDN); } else { mpfr_set(r25567, r25566, MPFR_RNDN); };
        if (mpfr_get_si(r25552, MPFR_RNDN)) { mpfr_set(r25568, r25557, MPFR_RNDN); } else { mpfr_set(r25568, r25567, MPFR_RNDN); };
        return mpfr_get_d(r25568, MPFR_RNDN);
}

