#include <tgmath.h>
#include <gmp.h>
#include <mpfr.h>
#include <stdio.h>
#include <stdbool.h>

char *name = "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2";

double f_if(float x, float y, float z, float t, float a, float b, float c) {
        float r25406 = x;
        float r25407 = y;
        float r25408 = 2.0;
        float r25409 = z;
        float r25410 = t;
        float r25411 = a;
        float r25412 = r25410 + r25411;
        float r25413 = sqrt(r25412);
        float r25414 = r25409 * r25413;
        float r25415 = r25414 / r25410;
        float r25416 = b;
        float r25417 = c;
        float r25418 = r25416 - r25417;
        float r25419 = 5.0;
        float r25420 = 6.0;
        float r25421 = r25419 / r25420;
        float r25422 = r25411 + r25421;
        float r25423 = 3.0;
        float r25424 = r25410 * r25423;
        float r25425 = r25408 / r25424;
        float r25426 = r25422 - r25425;
        float r25427 = r25418 * r25426;
        float r25428 = r25415 - r25427;
        float r25429 = r25408 * r25428;
        float r25430 = exp(r25429);
        float r25431 = r25407 * r25430;
        float r25432 = r25406 + r25431;
        float r25433 = r25406 / r25432;
        return r25433;
}

double f_id(double x, double y, double z, double t, double a, double b, double c) {
        double r25434 = x;
        double r25435 = y;
        double r25436 = 2.0;
        double r25437 = z;
        double r25438 = t;
        double r25439 = a;
        double r25440 = r25438 + r25439;
        double r25441 = sqrt(r25440);
        double r25442 = r25437 * r25441;
        double r25443 = r25442 / r25438;
        double r25444 = b;
        double r25445 = c;
        double r25446 = r25444 - r25445;
        double r25447 = 5.0;
        double r25448 = 6.0;
        double r25449 = r25447 / r25448;
        double r25450 = r25439 + r25449;
        double r25451 = 3.0;
        double r25452 = r25438 * r25451;
        double r25453 = r25436 / r25452;
        double r25454 = r25450 - r25453;
        double r25455 = r25446 * r25454;
        double r25456 = r25443 - r25455;
        double r25457 = r25436 * r25456;
        double r25458 = exp(r25457);
        double r25459 = r25435 * r25458;
        double r25460 = r25434 + r25459;
        double r25461 = r25434 / r25460;
        return r25461;
}


double f_of(float x, float y, float z, float t, float a, float b, float c) {
        float r25462 = x;
        float r25463 = y;
        float r25464 = 2.0;
        float r25465 = t;
        float r25466 = a;
        float r25467 = r25465 + r25466;
        float r25468 = sqrt(r25467);
        float r25469 = r25468 / r25465;
        float r25470 = z;
        float r25471 = 5.0;
        float r25472 = 6.0;
        float r25473 = r25471 / r25472;
        float r25474 = r25473 + r25466;
        float r25475 = c;
        float r25476 = b;
        float r25477 = r25475 - r25476;
        float r25478 = r25474 * r25477;
        float r25479 = fma(r25469, r25470, r25478);
        float r25480 = r25476 - r25475;
        float r25481 = 3.0;
        float r25482 = r25465 * r25481;
        float r25483 = r25464 / r25482;
        float r25484 = -r25483;
        float r25485 = r25480 * r25484;
        float r25486 = r25479 - r25485;
        float r25487 = r25464 * r25486;
        float r25488 = exp(r25487);
        float r25489 = r25463 * r25488;
        float r25490 = r25462 + r25489;
        float r25491 = r25462 / r25490;
        float r25492 = 1.0;
        bool r25493 = r25491 <= r25492;
        float r25494 = r25470 * r25468;
        float r25495 = 1;
        float r25496 = r25495 / r25465;
        float r25497 = r25464 / r25465;
        float r25498 = r25497 / r25481;
        float r25499 = r25474 - r25498;
        float r25500 = r25499 * r25477;
        float r25501 = fma(r25494, r25496, r25500);
        float r25502 = r25464 * r25501;
        float r25503 = exp(r25502);
        float r25504 = r25463 * r25503;
        float r25505 = r25462 + r25504;
        float r25506 = r25462 / r25505;
        float r25507 = r25493 ? r25491 : r25506;
        return r25507;
}

double f_od(double x, double y, double z, double t, double a, double b, double c) {
        double r25508 = x;
        double r25509 = y;
        double r25510 = 2.0;
        double r25511 = t;
        double r25512 = a;
        double r25513 = r25511 + r25512;
        double r25514 = sqrt(r25513);
        double r25515 = r25514 / r25511;
        double r25516 = z;
        double r25517 = 5.0;
        double r25518 = 6.0;
        double r25519 = r25517 / r25518;
        double r25520 = r25519 + r25512;
        double r25521 = c;
        double r25522 = b;
        double r25523 = r25521 - r25522;
        double r25524 = r25520 * r25523;
        double r25525 = fma(r25515, r25516, r25524);
        double r25526 = r25522 - r25521;
        double r25527 = 3.0;
        double r25528 = r25511 * r25527;
        double r25529 = r25510 / r25528;
        double r25530 = -r25529;
        double r25531 = r25526 * r25530;
        double r25532 = r25525 - r25531;
        double r25533 = r25510 * r25532;
        double r25534 = exp(r25533);
        double r25535 = r25509 * r25534;
        double r25536 = r25508 + r25535;
        double r25537 = r25508 / r25536;
        double r25538 = 1.0;
        bool r25539 = r25537 <= r25538;
        double r25540 = r25516 * r25514;
        double r25541 = 1;
        double r25542 = r25541 / r25511;
        double r25543 = r25510 / r25511;
        double r25544 = r25543 / r25527;
        double r25545 = r25520 - r25544;
        double r25546 = r25545 * r25523;
        double r25547 = fma(r25540, r25542, r25546);
        double r25548 = r25510 * r25547;
        double r25549 = exp(r25548);
        double r25550 = r25509 * r25549;
        double r25551 = r25508 + r25550;
        double r25552 = r25508 / r25551;
        double r25553 = r25539 ? r25537 : r25552;
        return r25553;
}

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 r25554, 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;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(336);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init_set_str(r25556, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
        mpfr_init(r25560);
        mpfr_init(r25561);
        mpfr_init(r25562);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init_set_str(r25567, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25568, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init_set_str(r25571, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25572);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init(r25576);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init(r25579);
        mpfr_init(r25580);
        mpfr_init(r25581);
}

double f_im(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25554, x, MPFR_RNDN);
        mpfr_set_d(r25555, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25557, z, MPFR_RNDN);
        mpfr_set_d(r25558, t, MPFR_RNDN);
        mpfr_set_d(r25559, a, MPFR_RNDN);
        mpfr_add(r25560, r25558, r25559, MPFR_RNDN);
        mpfr_sqrt(r25561, r25560, MPFR_RNDN);
        mpfr_mul(r25562, r25557, r25561, MPFR_RNDN);
        mpfr_div(r25563, r25562, r25558, MPFR_RNDN);
        mpfr_set_d(r25564, b, MPFR_RNDN);
        mpfr_set_d(r25565, c, MPFR_RNDN);
        mpfr_sub(r25566, r25564, r25565, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25569, r25567, r25568, MPFR_RNDN);
        mpfr_add(r25570, r25559, r25569, MPFR_RNDN);
        ;
        mpfr_mul(r25572, r25558, r25571, MPFR_RNDN);
        mpfr_div(r25573, r25556, r25572, MPFR_RNDN);
        mpfr_sub(r25574, r25570, r25573, MPFR_RNDN);
        mpfr_mul(r25575, r25566, r25574, MPFR_RNDN);
        mpfr_sub(r25576, r25563, r25575, MPFR_RNDN);
        mpfr_mul(r25577, r25556, r25576, MPFR_RNDN);
        mpfr_exp(r25578, r25577, MPFR_RNDN);
        mpfr_mul(r25579, r25555, r25578, MPFR_RNDN);
        mpfr_add(r25580, r25554, r25579, MPFR_RNDN);
        mpfr_div(r25581, r25554, r25580, MPFR_RNDN);
        return mpfr_get_d(r25581, MPFR_RNDN);
}

static mpfr_t r25582, r25583, r25584, r25585, r25586, r25587, r25588, r25589, r25590, r25591, r25592, r25593, r25594, r25595, r25596, r25597, r25598, r25599, r25600, r25601, r25602, r25603, r25604, r25605, r25606, r25607, r25608, r25609, r25610, r25611, r25612, r25613, r25614, r25615, r25616, r25617, r25618, r25619, r25620, r25621, r25622, r25623, r25624, r25625, r25626, r25627;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25582);
        mpfr_init(r25583);
        mpfr_init_set_str(r25584, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25585);
        mpfr_init(r25586);
        mpfr_init(r25587);
        mpfr_init(r25588);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init_set_str(r25591, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25592, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25593);
        mpfr_init(r25594);
        mpfr_init(r25595);
        mpfr_init(r25596);
        mpfr_init(r25597);
        mpfr_init(r25598);
        mpfr_init(r25599);
        mpfr_init(r25600);
        mpfr_init_set_str(r25601, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25602);
        mpfr_init(r25603);
        mpfr_init(r25604);
        mpfr_init(r25605);
        mpfr_init(r25606);
        mpfr_init(r25607);
        mpfr_init(r25608);
        mpfr_init(r25609);
        mpfr_init(r25610);
        mpfr_init(r25611);
        mpfr_init_set_str(r25612, "1.0", 10, MPFR_RNDN);
        mpfr_init(r25613);
        mpfr_init(r25614);
        mpfr_init_set_str(r25615, "1", 10, MPFR_RNDN);
        mpfr_init(r25616);
        mpfr_init(r25617);
        mpfr_init(r25618);
        mpfr_init(r25619);
        mpfr_init(r25620);
        mpfr_init(r25621);
        mpfr_init(r25622);
        mpfr_init(r25623);
        mpfr_init(r25624);
        mpfr_init(r25625);
        mpfr_init(r25626);
        mpfr_init(r25627);
}

double f_fm(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25582, x, MPFR_RNDN);
        mpfr_set_d(r25583, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25585, t, MPFR_RNDN);
        mpfr_set_d(r25586, a, MPFR_RNDN);
        mpfr_add(r25587, r25585, r25586, MPFR_RNDN);
        mpfr_sqrt(r25588, r25587, MPFR_RNDN);
        mpfr_div(r25589, r25588, r25585, MPFR_RNDN);
        mpfr_set_d(r25590, z, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25593, r25591, r25592, MPFR_RNDN);
        mpfr_add(r25594, r25593, r25586, MPFR_RNDN);
        mpfr_set_d(r25595, c, MPFR_RNDN);
        mpfr_set_d(r25596, b, MPFR_RNDN);
        mpfr_sub(r25597, r25595, r25596, MPFR_RNDN);
        mpfr_mul(r25598, r25594, r25597, MPFR_RNDN);
        mpfr_fma(r25599, r25589, r25590, r25598, MPFR_RNDN);
        mpfr_sub(r25600, r25596, r25595, MPFR_RNDN);
        ;
        mpfr_mul(r25602, r25585, r25601, MPFR_RNDN);
        mpfr_div(r25603, r25584, r25602, MPFR_RNDN);
        mpfr_neg(r25604, r25603, MPFR_RNDN);
        mpfr_mul(r25605, r25600, r25604, MPFR_RNDN);
        mpfr_sub(r25606, r25599, r25605, MPFR_RNDN);
        mpfr_mul(r25607, r25584, r25606, MPFR_RNDN);
        mpfr_exp(r25608, r25607, MPFR_RNDN);
        mpfr_mul(r25609, r25583, r25608, MPFR_RNDN);
        mpfr_add(r25610, r25582, r25609, MPFR_RNDN);
        mpfr_div(r25611, r25582, r25610, MPFR_RNDN);
        ;
        mpfr_set_si(r25613, mpfr_cmp(r25611, r25612) <= 0, MPFR_RNDN);
        mpfr_mul(r25614, r25590, r25588, MPFR_RNDN);
        ;
        mpfr_div(r25616, r25615, r25585, MPFR_RNDN);
        mpfr_div(r25617, r25584, r25585, MPFR_RNDN);
        mpfr_div(r25618, r25617, r25601, MPFR_RNDN);
        mpfr_sub(r25619, r25594, r25618, MPFR_RNDN);
        mpfr_mul(r25620, r25619, r25597, MPFR_RNDN);
        mpfr_fma(r25621, r25614, r25616, r25620, MPFR_RNDN);
        mpfr_mul(r25622, r25584, r25621, MPFR_RNDN);
        mpfr_exp(r25623, r25622, MPFR_RNDN);
        mpfr_mul(r25624, r25583, r25623, MPFR_RNDN);
        mpfr_add(r25625, r25582, r25624, MPFR_RNDN);
        mpfr_div(r25626, r25582, r25625, MPFR_RNDN);
        if (mpfr_get_si(r25613, MPFR_RNDN)) { mpfr_set(r25627, r25611, MPFR_RNDN); } else { mpfr_set(r25627, r25626, MPFR_RNDN); };
        return mpfr_get_d(r25627, MPFR_RNDN);
}

static mpfr_t r25628, r25629, r25630, r25631, r25632, r25633, r25634, r25635, r25636, r25637, r25638, r25639, r25640, r25641, r25642, r25643, r25644, r25645, r25646, r25647, r25648, r25649, r25650, r25651, r25652, r25653, r25654, r25655, r25656, r25657, r25658, r25659, r25660, r25661, r25662, r25663, r25664, r25665, r25666, r25667, r25668, r25669, r25670, r25671, r25672, r25673;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25628);
        mpfr_init(r25629);
        mpfr_init_set_str(r25630, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25631);
        mpfr_init(r25632);
        mpfr_init(r25633);
        mpfr_init(r25634);
        mpfr_init(r25635);
        mpfr_init(r25636);
        mpfr_init_set_str(r25637, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25638, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25639);
        mpfr_init(r25640);
        mpfr_init(r25641);
        mpfr_init(r25642);
        mpfr_init(r25643);
        mpfr_init(r25644);
        mpfr_init(r25645);
        mpfr_init(r25646);
        mpfr_init_set_str(r25647, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25648);
        mpfr_init(r25649);
        mpfr_init(r25650);
        mpfr_init(r25651);
        mpfr_init(r25652);
        mpfr_init(r25653);
        mpfr_init(r25654);
        mpfr_init(r25655);
        mpfr_init(r25656);
        mpfr_init(r25657);
        mpfr_init_set_str(r25658, "1.0", 10, MPFR_RNDN);
        mpfr_init(r25659);
        mpfr_init(r25660);
        mpfr_init_set_str(r25661, "1", 10, MPFR_RNDN);
        mpfr_init(r25662);
        mpfr_init(r25663);
        mpfr_init(r25664);
        mpfr_init(r25665);
        mpfr_init(r25666);
        mpfr_init(r25667);
        mpfr_init(r25668);
        mpfr_init(r25669);
        mpfr_init(r25670);
        mpfr_init(r25671);
        mpfr_init(r25672);
        mpfr_init(r25673);
}

double f_dm(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25628, x, MPFR_RNDN);
        mpfr_set_d(r25629, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25631, t, MPFR_RNDN);
        mpfr_set_d(r25632, a, MPFR_RNDN);
        mpfr_add(r25633, r25631, r25632, MPFR_RNDN);
        mpfr_sqrt(r25634, r25633, MPFR_RNDN);
        mpfr_div(r25635, r25634, r25631, MPFR_RNDN);
        mpfr_set_d(r25636, z, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25639, r25637, r25638, MPFR_RNDN);
        mpfr_add(r25640, r25639, r25632, MPFR_RNDN);
        mpfr_set_d(r25641, c, MPFR_RNDN);
        mpfr_set_d(r25642, b, MPFR_RNDN);
        mpfr_sub(r25643, r25641, r25642, MPFR_RNDN);
        mpfr_mul(r25644, r25640, r25643, MPFR_RNDN);
        mpfr_fma(r25645, r25635, r25636, r25644, MPFR_RNDN);
        mpfr_sub(r25646, r25642, r25641, MPFR_RNDN);
        ;
        mpfr_mul(r25648, r25631, r25647, MPFR_RNDN);
        mpfr_div(r25649, r25630, r25648, MPFR_RNDN);
        mpfr_neg(r25650, r25649, MPFR_RNDN);
        mpfr_mul(r25651, r25646, r25650, MPFR_RNDN);
        mpfr_sub(r25652, r25645, r25651, MPFR_RNDN);
        mpfr_mul(r25653, r25630, r25652, MPFR_RNDN);
        mpfr_exp(r25654, r25653, MPFR_RNDN);
        mpfr_mul(r25655, r25629, r25654, MPFR_RNDN);
        mpfr_add(r25656, r25628, r25655, MPFR_RNDN);
        mpfr_div(r25657, r25628, r25656, MPFR_RNDN);
        ;
        mpfr_set_si(r25659, mpfr_cmp(r25657, r25658) <= 0, MPFR_RNDN);
        mpfr_mul(r25660, r25636, r25634, MPFR_RNDN);
        ;
        mpfr_div(r25662, r25661, r25631, MPFR_RNDN);
        mpfr_div(r25663, r25630, r25631, MPFR_RNDN);
        mpfr_div(r25664, r25663, r25647, MPFR_RNDN);
        mpfr_sub(r25665, r25640, r25664, MPFR_RNDN);
        mpfr_mul(r25666, r25665, r25643, MPFR_RNDN);
        mpfr_fma(r25667, r25660, r25662, r25666, MPFR_RNDN);
        mpfr_mul(r25668, r25630, r25667, MPFR_RNDN);
        mpfr_exp(r25669, r25668, MPFR_RNDN);
        mpfr_mul(r25670, r25629, r25669, MPFR_RNDN);
        mpfr_add(r25671, r25628, r25670, MPFR_RNDN);
        mpfr_div(r25672, r25628, r25671, MPFR_RNDN);
        if (mpfr_get_si(r25659, MPFR_RNDN)) { mpfr_set(r25673, r25657, MPFR_RNDN); } else { mpfr_set(r25673, r25672, MPFR_RNDN); };
        return mpfr_get_d(r25673, MPFR_RNDN);
}

