#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 r25378 = b;
        float r25379 = -r25378;
        float r25380 = r25378 * r25378;
        float r25381 = 4;
        float r25382 = a;
        float r25383 = r25381 * r25382;
        float r25384 = c;
        float r25385 = r25383 * r25384;
        float r25386 = r25380 - r25385;
        float r25387 = sqrt(r25386);
        float r25388 = r25379 + r25387;
        float r25389 = 2;
        float r25390 = r25389 * r25382;
        float r25391 = r25388 / r25390;
        return r25391;
}

double f_id(double a, double b, double c) {
        double r25392 = b;
        double r25393 = -r25392;
        double r25394 = r25392 * r25392;
        double r25395 = 4;
        double r25396 = a;
        double r25397 = r25395 * r25396;
        double r25398 = c;
        double r25399 = r25397 * r25398;
        double r25400 = r25394 - r25399;
        double r25401 = sqrt(r25400);
        double r25402 = r25393 + r25401;
        double r25403 = 2;
        double r25404 = r25403 * r25396;
        double r25405 = r25402 / r25404;
        return r25405;
}


double f_of(float a, float b, float c) {
        float r25406 = b;
        float r25407 = -5.621268925987888e+88;
        bool r25408 = r25406 <= r25407;
        float r25409 = a;
        float r25410 = r25406 / r25409;
        float r25411 = -r25410;
        float r25412 = 8.295686654973578e-275;
        bool r25413 = r25406 <= r25412;
        float r25414 = -r25406;
        float r25415 = r25406 * r25406;
        float r25416 = c;
        float r25417 = 4;
        float r25418 = r25417 * r25409;
        float r25419 = r25416 * r25418;
        float r25420 = r25415 - r25419;
        float r25421 = sqrt(r25420);
        float r25422 = r25414 + r25421;
        float r25423 = 2;
        float r25424 = r25423 * r25409;
        float r25425 = r25422 / r25424;
        float r25426 = 1.2305310758297228e+74;
        bool r25427 = r25406 <= r25426;
        float r25428 = r25414 - r25421;
        float r25429 = cbrt(r25428);
        float r25430 = r25429 * r25429;
        float r25431 = r25416 / r25430;
        float r25432 = r25418 / r25429;
        float r25433 = r25431 * r25432;
        float r25434 = r25433 / r25424;
        float r25435 = r25416 / r25406;
        float r25436 = -r25435;
        float r25437 = r25427 ? r25434 : r25436;
        float r25438 = r25413 ? r25425 : r25437;
        float r25439 = r25408 ? r25411 : r25438;
        return r25439;
}

double f_od(double a, double b, double c) {
        double r25440 = b;
        double r25441 = -5.621268925987888e+88;
        bool r25442 = r25440 <= r25441;
        double r25443 = a;
        double r25444 = r25440 / r25443;
        double r25445 = -r25444;
        double r25446 = 8.295686654973578e-275;
        bool r25447 = r25440 <= r25446;
        double r25448 = -r25440;
        double r25449 = r25440 * r25440;
        double r25450 = c;
        double r25451 = 4;
        double r25452 = r25451 * r25443;
        double r25453 = r25450 * r25452;
        double r25454 = r25449 - r25453;
        double r25455 = sqrt(r25454);
        double r25456 = r25448 + r25455;
        double r25457 = 2;
        double r25458 = r25457 * r25443;
        double r25459 = r25456 / r25458;
        double r25460 = 1.2305310758297228e+74;
        bool r25461 = r25440 <= r25460;
        double r25462 = r25448 - r25455;
        double r25463 = cbrt(r25462);
        double r25464 = r25463 * r25463;
        double r25465 = r25450 / r25464;
        double r25466 = r25452 / r25463;
        double r25467 = r25465 * r25466;
        double r25468 = r25467 / r25458;
        double r25469 = r25450 / r25440;
        double r25470 = -r25469;
        double r25471 = r25461 ? r25468 : r25470;
        double r25472 = r25447 ? r25459 : r25471;
        double r25473 = r25442 ? r25445 : r25472;
        return r25473;
}

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 r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481, r25482, r25483, r25484, r25485, r25486, r25487;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3216);
        mpfr_init(r25474);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init_set_str(r25477, "4", 10, MPFR_RNDN);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init(r25481);
        mpfr_init(r25482);
        mpfr_init(r25483);
        mpfr_init(r25484);
        mpfr_init_set_str(r25485, "2", 10, MPFR_RNDN);
        mpfr_init(r25486);
        mpfr_init(r25487);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25474, b, MPFR_RNDN);
        mpfr_neg(r25475, r25474, MPFR_RNDN);
        mpfr_mul(r25476, r25474, r25474, MPFR_RNDN);
        ;
        mpfr_set_d(r25478, a, MPFR_RNDN);
        mpfr_mul(r25479, r25477, r25478, MPFR_RNDN);
        mpfr_set_d(r25480, c, MPFR_RNDN);
        mpfr_mul(r25481, r25479, r25480, MPFR_RNDN);
        mpfr_sub(r25482, r25476, r25481, MPFR_RNDN);
        mpfr_sqrt(r25483, r25482, MPFR_RNDN);
        mpfr_add(r25484, r25475, r25483, MPFR_RNDN);
        ;
        mpfr_mul(r25486, r25485, r25478, MPFR_RNDN);
        mpfr_div(r25487, r25484, r25486, MPFR_RNDN);
        return mpfr_get_d(r25487, MPFR_RNDN);
}

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

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3216);
        mpfr_init(r25488);
        mpfr_init_set_str(r25489, "-5.621268925987888e+88", 10, MPFR_RNDN);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init_set_str(r25494, "8.295686654973578e-275", 10, MPFR_RNDN);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init_set_str(r25499, "4", 10, MPFR_RNDN);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init_set_str(r25505, "2", 10, MPFR_RNDN);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init_set_str(r25508, "1.2305310758297228e+74", 10, MPFR_RNDN);
        mpfr_init(r25509);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
        mpfr_init(r25516);
        mpfr_init(r25517);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init(r25521);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r25488, b, MPFR_RNDN);
        ;
        mpfr_set_si(r25490, mpfr_cmp(r25488, r25489) <= 0, MPFR_RNDN);
        mpfr_set_d(r25491, a, MPFR_RNDN);
        mpfr_div(r25492, r25488, r25491, MPFR_RNDN);
        mpfr_neg(r25493, r25492, MPFR_RNDN);
        ;
        mpfr_set_si(r25495, mpfr_cmp(r25488, r25494) <= 0, MPFR_RNDN);
        mpfr_neg(r25496, r25488, MPFR_RNDN);
        mpfr_mul(r25497, r25488, r25488, MPFR_RNDN);
        mpfr_set_d(r25498, c, MPFR_RNDN);
        ;
        mpfr_mul(r25500, r25499, r25491, MPFR_RNDN);
        mpfr_mul(r25501, r25498, r25500, MPFR_RNDN);
        mpfr_sub(r25502, r25497, r25501, MPFR_RNDN);
        mpfr_sqrt(r25503, r25502, MPFR_RNDN);
        mpfr_add(r25504, r25496, r25503, MPFR_RNDN);
        ;
        mpfr_mul(r25506, r25505, r25491, MPFR_RNDN);
        mpfr_div(r25507, r25504, r25506, MPFR_RNDN);
        ;
        mpfr_set_si(r25509, mpfr_cmp(r25488, r25508) <= 0, MPFR_RNDN);
        mpfr_sub(r25510, r25496, r25503, MPFR_RNDN);
        mpfr_cbrt(r25511, r25510, MPFR_RNDN);
        mpfr_mul(r25512, r25511, r25511, MPFR_RNDN);
        mpfr_div(r25513, r25498, r25512, MPFR_RNDN);
        mpfr_div(r25514, r25500, r25511, MPFR_RNDN);
        mpfr_mul(r25515, r25513, r25514, MPFR_RNDN);
        mpfr_div(r25516, r25515, r25506, MPFR_RNDN);
        mpfr_div(r25517, r25498, r25488, MPFR_RNDN);
        mpfr_neg(r25518, r25517, MPFR_RNDN);
        if (mpfr_get_si(r25509, MPFR_RNDN)) { mpfr_set(r25519, r25516, MPFR_RNDN); } else { mpfr_set(r25519, r25518, MPFR_RNDN); };
        if (mpfr_get_si(r25495, MPFR_RNDN)) { mpfr_set(r25520, r25507, MPFR_RNDN); } else { mpfr_set(r25520, r25519, MPFR_RNDN); };
        if (mpfr_get_si(r25490, MPFR_RNDN)) { mpfr_set(r25521, r25493, MPFR_RNDN); } else { mpfr_set(r25521, r25520, MPFR_RNDN); };
        return mpfr_get_d(r25521, MPFR_RNDN);
}

static mpfr_t 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, r25555;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3216);
        mpfr_init(r25522);
        mpfr_init_set_str(r25523, "-5.621268925987888e+88", 10, MPFR_RNDN);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init_set_str(r25528, "8.295686654973578e-275", 10, MPFR_RNDN);
        mpfr_init(r25529);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init_set_str(r25533, "4", 10, MPFR_RNDN);
        mpfr_init(r25534);
        mpfr_init(r25535);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init_set_str(r25539, "2", 10, MPFR_RNDN);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init_set_str(r25542, "1.2305310758297228e+74", 10, MPFR_RNDN);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        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);
        mpfr_init(r25555);
}

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

