#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 r25366 = b;
        float r25367 = -r25366;
        float r25368 = r25366 * r25366;
        float r25369 = 4;
        float r25370 = a;
        float r25371 = r25369 * r25370;
        float r25372 = c;
        float r25373 = r25371 * r25372;
        float r25374 = r25368 - r25373;
        float r25375 = sqrt(r25374);
        float r25376 = r25367 + r25375;
        float r25377 = 2;
        float r25378 = r25377 * r25370;
        float r25379 = r25376 / r25378;
        return r25379;
}

double f_id(double a, double b, double c) {
        double r25380 = b;
        double r25381 = -r25380;
        double r25382 = r25380 * r25380;
        double r25383 = 4;
        double r25384 = a;
        double r25385 = r25383 * r25384;
        double r25386 = c;
        double r25387 = r25385 * r25386;
        double r25388 = r25382 - r25387;
        double r25389 = sqrt(r25388);
        double r25390 = r25381 + r25389;
        double r25391 = 2;
        double r25392 = r25391 * r25384;
        double r25393 = r25390 / r25392;
        return r25393;
}


double f_of(float a, float b, float c) {
        float r25394 = b;
        float r25395 = 2;
        float r25396 = pow(r25394, r25395);
        float r25397 = 4;
        float r25398 = c;
        float r25399 = a;
        float r25400 = r25398 * r25399;
        float r25401 = r25397 * r25400;
        float r25402 = r25396 - r25401;
        float r25403 = sqrt(r25402);
        float r25404 = r25403 - r25394;
        float r25405 = r25395 * r25399;
        float r25406 = r25404 / r25405;
        float r25407 = -3.893813382866839e+302;
        bool r25408 = r25406 <= r25407;
        float r25409 = r25398 / r25395;
        float r25410 = -r25397;
        float r25411 = r25409 * r25410;
        float r25412 = r25394 + r25394;
        float r25413 = r25411 / r25412;
        float r25414 = -2.279763752477715e-233;
        bool r25415 = r25406 <= r25414;
        float r25416 = 9.990245652938313e-103;
        bool r25417 = r25406 <= r25416;
        float r25418 = r25399 * r25398;
        float r25419 = r25394 * r25394;
        float r25420 = fma(r25418, r25410, r25419);
        float r25421 = sqrt(r25420);
        float r25422 = r25421 + r25394;
        float r25423 = r25411 / r25422;
        float r25424 = 7.314979115890435e+294;
        bool r25425 = r25406 <= r25424;
        float r25426 = r25425 ? r25406 : r25413;
        float r25427 = r25417 ? r25423 : r25426;
        float r25428 = r25415 ? r25406 : r25427;
        float r25429 = r25408 ? r25413 : r25428;
        return r25429;
}

double f_od(double a, double b, double c) {
        double r25430 = b;
        double r25431 = 2;
        double r25432 = pow(r25430, r25431);
        double r25433 = 4;
        double r25434 = c;
        double r25435 = a;
        double r25436 = r25434 * r25435;
        double r25437 = r25433 * r25436;
        double r25438 = r25432 - r25437;
        double r25439 = sqrt(r25438);
        double r25440 = r25439 - r25430;
        double r25441 = r25431 * r25435;
        double r25442 = r25440 / r25441;
        double r25443 = -3.893813382866839e+302;
        bool r25444 = r25442 <= r25443;
        double r25445 = r25434 / r25431;
        double r25446 = -r25433;
        double r25447 = r25445 * r25446;
        double r25448 = r25430 + r25430;
        double r25449 = r25447 / r25448;
        double r25450 = -2.279763752477715e-233;
        bool r25451 = r25442 <= r25450;
        double r25452 = 9.990245652938313e-103;
        bool r25453 = r25442 <= r25452;
        double r25454 = r25435 * r25434;
        double r25455 = r25430 * r25430;
        double r25456 = fma(r25454, r25446, r25455);
        double r25457 = sqrt(r25456);
        double r25458 = r25457 + r25430;
        double r25459 = r25447 / r25458;
        double r25460 = 7.314979115890435e+294;
        bool r25461 = r25442 <= r25460;
        double r25462 = r25461 ? r25442 : r25449;
        double r25463 = r25453 ? r25459 : r25462;
        double r25464 = r25451 ? r25442 : r25463;
        double r25465 = r25444 ? r25449 : r25464;
        return r25465;
}

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 r25466, r25467, r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3408);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init_set_str(r25469, "4", 10, MPFR_RNDN);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init_set_str(r25477, "2", 10, MPFR_RNDN);
        mpfr_init(r25478);
        mpfr_init(r25479);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25466, b, MPFR_RNDN);
        mpfr_neg(r25467, r25466, MPFR_RNDN);
        mpfr_mul(r25468, r25466, r25466, MPFR_RNDN);
        ;
        mpfr_set_d(r25470, a, MPFR_RNDN);
        mpfr_mul(r25471, r25469, r25470, MPFR_RNDN);
        mpfr_set_d(r25472, c, MPFR_RNDN);
        mpfr_mul(r25473, r25471, r25472, MPFR_RNDN);
        mpfr_sub(r25474, r25468, r25473, MPFR_RNDN);
        mpfr_sqrt(r25475, r25474, MPFR_RNDN);
        mpfr_add(r25476, r25467, r25475, MPFR_RNDN);
        ;
        mpfr_mul(r25478, r25477, r25470, MPFR_RNDN);
        mpfr_div(r25479, r25476, r25478, MPFR_RNDN);
        return mpfr_get_d(r25479, MPFR_RNDN);
}

static mpfr_t r25480, r25481, r25482, r25483, r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502, r25503, r25504, r25505, r25506, r25507, r25508, r25509, r25510, r25511, r25512, r25513, r25514, r25515;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3408);
        mpfr_init(r25480);
        mpfr_init_set_str(r25481, "2", 10, MPFR_RNDN);
        mpfr_init(r25482);
        mpfr_init_set_str(r25483, "4", 10, MPFR_RNDN);
        mpfr_init(r25484);
        mpfr_init(r25485);
        mpfr_init(r25486);
        mpfr_init(r25487);
        mpfr_init(r25488);
        mpfr_init(r25489);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init_set_str(r25493, "-3.893813382866839e+302", 10, MPFR_RNDN);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init_set_str(r25500, "-2.279763752477715e-233", 10, MPFR_RNDN);
        mpfr_init(r25501);
        mpfr_init_set_str(r25502, "9.990245652938313e-103", 10, MPFR_RNDN);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init(r25509);
        mpfr_init_set_str(r25510, "7.314979115890435e+294", 10, MPFR_RNDN);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r25480, b, MPFR_RNDN);
        ;
        mpfr_pow(r25482, r25480, r25481, MPFR_RNDN);
        ;
        mpfr_set_d(r25484, c, MPFR_RNDN);
        mpfr_set_d(r25485, a, MPFR_RNDN);
        mpfr_mul(r25486, r25484, r25485, MPFR_RNDN);
        mpfr_mul(r25487, r25483, r25486, MPFR_RNDN);
        mpfr_sub(r25488, r25482, r25487, MPFR_RNDN);
        mpfr_sqrt(r25489, r25488, MPFR_RNDN);
        mpfr_sub(r25490, r25489, r25480, MPFR_RNDN);
        mpfr_mul(r25491, r25481, r25485, MPFR_RNDN);
        mpfr_div(r25492, r25490, r25491, MPFR_RNDN);
        ;
        mpfr_set_si(r25494, mpfr_cmp(r25492, r25493) <= 0, MPFR_RNDN);
        mpfr_div(r25495, r25484, r25481, MPFR_RNDN);
        mpfr_neg(r25496, r25483, MPFR_RNDN);
        mpfr_mul(r25497, r25495, r25496, MPFR_RNDN);
        mpfr_add(r25498, r25480, r25480, MPFR_RNDN);
        mpfr_div(r25499, r25497, r25498, MPFR_RNDN);
        ;
        mpfr_set_si(r25501, mpfr_cmp(r25492, r25500) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25503, mpfr_cmp(r25492, r25502) <= 0, MPFR_RNDN);
        mpfr_mul(r25504, r25485, r25484, MPFR_RNDN);
        mpfr_mul(r25505, r25480, r25480, MPFR_RNDN);
        mpfr_fma(r25506, r25504, r25496, r25505, MPFR_RNDN);
        mpfr_sqrt(r25507, r25506, MPFR_RNDN);
        mpfr_add(r25508, r25507, r25480, MPFR_RNDN);
        mpfr_div(r25509, r25497, r25508, MPFR_RNDN);
        ;
        mpfr_set_si(r25511, mpfr_cmp(r25492, r25510) <= 0, MPFR_RNDN);
        if (mpfr_get_si(r25511, MPFR_RNDN)) { mpfr_set(r25512, r25492, MPFR_RNDN); } else { mpfr_set(r25512, r25499, MPFR_RNDN); };
        if (mpfr_get_si(r25503, MPFR_RNDN)) { mpfr_set(r25513, r25509, MPFR_RNDN); } else { mpfr_set(r25513, r25512, MPFR_RNDN); };
        if (mpfr_get_si(r25501, MPFR_RNDN)) { mpfr_set(r25514, r25492, MPFR_RNDN); } else { mpfr_set(r25514, r25513, MPFR_RNDN); };
        if (mpfr_get_si(r25494, MPFR_RNDN)) { mpfr_set(r25515, r25499, MPFR_RNDN); } else { mpfr_set(r25515, r25514, MPFR_RNDN); };
        return mpfr_get_d(r25515, MPFR_RNDN);
}

static mpfr_t r25516, r25517, r25518, r25519, r25520, 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;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3408);
        mpfr_init(r25516);
        mpfr_init_set_str(r25517, "2", 10, MPFR_RNDN);
        mpfr_init(r25518);
        mpfr_init_set_str(r25519, "4", 10, MPFR_RNDN);
        mpfr_init(r25520);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init_set_str(r25529, "-3.893813382866839e+302", 10, MPFR_RNDN);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init(r25535);
        mpfr_init_set_str(r25536, "-2.279763752477715e-233", 10, MPFR_RNDN);
        mpfr_init(r25537);
        mpfr_init_set_str(r25538, "9.990245652938313e-103", 10, MPFR_RNDN);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init_set_str(r25546, "7.314979115890435e+294", 10, MPFR_RNDN);
        mpfr_init(r25547);
        mpfr_init(r25548);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
}

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

