#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 r25280 = b;
        float r25281 = -r25280;
        float r25282 = r25280 * r25280;
        float r25283 = 4;
        float r25284 = a;
        float r25285 = r25283 * r25284;
        float r25286 = c;
        float r25287 = r25285 * r25286;
        float r25288 = r25282 - r25287;
        float r25289 = sqrt(r25288);
        float r25290 = r25281 + r25289;
        float r25291 = 2;
        float r25292 = r25291 * r25284;
        float r25293 = r25290 / r25292;
        return r25293;
}

double f_id(double a, double b, double c) {
        double r25294 = b;
        double r25295 = -r25294;
        double r25296 = r25294 * r25294;
        double r25297 = 4;
        double r25298 = a;
        double r25299 = r25297 * r25298;
        double r25300 = c;
        double r25301 = r25299 * r25300;
        double r25302 = r25296 - r25301;
        double r25303 = sqrt(r25302);
        double r25304 = r25295 + r25303;
        double r25305 = 2;
        double r25306 = r25305 * r25298;
        double r25307 = r25304 / r25306;
        return r25307;
}


double f_of(float a, float b, float c) {
        float r25308 = 1;
        float r25309 = 2;
        float r25310 = r25308 / r25309;
        float r25311 = 4;
        float r25312 = c;
        float r25313 = -r25312;
        float r25314 = r25311 * r25313;
        float r25315 = r25310 * r25314;
        float r25316 = b;
        float r25317 = sqrt(r25316);
        float r25318 = a;
        float r25319 = r25311 * r25318;
        float r25320 = r25316 * r25316;
        float r25321 = fma(r25313, r25319, r25320);
        float r25322 = sqrt(r25321);
        float r25323 = sqrt(r25322);
        float r25324 = fma(r25317, r25323, r25316);
        float r25325 = r25315 / r25324;
        float r25326 = -2.1386830821976588e+31;
        bool r25327 = r25325 <= r25326;
        float r25328 = r25312 * r25318;
        float r25329 = -r25311;
        float r25330 = r25328 * r25329;
        float r25331 = fma(r25319, r25313, r25320);
        float r25332 = sqrt(r25331);
        float r25333 = sqrt(r25332);
        float r25334 = r25333 * r25333;
        float r25335 = r25334 + r25316;
        float r25336 = r25330 / r25335;
        float r25337 = r25309 * r25318;
        float r25338 = r25336 / r25337;
        float r25339 = -3.8141867858944e-321;
        bool r25340 = r25325 <= r25339;
        float r25341 = r25314 * r25310;
        float r25342 = r25322 + r25316;
        float r25343 = r25341 / r25342;
        float r25344 = log1p(r25343);
        float r25345 = expm1(r25344);
        float r25346 = 4.619883081955796e-293;
        bool r25347 = r25325 <= r25346;
        float r25348 = r25316 + r25316;
        float r25349 = r25330 / r25348;
        float r25350 = r25349 / r25337;
        float r25351 = 3.120724825566233e+258;
        bool r25352 = r25325 <= r25351;
        float r25353 = r25332 / r25337;
        float r25354 = r25316 / r25337;
        float r25355 = r25353 - r25354;
        float r25356 = r25352 ? r25345 : r25355;
        float r25357 = r25347 ? r25350 : r25356;
        float r25358 = r25340 ? r25345 : r25357;
        float r25359 = r25327 ? r25338 : r25358;
        return r25359;
}

double f_od(double a, double b, double c) {
        double r25360 = 1;
        double r25361 = 2;
        double r25362 = r25360 / r25361;
        double r25363 = 4;
        double r25364 = c;
        double r25365 = -r25364;
        double r25366 = r25363 * r25365;
        double r25367 = r25362 * r25366;
        double r25368 = b;
        double r25369 = sqrt(r25368);
        double r25370 = a;
        double r25371 = r25363 * r25370;
        double r25372 = r25368 * r25368;
        double r25373 = fma(r25365, r25371, r25372);
        double r25374 = sqrt(r25373);
        double r25375 = sqrt(r25374);
        double r25376 = fma(r25369, r25375, r25368);
        double r25377 = r25367 / r25376;
        double r25378 = -2.1386830821976588e+31;
        bool r25379 = r25377 <= r25378;
        double r25380 = r25364 * r25370;
        double r25381 = -r25363;
        double r25382 = r25380 * r25381;
        double r25383 = fma(r25371, r25365, r25372);
        double r25384 = sqrt(r25383);
        double r25385 = sqrt(r25384);
        double r25386 = r25385 * r25385;
        double r25387 = r25386 + r25368;
        double r25388 = r25382 / r25387;
        double r25389 = r25361 * r25370;
        double r25390 = r25388 / r25389;
        double r25391 = -3.8141867858944e-321;
        bool r25392 = r25377 <= r25391;
        double r25393 = r25366 * r25362;
        double r25394 = r25374 + r25368;
        double r25395 = r25393 / r25394;
        double r25396 = log1p(r25395);
        double r25397 = expm1(r25396);
        double r25398 = 4.619883081955796e-293;
        bool r25399 = r25377 <= r25398;
        double r25400 = r25368 + r25368;
        double r25401 = r25382 / r25400;
        double r25402 = r25401 / r25389;
        double r25403 = 3.120724825566233e+258;
        bool r25404 = r25377 <= r25403;
        double r25405 = r25384 / r25389;
        double r25406 = r25368 / r25389;
        double r25407 = r25405 - r25406;
        double r25408 = r25404 ? r25397 : r25407;
        double r25409 = r25399 ? r25402 : r25408;
        double r25410 = r25392 ? r25397 : r25409;
        double r25411 = r25379 ? r25390 : r25410;
        return r25411;
}

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 r25412, r25413, r25414, r25415, r25416, r25417, r25418, r25419, r25420, r25421, r25422, r25423, r25424, r25425;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3472);
        mpfr_init(r25412);
        mpfr_init(r25413);
        mpfr_init(r25414);
        mpfr_init_set_str(r25415, "4", 10, MPFR_RNDN);
        mpfr_init(r25416);
        mpfr_init(r25417);
        mpfr_init(r25418);
        mpfr_init(r25419);
        mpfr_init(r25420);
        mpfr_init(r25421);
        mpfr_init(r25422);
        mpfr_init_set_str(r25423, "2", 10, MPFR_RNDN);
        mpfr_init(r25424);
        mpfr_init(r25425);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r25412, b, MPFR_RNDN);
        mpfr_neg(r25413, r25412, MPFR_RNDN);
        mpfr_mul(r25414, r25412, r25412, MPFR_RNDN);
        ;
        mpfr_set_d(r25416, a, MPFR_RNDN);
        mpfr_mul(r25417, r25415, r25416, MPFR_RNDN);
        mpfr_set_d(r25418, c, MPFR_RNDN);
        mpfr_mul(r25419, r25417, r25418, MPFR_RNDN);
        mpfr_sub(r25420, r25414, r25419, MPFR_RNDN);
        mpfr_sqrt(r25421, r25420, MPFR_RNDN);
        mpfr_add(r25422, r25413, r25421, MPFR_RNDN);
        ;
        mpfr_mul(r25424, r25423, r25416, MPFR_RNDN);
        mpfr_div(r25425, r25422, r25424, MPFR_RNDN);
        return mpfr_get_d(r25425, MPFR_RNDN);
}

static mpfr_t r25426, r25427, r25428, r25429, r25430, r25431, r25432, r25433, r25434, r25435, r25436, r25437, r25438, r25439, r25440, r25441, r25442, r25443, r25444, 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;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3472);
        mpfr_init_set_str(r25426, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25427, "2", 10, MPFR_RNDN);
        mpfr_init(r25428);
        mpfr_init_set_str(r25429, "4", 10, MPFR_RNDN);
        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_set_str(r25444, "-2.1386830821976588e+31", 10, MPFR_RNDN);
        mpfr_init(r25445);
        mpfr_init(r25446);
        mpfr_init(r25447);
        mpfr_init(r25448);
        mpfr_init(r25449);
        mpfr_init(r25450);
        mpfr_init(r25451);
        mpfr_init(r25452);
        mpfr_init(r25453);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init(r25456);
        mpfr_init_set_str(r25457, "-3.8141867858944e-321", 10, MPFR_RNDN);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init(r25460);
        mpfr_init(r25461);
        mpfr_init(r25462);
        mpfr_init(r25463);
        mpfr_init_set_str(r25464, "4.619883081955796e-293", 10, MPFR_RNDN);
        mpfr_init(r25465);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init_set_str(r25469, "3.120724825566233e+258", 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(r25477);
}

double f_fm(double a, double b, double c) {
        ;
        ;
        mpfr_div(r25428, r25426, r25427, MPFR_RNDN);
        ;
        mpfr_set_d(r25430, c, MPFR_RNDN);
        mpfr_neg(r25431, r25430, MPFR_RNDN);
        mpfr_mul(r25432, r25429, r25431, MPFR_RNDN);
        mpfr_mul(r25433, r25428, r25432, MPFR_RNDN);
        mpfr_set_d(r25434, b, MPFR_RNDN);
        mpfr_sqrt(r25435, r25434, MPFR_RNDN);
        mpfr_set_d(r25436, a, MPFR_RNDN);
        mpfr_mul(r25437, r25429, r25436, MPFR_RNDN);
        mpfr_mul(r25438, r25434, r25434, MPFR_RNDN);
        mpfr_fma(r25439, r25431, r25437, r25438, MPFR_RNDN);
        mpfr_sqrt(r25440, r25439, MPFR_RNDN);
        mpfr_sqrt(r25441, r25440, MPFR_RNDN);
        mpfr_fma(r25442, r25435, r25441, r25434, MPFR_RNDN);
        mpfr_div(r25443, r25433, r25442, MPFR_RNDN);
        ;
        mpfr_set_si(r25445, mpfr_cmp(r25443, r25444) <= 0, MPFR_RNDN);
        mpfr_mul(r25446, r25430, r25436, MPFR_RNDN);
        mpfr_neg(r25447, r25429, MPFR_RNDN);
        mpfr_mul(r25448, r25446, r25447, MPFR_RNDN);
        mpfr_fma(r25449, r25437, r25431, r25438, MPFR_RNDN);
        mpfr_sqrt(r25450, r25449, MPFR_RNDN);
        mpfr_sqrt(r25451, r25450, MPFR_RNDN);
        mpfr_mul(r25452, r25451, r25451, MPFR_RNDN);
        mpfr_add(r25453, r25452, r25434, MPFR_RNDN);
        mpfr_div(r25454, r25448, r25453, MPFR_RNDN);
        mpfr_mul(r25455, r25427, r25436, MPFR_RNDN);
        mpfr_div(r25456, r25454, r25455, MPFR_RNDN);
        ;
        mpfr_set_si(r25458, mpfr_cmp(r25443, r25457) <= 0, MPFR_RNDN);
        mpfr_mul(r25459, r25432, r25428, MPFR_RNDN);
        mpfr_add(r25460, r25440, r25434, MPFR_RNDN);
        mpfr_div(r25461, r25459, r25460, MPFR_RNDN);
        mpfr_log1p(r25462, r25461, MPFR_RNDN);
        mpfr_expm1(r25463, r25462, MPFR_RNDN);
        ;
        mpfr_set_si(r25465, mpfr_cmp(r25443, r25464) <= 0, MPFR_RNDN);
        mpfr_add(r25466, r25434, r25434, MPFR_RNDN);
        mpfr_div(r25467, r25448, r25466, MPFR_RNDN);
        mpfr_div(r25468, r25467, r25455, MPFR_RNDN);
        ;
        mpfr_set_si(r25470, mpfr_cmp(r25443, r25469) <= 0, MPFR_RNDN);
        mpfr_div(r25471, r25450, r25455, MPFR_RNDN);
        mpfr_div(r25472, r25434, r25455, MPFR_RNDN);
        mpfr_sub(r25473, r25471, r25472, MPFR_RNDN);
        if (mpfr_get_si(r25470, MPFR_RNDN)) { mpfr_set(r25474, r25463, MPFR_RNDN); } else { mpfr_set(r25474, r25473, MPFR_RNDN); };
        if (mpfr_get_si(r25465, MPFR_RNDN)) { mpfr_set(r25475, r25468, MPFR_RNDN); } else { mpfr_set(r25475, r25474, MPFR_RNDN); };
        if (mpfr_get_si(r25458, MPFR_RNDN)) { mpfr_set(r25476, r25463, MPFR_RNDN); } else { mpfr_set(r25476, r25475, MPFR_RNDN); };
        if (mpfr_get_si(r25445, MPFR_RNDN)) { mpfr_set(r25477, r25456, MPFR_RNDN); } else { mpfr_set(r25477, r25476, MPFR_RNDN); };
        return mpfr_get_d(r25477, MPFR_RNDN);
}

static mpfr_t r25478, r25479, 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, r25516, r25517, r25518, r25519, r25520, r25521, r25522, r25523, r25524, r25525, r25526, r25527, r25528, r25529;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3472);
        mpfr_init_set_str(r25478, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25479, "2", 10, MPFR_RNDN);
        mpfr_init(r25480);
        mpfr_init_set_str(r25481, "4", 10, MPFR_RNDN);
        mpfr_init(r25482);
        mpfr_init(r25483);
        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(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init_set_str(r25496, "-2.1386830821976588e+31", 10, MPFR_RNDN);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init_set_str(r25509, "-3.8141867858944e-321", 10, MPFR_RNDN);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
        mpfr_init_set_str(r25516, "4.619883081955796e-293", 10, MPFR_RNDN);
        mpfr_init(r25517);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init_set_str(r25521, "3.120724825566233e+258", 10, MPFR_RNDN);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init(r25529);
}

double f_dm(double a, double b, double c) {
        ;
        ;
        mpfr_div(r25480, r25478, r25479, MPFR_RNDN);
        ;
        mpfr_set_d(r25482, c, MPFR_RNDN);
        mpfr_neg(r25483, r25482, MPFR_RNDN);
        mpfr_mul(r25484, r25481, r25483, MPFR_RNDN);
        mpfr_mul(r25485, r25480, r25484, MPFR_RNDN);
        mpfr_set_d(r25486, b, MPFR_RNDN);
        mpfr_sqrt(r25487, r25486, MPFR_RNDN);
        mpfr_set_d(r25488, a, MPFR_RNDN);
        mpfr_mul(r25489, r25481, r25488, MPFR_RNDN);
        mpfr_mul(r25490, r25486, r25486, MPFR_RNDN);
        mpfr_fma(r25491, r25483, r25489, r25490, MPFR_RNDN);
        mpfr_sqrt(r25492, r25491, MPFR_RNDN);
        mpfr_sqrt(r25493, r25492, MPFR_RNDN);
        mpfr_fma(r25494, r25487, r25493, r25486, MPFR_RNDN);
        mpfr_div(r25495, r25485, r25494, MPFR_RNDN);
        ;
        mpfr_set_si(r25497, mpfr_cmp(r25495, r25496) <= 0, MPFR_RNDN);
        mpfr_mul(r25498, r25482, r25488, MPFR_RNDN);
        mpfr_neg(r25499, r25481, MPFR_RNDN);
        mpfr_mul(r25500, r25498, r25499, MPFR_RNDN);
        mpfr_fma(r25501, r25489, r25483, r25490, MPFR_RNDN);
        mpfr_sqrt(r25502, r25501, MPFR_RNDN);
        mpfr_sqrt(r25503, r25502, MPFR_RNDN);
        mpfr_mul(r25504, r25503, r25503, MPFR_RNDN);
        mpfr_add(r25505, r25504, r25486, MPFR_RNDN);
        mpfr_div(r25506, r25500, r25505, MPFR_RNDN);
        mpfr_mul(r25507, r25479, r25488, MPFR_RNDN);
        mpfr_div(r25508, r25506, r25507, MPFR_RNDN);
        ;
        mpfr_set_si(r25510, mpfr_cmp(r25495, r25509) <= 0, MPFR_RNDN);
        mpfr_mul(r25511, r25484, r25480, MPFR_RNDN);
        mpfr_add(r25512, r25492, r25486, MPFR_RNDN);
        mpfr_div(r25513, r25511, r25512, MPFR_RNDN);
        mpfr_log1p(r25514, r25513, MPFR_RNDN);
        mpfr_expm1(r25515, r25514, MPFR_RNDN);
        ;
        mpfr_set_si(r25517, mpfr_cmp(r25495, r25516) <= 0, MPFR_RNDN);
        mpfr_add(r25518, r25486, r25486, MPFR_RNDN);
        mpfr_div(r25519, r25500, r25518, MPFR_RNDN);
        mpfr_div(r25520, r25519, r25507, MPFR_RNDN);
        ;
        mpfr_set_si(r25522, mpfr_cmp(r25495, r25521) <= 0, MPFR_RNDN);
        mpfr_div(r25523, r25502, r25507, MPFR_RNDN);
        mpfr_div(r25524, r25486, r25507, MPFR_RNDN);
        mpfr_sub(r25525, r25523, r25524, MPFR_RNDN);
        if (mpfr_get_si(r25522, MPFR_RNDN)) { mpfr_set(r25526, r25515, MPFR_RNDN); } else { mpfr_set(r25526, r25525, MPFR_RNDN); };
        if (mpfr_get_si(r25517, MPFR_RNDN)) { mpfr_set(r25527, r25520, MPFR_RNDN); } else { mpfr_set(r25527, r25526, MPFR_RNDN); };
        if (mpfr_get_si(r25510, MPFR_RNDN)) { mpfr_set(r25528, r25515, MPFR_RNDN); } else { mpfr_set(r25528, r25527, MPFR_RNDN); };
        if (mpfr_get_si(r25497, MPFR_RNDN)) { mpfr_set(r25529, r25508, MPFR_RNDN); } else { mpfr_set(r25529, r25528, MPFR_RNDN); };
        return mpfr_get_d(r25529, MPFR_RNDN);
}

