#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 r25330 = x;
        float r25331 = y;
        float r25332 = 2.0;
        float r25333 = z;
        float r25334 = t;
        float r25335 = a;
        float r25336 = r25334 + r25335;
        float r25337 = sqrt(r25336);
        float r25338 = r25333 * r25337;
        float r25339 = r25338 / r25334;
        float r25340 = b;
        float r25341 = c;
        float r25342 = r25340 - r25341;
        float r25343 = 5.0;
        float r25344 = 6.0;
        float r25345 = r25343 / r25344;
        float r25346 = r25335 + r25345;
        float r25347 = 3.0;
        float r25348 = r25334 * r25347;
        float r25349 = r25332 / r25348;
        float r25350 = r25346 - r25349;
        float r25351 = r25342 * r25350;
        float r25352 = r25339 - r25351;
        float r25353 = r25332 * r25352;
        float r25354 = exp(r25353);
        float r25355 = r25331 * r25354;
        float r25356 = r25330 + r25355;
        float r25357 = r25330 / r25356;
        return r25357;
}

double f_id(double x, double y, double z, double t, double a, double b, double c) {
        double r25358 = x;
        double r25359 = y;
        double r25360 = 2.0;
        double r25361 = z;
        double r25362 = t;
        double r25363 = a;
        double r25364 = r25362 + r25363;
        double r25365 = sqrt(r25364);
        double r25366 = r25361 * r25365;
        double r25367 = r25366 / r25362;
        double r25368 = b;
        double r25369 = c;
        double r25370 = r25368 - r25369;
        double r25371 = 5.0;
        double r25372 = 6.0;
        double r25373 = r25371 / r25372;
        double r25374 = r25363 + r25373;
        double r25375 = 3.0;
        double r25376 = r25362 * r25375;
        double r25377 = r25360 / r25376;
        double r25378 = r25374 - r25377;
        double r25379 = r25370 * r25378;
        double r25380 = r25367 - r25379;
        double r25381 = r25360 * r25380;
        double r25382 = exp(r25381);
        double r25383 = r25359 * r25382;
        double r25384 = r25358 + r25383;
        double r25385 = r25358 / r25384;
        return r25385;
}


double f_of(float x, float y, float z, float t, float a, float b, float c) {
        float r25386 = y;
        float r25387 = 2.0;
        float r25388 = z;
        float r25389 = t;
        float r25390 = a;
        float r25391 = r25389 + r25390;
        float r25392 = sqrt(r25391);
        float r25393 = r25389 / r25392;
        float r25394 = r25388 / r25393;
        float r25395 = b;
        float r25396 = c;
        float r25397 = r25395 - r25396;
        float r25398 = 5.0;
        float r25399 = 6.0;
        float r25400 = r25398 / r25399;
        float r25401 = r25390 + r25400;
        float r25402 = 3.0;
        float r25403 = r25389 * r25402;
        float r25404 = r25387 / r25403;
        float r25405 = r25401 - r25404;
        float r25406 = r25397 * r25405;
        float r25407 = r25394 - r25406;
        float r25408 = r25387 * r25407;
        float r25409 = exp(r25408);
        float r25410 = r25386 * r25409;
        float r25411 = 5.0183729110771386e-54;
        bool r25412 = r25410 <= r25411;
        float r25413 = x;
        float r25414 = r25413 + r25410;
        float r25415 = r25413 / r25414;
        float r25416 = 0;
        float r25417 = r25412 ? r25415 : r25416;
        return r25417;
}

double f_od(double x, double y, double z, double t, double a, double b, double c) {
        double r25418 = y;
        double r25419 = 2.0;
        double r25420 = z;
        double r25421 = t;
        double r25422 = a;
        double r25423 = r25421 + r25422;
        double r25424 = sqrt(r25423);
        double r25425 = r25421 / r25424;
        double r25426 = r25420 / r25425;
        double r25427 = b;
        double r25428 = c;
        double r25429 = r25427 - r25428;
        double r25430 = 5.0;
        double r25431 = 6.0;
        double r25432 = r25430 / r25431;
        double r25433 = r25422 + r25432;
        double r25434 = 3.0;
        double r25435 = r25421 * r25434;
        double r25436 = r25419 / r25435;
        double r25437 = r25433 - r25436;
        double r25438 = r25429 * r25437;
        double r25439 = r25426 - r25438;
        double r25440 = r25419 * r25439;
        double r25441 = exp(r25440);
        double r25442 = r25418 * r25441;
        double r25443 = 5.0183729110771386e-54;
        bool r25444 = r25442 <= r25443;
        double r25445 = x;
        double r25446 = r25445 + r25442;
        double r25447 = r25445 / r25446;
        double r25448 = 0;
        double r25449 = r25444 ? r25447 : r25448;
        return r25449;
}

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 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_im() {
        mpfr_set_default_prec(336);
        mpfr_init(r25450);
        mpfr_init(r25451);
        mpfr_init_set_str(r25452, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25453);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init(r25456);
        mpfr_init(r25457);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init(r25460);
        mpfr_init(r25461);
        mpfr_init(r25462);
        mpfr_init_set_str(r25463, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25464, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25465);
        mpfr_init(r25466);
        mpfr_init_set_str(r25467, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25468);
        mpfr_init(r25469);
        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_im(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25450, x, MPFR_RNDN);
        mpfr_set_d(r25451, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25453, z, MPFR_RNDN);
        mpfr_set_d(r25454, t, MPFR_RNDN);
        mpfr_set_d(r25455, a, MPFR_RNDN);
        mpfr_add(r25456, r25454, r25455, MPFR_RNDN);
        mpfr_sqrt(r25457, r25456, MPFR_RNDN);
        mpfr_mul(r25458, r25453, r25457, MPFR_RNDN);
        mpfr_div(r25459, r25458, r25454, MPFR_RNDN);
        mpfr_set_d(r25460, b, MPFR_RNDN);
        mpfr_set_d(r25461, c, MPFR_RNDN);
        mpfr_sub(r25462, r25460, r25461, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25465, r25463, r25464, MPFR_RNDN);
        mpfr_add(r25466, r25455, r25465, MPFR_RNDN);
        ;
        mpfr_mul(r25468, r25454, r25467, MPFR_RNDN);
        mpfr_div(r25469, r25452, r25468, MPFR_RNDN);
        mpfr_sub(r25470, r25466, r25469, MPFR_RNDN);
        mpfr_mul(r25471, r25462, r25470, MPFR_RNDN);
        mpfr_sub(r25472, r25459, r25471, MPFR_RNDN);
        mpfr_mul(r25473, r25452, r25472, MPFR_RNDN);
        mpfr_exp(r25474, r25473, MPFR_RNDN);
        mpfr_mul(r25475, r25451, r25474, MPFR_RNDN);
        mpfr_add(r25476, r25450, r25475, MPFR_RNDN);
        mpfr_div(r25477, r25450, 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;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25478);
        mpfr_init_set_str(r25479, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25480);
        mpfr_init(r25481);
        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_set_str(r25490, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25491, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init_set_str(r25494, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init_set_str(r25503, "5.0183729110771386e-54", 10, MPFR_RNDN);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init_set_str(r25508, "0", 10, MPFR_RNDN);
        mpfr_init(r25509);
}

double f_fm(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25478, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25480, z, MPFR_RNDN);
        mpfr_set_d(r25481, t, MPFR_RNDN);
        mpfr_set_d(r25482, a, MPFR_RNDN);
        mpfr_add(r25483, r25481, r25482, MPFR_RNDN);
        mpfr_sqrt(r25484, r25483, MPFR_RNDN);
        mpfr_div(r25485, r25481, r25484, MPFR_RNDN);
        mpfr_div(r25486, r25480, r25485, MPFR_RNDN);
        mpfr_set_d(r25487, b, MPFR_RNDN);
        mpfr_set_d(r25488, c, MPFR_RNDN);
        mpfr_sub(r25489, r25487, r25488, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25492, r25490, r25491, MPFR_RNDN);
        mpfr_add(r25493, r25482, r25492, MPFR_RNDN);
        ;
        mpfr_mul(r25495, r25481, r25494, MPFR_RNDN);
        mpfr_div(r25496, r25479, r25495, MPFR_RNDN);
        mpfr_sub(r25497, r25493, r25496, MPFR_RNDN);
        mpfr_mul(r25498, r25489, r25497, MPFR_RNDN);
        mpfr_sub(r25499, r25486, r25498, MPFR_RNDN);
        mpfr_mul(r25500, r25479, r25499, MPFR_RNDN);
        mpfr_exp(r25501, r25500, MPFR_RNDN);
        mpfr_mul(r25502, r25478, r25501, MPFR_RNDN);
        ;
        mpfr_set_si(r25504, mpfr_cmp(r25502, r25503) <= 0, MPFR_RNDN);
        mpfr_set_d(r25505, x, MPFR_RNDN);
        mpfr_add(r25506, r25505, r25502, MPFR_RNDN);
        mpfr_div(r25507, r25505, r25506, MPFR_RNDN);
        ;
        if (mpfr_get_si(r25504, MPFR_RNDN)) { mpfr_set(r25509, r25507, MPFR_RNDN); } else { mpfr_set(r25509, r25508, MPFR_RNDN); };
        return mpfr_get_d(r25509, MPFR_RNDN);
}

static mpfr_t 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, r25536, r25537, r25538, r25539, r25540, r25541;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25510);
        mpfr_init_set_str(r25511, "2.0", 10, MPFR_RNDN);
        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);
        mpfr_init_set_str(r25522, "5.0", 10, MPFR_RNDN);
        mpfr_init_set_str(r25523, "6.0", 10, MPFR_RNDN);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init_set_str(r25526, "3.0", 10, MPFR_RNDN);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init(r25529);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init_set_str(r25535, "5.0183729110771386e-54", 10, MPFR_RNDN);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init_set_str(r25540, "0", 10, MPFR_RNDN);
        mpfr_init(r25541);
}

double f_dm(double x, double y, double z, double t, double a, double b, double c) {
        mpfr_set_d(r25510, y, MPFR_RNDN);
        ;
        mpfr_set_d(r25512, z, MPFR_RNDN);
        mpfr_set_d(r25513, t, MPFR_RNDN);
        mpfr_set_d(r25514, a, MPFR_RNDN);
        mpfr_add(r25515, r25513, r25514, MPFR_RNDN);
        mpfr_sqrt(r25516, r25515, MPFR_RNDN);
        mpfr_div(r25517, r25513, r25516, MPFR_RNDN);
        mpfr_div(r25518, r25512, r25517, MPFR_RNDN);
        mpfr_set_d(r25519, b, MPFR_RNDN);
        mpfr_set_d(r25520, c, MPFR_RNDN);
        mpfr_sub(r25521, r25519, r25520, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25524, r25522, r25523, MPFR_RNDN);
        mpfr_add(r25525, r25514, r25524, MPFR_RNDN);
        ;
        mpfr_mul(r25527, r25513, r25526, MPFR_RNDN);
        mpfr_div(r25528, r25511, r25527, MPFR_RNDN);
        mpfr_sub(r25529, r25525, r25528, MPFR_RNDN);
        mpfr_mul(r25530, r25521, r25529, MPFR_RNDN);
        mpfr_sub(r25531, r25518, r25530, MPFR_RNDN);
        mpfr_mul(r25532, r25511, r25531, MPFR_RNDN);
        mpfr_exp(r25533, r25532, MPFR_RNDN);
        mpfr_mul(r25534, r25510, r25533, MPFR_RNDN);
        ;
        mpfr_set_si(r25536, mpfr_cmp(r25534, r25535) <= 0, MPFR_RNDN);
        mpfr_set_d(r25537, x, MPFR_RNDN);
        mpfr_add(r25538, r25537, r25534, MPFR_RNDN);
        mpfr_div(r25539, r25537, r25538, MPFR_RNDN);
        ;
        if (mpfr_get_si(r25536, MPFR_RNDN)) { mpfr_set(r25541, r25539, MPFR_RNDN); } else { mpfr_set(r25541, r25540, MPFR_RNDN); };
        return mpfr_get_d(r25541, MPFR_RNDN);
}

