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

char *name = "Jmat.Real.erfi, branch x greater than or equal to 5";

double f_if(float x) {
        float r25356 = 1;
        float r25357 = atan2(1.0, 0.0);
        float r25358 = sqrt(r25357);
        float r25359 = r25356 / r25358;
        float r25360 = x;
        float r25361 = fabs(r25360);
        float r25362 = r25361 * r25361;
        float r25363 = exp(r25362);
        float r25364 = r25359 * r25363;
        float r25365 = r25356 / r25361;
        float r25366 = 2;
        float r25367 = r25356 / r25366;
        float r25368 = r25365 * r25365;
        float r25369 = r25368 * r25365;
        float r25370 = r25367 * r25369;
        float r25371 = r25365 + r25370;
        float r25372 = 3;
        float r25373 = 4;
        float r25374 = r25372 / r25373;
        float r25375 = r25369 * r25365;
        float r25376 = r25375 * r25365;
        float r25377 = r25374 * r25376;
        float r25378 = r25371 + r25377;
        float r25379 = 15;
        float r25380 = 8;
        float r25381 = r25379 / r25380;
        float r25382 = r25376 * r25365;
        float r25383 = r25382 * r25365;
        float r25384 = r25381 * r25383;
        float r25385 = r25378 + r25384;
        float r25386 = r25364 * r25385;
        return r25386;
}

double f_id(double x) {
        double r25387 = 1;
        double r25388 = atan2(1.0, 0.0);
        double r25389 = sqrt(r25388);
        double r25390 = r25387 / r25389;
        double r25391 = x;
        double r25392 = fabs(r25391);
        double r25393 = r25392 * r25392;
        double r25394 = exp(r25393);
        double r25395 = r25390 * r25394;
        double r25396 = r25387 / r25392;
        double r25397 = 2;
        double r25398 = r25387 / r25397;
        double r25399 = r25396 * r25396;
        double r25400 = r25399 * r25396;
        double r25401 = r25398 * r25400;
        double r25402 = r25396 + r25401;
        double r25403 = 3;
        double r25404 = 4;
        double r25405 = r25403 / r25404;
        double r25406 = r25400 * r25396;
        double r25407 = r25406 * r25396;
        double r25408 = r25405 * r25407;
        double r25409 = r25402 + r25408;
        double r25410 = 15;
        double r25411 = 8;
        double r25412 = r25410 / r25411;
        double r25413 = r25407 * r25396;
        double r25414 = r25413 * r25396;
        double r25415 = r25412 * r25414;
        double r25416 = r25409 + r25415;
        double r25417 = r25395 * r25416;
        return r25417;
}


double f_of(float x) {
        float r25418 = x;
        float r25419 = fabs(r25418);
        float r25420 = r25419 * r25419;
        float r25421 = exp(r25420);
        float r25422 = 1;
        float r25423 = atan2(1.0, 0.0);
        float r25424 = sqrt(r25423);
        float r25425 = r25419 * r25424;
        float r25426 = r25422 / r25425;
        float r25427 = r25422 / r25419;
        float r25428 = 2;
        float r25429 = r25419 * r25428;
        float r25430 = r25427 / r25429;
        float r25431 = 3;
        float r25432 = 4;
        float r25433 = r25431 / r25432;
        float r25434 = r25433 / r25419;
        float r25435 = pow(r25419, r25431);
        float r25436 = r25434 / r25435;
        float r25437 = r25430 + r25436;
        float r25438 = r25426 * r25437;
        float r25439 = -1;
        float r25440 = r25439 - r25431;
        float r25441 = pow(r25419, r25440);
        float r25442 = r25441 / r25419;
        float r25443 = 15;
        float r25444 = 8;
        float r25445 = r25443 / r25444;
        float r25446 = sqrt(r25424);
        float r25447 = r25446 * r25446;
        float r25448 = r25445 / r25447;
        float r25449 = r25420 / r25448;
        float r25450 = r25442 / r25449;
        float r25451 = r25426 + r25450;
        float r25452 = r25438 + r25451;
        float r25453 = r25421 * r25452;
        return r25453;
}

double f_od(double x) {
        double r25454 = x;
        double r25455 = fabs(r25454);
        double r25456 = r25455 * r25455;
        double r25457 = exp(r25456);
        double r25458 = 1;
        double r25459 = atan2(1.0, 0.0);
        double r25460 = sqrt(r25459);
        double r25461 = r25455 * r25460;
        double r25462 = r25458 / r25461;
        double r25463 = r25458 / r25455;
        double r25464 = 2;
        double r25465 = r25455 * r25464;
        double r25466 = r25463 / r25465;
        double r25467 = 3;
        double r25468 = 4;
        double r25469 = r25467 / r25468;
        double r25470 = r25469 / r25455;
        double r25471 = pow(r25455, r25467);
        double r25472 = r25470 / r25471;
        double r25473 = r25466 + r25472;
        double r25474 = r25462 * r25473;
        double r25475 = -1;
        double r25476 = r25475 - r25467;
        double r25477 = pow(r25455, r25476);
        double r25478 = r25477 / r25455;
        double r25479 = 15;
        double r25480 = 8;
        double r25481 = r25479 / r25480;
        double r25482 = sqrt(r25460);
        double r25483 = r25482 * r25482;
        double r25484 = r25481 / r25483;
        double r25485 = r25456 / r25484;
        double r25486 = r25478 / r25485;
        double r25487 = r25462 + r25486;
        double r25488 = r25474 + r25487;
        double r25489 = r25457 * r25488;
        return r25489;
}

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

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25490, "1", 10, MPFR_RNDN);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init_set_str(r25500, "2", 10, MPFR_RNDN);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init_set_str(r25506, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r25507, "4", 10, MPFR_RNDN);
        mpfr_init(r25508);
        mpfr_init(r25509);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init_set_str(r25513, "15", 10, MPFR_RNDN);
        mpfr_init_set_str(r25514, "8", 10, MPFR_RNDN);
        mpfr_init(r25515);
        mpfr_init(r25516);
        mpfr_init(r25517);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init(r25520);
}

double f_im(double x) {
        ;
        mpfr_const_pi(r25491, MPFR_RNDN);
        mpfr_sqrt(r25492, r25491, MPFR_RNDN);
        mpfr_div(r25493, r25490, r25492, MPFR_RNDN);
        mpfr_set_d(r25494, x, MPFR_RNDN);
        mpfr_abs(r25495, r25494, MPFR_RNDN);
        mpfr_mul(r25496, r25495, r25495, MPFR_RNDN);
        mpfr_exp(r25497, r25496, MPFR_RNDN);
        mpfr_mul(r25498, r25493, r25497, MPFR_RNDN);
        mpfr_div(r25499, r25490, r25495, MPFR_RNDN);
        ;
        mpfr_div(r25501, r25490, r25500, MPFR_RNDN);
        mpfr_mul(r25502, r25499, r25499, MPFR_RNDN);
        mpfr_mul(r25503, r25502, r25499, MPFR_RNDN);
        mpfr_mul(r25504, r25501, r25503, MPFR_RNDN);
        mpfr_add(r25505, r25499, r25504, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25508, r25506, r25507, MPFR_RNDN);
        mpfr_mul(r25509, r25503, r25499, MPFR_RNDN);
        mpfr_mul(r25510, r25509, r25499, MPFR_RNDN);
        mpfr_mul(r25511, r25508, r25510, MPFR_RNDN);
        mpfr_add(r25512, r25505, r25511, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25515, r25513, r25514, MPFR_RNDN);
        mpfr_mul(r25516, r25510, r25499, MPFR_RNDN);
        mpfr_mul(r25517, r25516, r25499, MPFR_RNDN);
        mpfr_mul(r25518, r25515, r25517, MPFR_RNDN);
        mpfr_add(r25519, r25512, r25518, MPFR_RNDN);
        mpfr_mul(r25520, r25498, r25519, MPFR_RNDN);
        return mpfr_get_d(r25520, MPFR_RNDN);
}

static mpfr_t 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, r25552, r25553, r25554, r25555, r25556;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init_set_str(r25525, "1", 10, MPFR_RNDN);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init(r25529);
        mpfr_init(r25530);
        mpfr_init_set_str(r25531, "2", 10, MPFR_RNDN);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init_set_str(r25534, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r25535, "4", 10, MPFR_RNDN);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init_set_str(r25542, "-1", 10, MPFR_RNDN);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init_set_str(r25546, "15", 10, MPFR_RNDN);
        mpfr_init_set_str(r25547, "8", 10, MPFR_RNDN);
        mpfr_init(r25548);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
        mpfr_init(r25552);
        mpfr_init(r25553);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init(r25556);
}

double f_fm(double x) {
        mpfr_set_d(r25521, x, MPFR_RNDN);
        mpfr_abs(r25522, r25521, MPFR_RNDN);
        mpfr_mul(r25523, r25522, r25522, MPFR_RNDN);
        mpfr_exp(r25524, r25523, MPFR_RNDN);
        ;
        mpfr_const_pi(r25526, MPFR_RNDN);
        mpfr_sqrt(r25527, r25526, MPFR_RNDN);
        mpfr_mul(r25528, r25522, r25527, MPFR_RNDN);
        mpfr_div(r25529, r25525, r25528, MPFR_RNDN);
        mpfr_div(r25530, r25525, r25522, MPFR_RNDN);
        ;
        mpfr_mul(r25532, r25522, r25531, MPFR_RNDN);
        mpfr_div(r25533, r25530, r25532, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25536, r25534, r25535, MPFR_RNDN);
        mpfr_div(r25537, r25536, r25522, MPFR_RNDN);
        mpfr_pow(r25538, r25522, r25534, MPFR_RNDN);
        mpfr_div(r25539, r25537, r25538, MPFR_RNDN);
        mpfr_add(r25540, r25533, r25539, MPFR_RNDN);
        mpfr_mul(r25541, r25529, r25540, MPFR_RNDN);
        ;
        mpfr_sub(r25543, r25542, r25534, MPFR_RNDN);
        mpfr_pow(r25544, r25522, r25543, MPFR_RNDN);
        mpfr_div(r25545, r25544, r25522, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25548, r25546, r25547, MPFR_RNDN);
        mpfr_sqrt(r25549, r25527, MPFR_RNDN);
        mpfr_mul(r25550, r25549, r25549, MPFR_RNDN);
        mpfr_div(r25551, r25548, r25550, MPFR_RNDN);
        mpfr_div(r25552, r25523, r25551, MPFR_RNDN);
        mpfr_div(r25553, r25545, r25552, MPFR_RNDN);
        mpfr_add(r25554, r25529, r25553, MPFR_RNDN);
        mpfr_add(r25555, r25541, r25554, MPFR_RNDN);
        mpfr_mul(r25556, r25524, r25555, MPFR_RNDN);
        return mpfr_get_d(r25556, MPFR_RNDN);
}

static mpfr_t 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, r25582, r25583, r25584, r25585, r25586, r25587, r25588, r25589, r25590, r25591, r25592;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
        mpfr_init(r25560);
        mpfr_init_set_str(r25561, "1", 10, MPFR_RNDN);
        mpfr_init(r25562);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init_set_str(r25567, "2", 10, MPFR_RNDN);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init_set_str(r25570, "3", 10, MPFR_RNDN);
        mpfr_init_set_str(r25571, "4", 10, MPFR_RNDN);
        mpfr_init(r25572);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init(r25576);
        mpfr_init(r25577);
        mpfr_init_set_str(r25578, "-1", 10, MPFR_RNDN);
        mpfr_init(r25579);
        mpfr_init(r25580);
        mpfr_init(r25581);
        mpfr_init_set_str(r25582, "15", 10, MPFR_RNDN);
        mpfr_init_set_str(r25583, "8", 10, MPFR_RNDN);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init(r25586);
        mpfr_init(r25587);
        mpfr_init(r25588);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init(r25591);
        mpfr_init(r25592);
}

double f_dm(double x) {
        mpfr_set_d(r25557, x, MPFR_RNDN);
        mpfr_abs(r25558, r25557, MPFR_RNDN);
        mpfr_mul(r25559, r25558, r25558, MPFR_RNDN);
        mpfr_exp(r25560, r25559, MPFR_RNDN);
        ;
        mpfr_const_pi(r25562, MPFR_RNDN);
        mpfr_sqrt(r25563, r25562, MPFR_RNDN);
        mpfr_mul(r25564, r25558, r25563, MPFR_RNDN);
        mpfr_div(r25565, r25561, r25564, MPFR_RNDN);
        mpfr_div(r25566, r25561, r25558, MPFR_RNDN);
        ;
        mpfr_mul(r25568, r25558, r25567, MPFR_RNDN);
        mpfr_div(r25569, r25566, r25568, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25572, r25570, r25571, MPFR_RNDN);
        mpfr_div(r25573, r25572, r25558, MPFR_RNDN);
        mpfr_pow(r25574, r25558, r25570, MPFR_RNDN);
        mpfr_div(r25575, r25573, r25574, MPFR_RNDN);
        mpfr_add(r25576, r25569, r25575, MPFR_RNDN);
        mpfr_mul(r25577, r25565, r25576, MPFR_RNDN);
        ;
        mpfr_sub(r25579, r25578, r25570, MPFR_RNDN);
        mpfr_pow(r25580, r25558, r25579, MPFR_RNDN);
        mpfr_div(r25581, r25580, r25558, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25584, r25582, r25583, MPFR_RNDN);
        mpfr_sqrt(r25585, r25563, MPFR_RNDN);
        mpfr_mul(r25586, r25585, r25585, MPFR_RNDN);
        mpfr_div(r25587, r25584, r25586, MPFR_RNDN);
        mpfr_div(r25588, r25559, r25587, MPFR_RNDN);
        mpfr_div(r25589, r25581, r25588, MPFR_RNDN);
        mpfr_add(r25590, r25565, r25589, MPFR_RNDN);
        mpfr_add(r25591, r25577, r25590, MPFR_RNDN);
        mpfr_mul(r25592, r25560, r25591, MPFR_RNDN);
        return mpfr_get_d(r25592, MPFR_RNDN);
}

