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

char *name = "Jmat.Real.erf";

double f_if(float x) {
        float r25335 = 1;
        float r25336 = 0.3275911;
        float r25337 = x;
        float r25338 = fabs(r25337);
        float r25339 = r25336 * r25338;
        float r25340 = r25335 + r25339;
        float r25341 = r25335 / r25340;
        float r25342 = 0.254829592;
        float r25343 = -0.284496736;
        float r25344 = 1.421413741;
        float r25345 = -1.453152027;
        float r25346 = 1.061405429;
        float r25347 = r25341 * r25346;
        float r25348 = r25345 + r25347;
        float r25349 = r25341 * r25348;
        float r25350 = r25344 + r25349;
        float r25351 = r25341 * r25350;
        float r25352 = r25343 + r25351;
        float r25353 = r25341 * r25352;
        float r25354 = r25342 + r25353;
        float r25355 = r25341 * r25354;
        float r25356 = r25338 * r25338;
        float r25357 = -r25356;
        float r25358 = exp(r25357);
        float r25359 = r25355 * r25358;
        float r25360 = r25335 - r25359;
        return r25360;
}

double f_id(double x) {
        double r25361 = 1;
        double r25362 = 0.3275911;
        double r25363 = x;
        double r25364 = fabs(r25363);
        double r25365 = r25362 * r25364;
        double r25366 = r25361 + r25365;
        double r25367 = r25361 / r25366;
        double r25368 = 0.254829592;
        double r25369 = -0.284496736;
        double r25370 = 1.421413741;
        double r25371 = -1.453152027;
        double r25372 = 1.061405429;
        double r25373 = r25367 * r25372;
        double r25374 = r25371 + r25373;
        double r25375 = r25367 * r25374;
        double r25376 = r25370 + r25375;
        double r25377 = r25367 * r25376;
        double r25378 = r25369 + r25377;
        double r25379 = r25367 * r25378;
        double r25380 = r25368 + r25379;
        double r25381 = r25367 * r25380;
        double r25382 = r25364 * r25364;
        double r25383 = -r25382;
        double r25384 = exp(r25383);
        double r25385 = r25381 * r25384;
        double r25386 = r25361 - r25385;
        return r25386;
}


double f_of(float x) {
        float r25387 = 1;
        float r25388 = 0.3275911;
        float r25389 = x;
        float r25390 = fabs(r25389);
        float r25391 = r25388 * r25390;
        float r25392 = r25387 + r25391;
        float r25393 = r25387 / r25392;
        float r25394 = 0.254829592;
        float r25395 = 1.421413741;
        float r25396 = r25395 / r25392;
        float r25397 = -0.284496736;
        float r25398 = r25396 + r25397;
        float r25399 = 1.061405429;
        float r25400 = r25399 / r25392;
        float r25401 = -1.453152027;
        float r25402 = r25400 + r25401;
        float r25403 = r25393 * r25393;
        float r25404 = r25402 * r25403;
        float r25405 = r25398 + r25404;
        float r25406 = 3;
        float r25407 = pow(r25405, r25406);
        float r25408 = cbrt(r25407);
        float r25409 = r25393 * r25408;
        float r25410 = r25394 + r25409;
        float r25411 = r25393 * r25410;
        float r25412 = r25390 * r25390;
        float r25413 = -r25412;
        float r25414 = exp(r25413);
        float r25415 = r25411 * r25414;
        float r25416 = r25387 - r25415;
        float r25417 = cbrt(r25416);
        float r25418 = r25417 * r25417;
        float r25419 = r25390 * r25388;
        float r25420 = r25419 + r25387;
        float r25421 = r25420 * r25420;
        float r25422 = r25387 / r25421;
        float r25423 = r25399 / r25420;
        float r25424 = r25401 + r25423;
        float r25425 = r25422 * r25424;
        float r25426 = r25425 / r25420;
        float r25427 = r25395 / r25420;
        float r25428 = r25427 + r25397;
        float r25429 = r25428 / r25420;
        float r25430 = r25429 + r25394;
        float r25431 = r25426 + r25430;
        float r25432 = r25387 / r25420;
        float r25433 = exp(r25412);
        float r25434 = r25432 / r25433;
        float r25435 = r25431 * r25434;
        float r25436 = r25387 - r25435;
        float r25437 = cbrt(r25436);
        float r25438 = r25418 * r25437;
        float r25439 = cbrt(r25438);
        float r25440 = r25417 * r25439;
        float r25441 = r25440 * r25437;
        float r25442 = cbrt(r25441);
        float r25443 = r25417 * r25442;
        float r25444 = r25443 * r25437;
        return r25444;
}

double f_od(double x) {
        double r25445 = 1;
        double r25446 = 0.3275911;
        double r25447 = x;
        double r25448 = fabs(r25447);
        double r25449 = r25446 * r25448;
        double r25450 = r25445 + r25449;
        double r25451 = r25445 / r25450;
        double r25452 = 0.254829592;
        double r25453 = 1.421413741;
        double r25454 = r25453 / r25450;
        double r25455 = -0.284496736;
        double r25456 = r25454 + r25455;
        double r25457 = 1.061405429;
        double r25458 = r25457 / r25450;
        double r25459 = -1.453152027;
        double r25460 = r25458 + r25459;
        double r25461 = r25451 * r25451;
        double r25462 = r25460 * r25461;
        double r25463 = r25456 + r25462;
        double r25464 = 3;
        double r25465 = pow(r25463, r25464);
        double r25466 = cbrt(r25465);
        double r25467 = r25451 * r25466;
        double r25468 = r25452 + r25467;
        double r25469 = r25451 * r25468;
        double r25470 = r25448 * r25448;
        double r25471 = -r25470;
        double r25472 = exp(r25471);
        double r25473 = r25469 * r25472;
        double r25474 = r25445 - r25473;
        double r25475 = cbrt(r25474);
        double r25476 = r25475 * r25475;
        double r25477 = r25448 * r25446;
        double r25478 = r25477 + r25445;
        double r25479 = r25478 * r25478;
        double r25480 = r25445 / r25479;
        double r25481 = r25457 / r25478;
        double r25482 = r25459 + r25481;
        double r25483 = r25480 * r25482;
        double r25484 = r25483 / r25478;
        double r25485 = r25453 / r25478;
        double r25486 = r25485 + r25455;
        double r25487 = r25486 / r25478;
        double r25488 = r25487 + r25452;
        double r25489 = r25484 + r25488;
        double r25490 = r25445 / r25478;
        double r25491 = exp(r25470);
        double r25492 = r25490 / r25491;
        double r25493 = r25489 * r25492;
        double r25494 = r25445 - r25493;
        double r25495 = cbrt(r25494);
        double r25496 = r25476 * r25495;
        double r25497 = cbrt(r25496);
        double r25498 = r25475 * r25497;
        double r25499 = r25498 * r25495;
        double r25500 = cbrt(r25499);
        double r25501 = r25475 * r25500;
        double r25502 = r25501 * r25495;
        return r25502;
}

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

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25503, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25504, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init(r25509);
        mpfr_init_set_str(r25510, "0.254829592", 10, MPFR_RNDN);
        mpfr_init_set_str(r25511, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init_set_str(r25512, "1.421413741", 10, MPFR_RNDN);
        mpfr_init_set_str(r25513, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init_set_str(r25514, "1.061405429", 10, MPFR_RNDN);
        mpfr_init(r25515);
        mpfr_init(r25516);
        mpfr_init(r25517);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
}

double f_im(double x) {
        ;
        ;
        mpfr_set_d(r25505, x, MPFR_RNDN);
        mpfr_abs(r25506, r25505, MPFR_RNDN);
        mpfr_mul(r25507, r25504, r25506, MPFR_RNDN);
        mpfr_add(r25508, r25503, r25507, MPFR_RNDN);
        mpfr_div(r25509, r25503, r25508, MPFR_RNDN);
        ;
        ;
        ;
        ;
        ;
        mpfr_mul(r25515, r25509, r25514, MPFR_RNDN);
        mpfr_add(r25516, r25513, r25515, MPFR_RNDN);
        mpfr_mul(r25517, r25509, r25516, MPFR_RNDN);
        mpfr_add(r25518, r25512, r25517, MPFR_RNDN);
        mpfr_mul(r25519, r25509, r25518, MPFR_RNDN);
        mpfr_add(r25520, r25511, r25519, MPFR_RNDN);
        mpfr_mul(r25521, r25509, r25520, MPFR_RNDN);
        mpfr_add(r25522, r25510, r25521, MPFR_RNDN);
        mpfr_mul(r25523, r25509, r25522, MPFR_RNDN);
        mpfr_mul(r25524, r25506, r25506, MPFR_RNDN);
        mpfr_neg(r25525, r25524, MPFR_RNDN);
        mpfr_exp(r25526, r25525, MPFR_RNDN);
        mpfr_mul(r25527, r25523, r25526, MPFR_RNDN);
        mpfr_sub(r25528, r25503, r25527, MPFR_RNDN);
        return mpfr_get_d(r25528, MPFR_RNDN);
}

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

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25529, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25530, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init(r25535);
        mpfr_init_set_str(r25536, "0.254829592", 10, MPFR_RNDN);
        mpfr_init_set_str(r25537, "1.421413741", 10, MPFR_RNDN);
        mpfr_init(r25538);
        mpfr_init_set_str(r25539, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25540);
        mpfr_init_set_str(r25541, "1.061405429", 10, MPFR_RNDN);
        mpfr_init(r25542);
        mpfr_init_set_str(r25543, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init(r25546);
        mpfr_init(r25547);
        mpfr_init_set_str(r25548, "3", 10, MPFR_RNDN);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
        mpfr_init(r25552);
        mpfr_init(r25553);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init(r25556);
        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(r25567);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init(r25571);
        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);
        mpfr_init(r25582);
        mpfr_init(r25583);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init(r25586);
}

double f_fm(double x) {
        ;
        ;
        mpfr_set_d(r25531, x, MPFR_RNDN);
        mpfr_abs(r25532, r25531, MPFR_RNDN);
        mpfr_mul(r25533, r25530, r25532, MPFR_RNDN);
        mpfr_add(r25534, r25529, r25533, MPFR_RNDN);
        mpfr_div(r25535, r25529, r25534, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25538, r25537, r25534, MPFR_RNDN);
        ;
        mpfr_add(r25540, r25538, r25539, MPFR_RNDN);
        ;
        mpfr_div(r25542, r25541, r25534, MPFR_RNDN);
        ;
        mpfr_add(r25544, r25542, r25543, MPFR_RNDN);
        mpfr_mul(r25545, r25535, r25535, MPFR_RNDN);
        mpfr_mul(r25546, r25544, r25545, MPFR_RNDN);
        mpfr_add(r25547, r25540, r25546, MPFR_RNDN);
        ;
        mpfr_pow(r25549, r25547, r25548, MPFR_RNDN);
        mpfr_cbrt(r25550, r25549, MPFR_RNDN);
        mpfr_mul(r25551, r25535, r25550, MPFR_RNDN);
        mpfr_add(r25552, r25536, r25551, MPFR_RNDN);
        mpfr_mul(r25553, r25535, r25552, MPFR_RNDN);
        mpfr_mul(r25554, r25532, r25532, MPFR_RNDN);
        mpfr_neg(r25555, r25554, MPFR_RNDN);
        mpfr_exp(r25556, r25555, MPFR_RNDN);
        mpfr_mul(r25557, r25553, r25556, MPFR_RNDN);
        mpfr_sub(r25558, r25529, r25557, MPFR_RNDN);
        mpfr_cbrt(r25559, r25558, MPFR_RNDN);
        mpfr_mul(r25560, r25559, r25559, MPFR_RNDN);
        mpfr_mul(r25561, r25532, r25530, MPFR_RNDN);
        mpfr_add(r25562, r25561, r25529, MPFR_RNDN);
        mpfr_mul(r25563, r25562, r25562, MPFR_RNDN);
        mpfr_div(r25564, r25529, r25563, MPFR_RNDN);
        mpfr_div(r25565, r25541, r25562, MPFR_RNDN);
        mpfr_add(r25566, r25543, r25565, MPFR_RNDN);
        mpfr_mul(r25567, r25564, r25566, MPFR_RNDN);
        mpfr_div(r25568, r25567, r25562, MPFR_RNDN);
        mpfr_div(r25569, r25537, r25562, MPFR_RNDN);
        mpfr_add(r25570, r25569, r25539, MPFR_RNDN);
        mpfr_div(r25571, r25570, r25562, MPFR_RNDN);
        mpfr_add(r25572, r25571, r25536, MPFR_RNDN);
        mpfr_add(r25573, r25568, r25572, MPFR_RNDN);
        mpfr_div(r25574, r25529, r25562, MPFR_RNDN);
        mpfr_exp(r25575, r25554, MPFR_RNDN);
        mpfr_div(r25576, r25574, r25575, MPFR_RNDN);
        mpfr_mul(r25577, r25573, r25576, MPFR_RNDN);
        mpfr_sub(r25578, r25529, r25577, MPFR_RNDN);
        mpfr_cbrt(r25579, r25578, MPFR_RNDN);
        mpfr_mul(r25580, r25560, r25579, MPFR_RNDN);
        mpfr_cbrt(r25581, r25580, MPFR_RNDN);
        mpfr_mul(r25582, r25559, r25581, MPFR_RNDN);
        mpfr_mul(r25583, r25582, r25579, MPFR_RNDN);
        mpfr_cbrt(r25584, r25583, MPFR_RNDN);
        mpfr_mul(r25585, r25559, r25584, MPFR_RNDN);
        mpfr_mul(r25586, r25585, r25579, MPFR_RNDN);
        return mpfr_get_d(r25586, MPFR_RNDN);
}

static mpfr_t 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, r25628, r25629, r25630, r25631, r25632, r25633, r25634, r25635, r25636, r25637, r25638, r25639, r25640, r25641, r25642, r25643, r25644;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25587, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25588, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init(r25591);
        mpfr_init(r25592);
        mpfr_init(r25593);
        mpfr_init_set_str(r25594, "0.254829592", 10, MPFR_RNDN);
        mpfr_init_set_str(r25595, "1.421413741", 10, MPFR_RNDN);
        mpfr_init(r25596);
        mpfr_init_set_str(r25597, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25598);
        mpfr_init_set_str(r25599, "1.061405429", 10, MPFR_RNDN);
        mpfr_init(r25600);
        mpfr_init_set_str(r25601, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init(r25602);
        mpfr_init(r25603);
        mpfr_init(r25604);
        mpfr_init(r25605);
        mpfr_init_set_str(r25606, "3", 10, MPFR_RNDN);
        mpfr_init(r25607);
        mpfr_init(r25608);
        mpfr_init(r25609);
        mpfr_init(r25610);
        mpfr_init(r25611);
        mpfr_init(r25612);
        mpfr_init(r25613);
        mpfr_init(r25614);
        mpfr_init(r25615);
        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);
        mpfr_init(r25628);
        mpfr_init(r25629);
        mpfr_init(r25630);
        mpfr_init(r25631);
        mpfr_init(r25632);
        mpfr_init(r25633);
        mpfr_init(r25634);
        mpfr_init(r25635);
        mpfr_init(r25636);
        mpfr_init(r25637);
        mpfr_init(r25638);
        mpfr_init(r25639);
        mpfr_init(r25640);
        mpfr_init(r25641);
        mpfr_init(r25642);
        mpfr_init(r25643);
        mpfr_init(r25644);
}

double f_dm(double x) {
        ;
        ;
        mpfr_set_d(r25589, x, MPFR_RNDN);
        mpfr_abs(r25590, r25589, MPFR_RNDN);
        mpfr_mul(r25591, r25588, r25590, MPFR_RNDN);
        mpfr_add(r25592, r25587, r25591, MPFR_RNDN);
        mpfr_div(r25593, r25587, r25592, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25596, r25595, r25592, MPFR_RNDN);
        ;
        mpfr_add(r25598, r25596, r25597, MPFR_RNDN);
        ;
        mpfr_div(r25600, r25599, r25592, MPFR_RNDN);
        ;
        mpfr_add(r25602, r25600, r25601, MPFR_RNDN);
        mpfr_mul(r25603, r25593, r25593, MPFR_RNDN);
        mpfr_mul(r25604, r25602, r25603, MPFR_RNDN);
        mpfr_add(r25605, r25598, r25604, MPFR_RNDN);
        ;
        mpfr_pow(r25607, r25605, r25606, MPFR_RNDN);
        mpfr_cbrt(r25608, r25607, MPFR_RNDN);
        mpfr_mul(r25609, r25593, r25608, MPFR_RNDN);
        mpfr_add(r25610, r25594, r25609, MPFR_RNDN);
        mpfr_mul(r25611, r25593, r25610, MPFR_RNDN);
        mpfr_mul(r25612, r25590, r25590, MPFR_RNDN);
        mpfr_neg(r25613, r25612, MPFR_RNDN);
        mpfr_exp(r25614, r25613, MPFR_RNDN);
        mpfr_mul(r25615, r25611, r25614, MPFR_RNDN);
        mpfr_sub(r25616, r25587, r25615, MPFR_RNDN);
        mpfr_cbrt(r25617, r25616, MPFR_RNDN);
        mpfr_mul(r25618, r25617, r25617, MPFR_RNDN);
        mpfr_mul(r25619, r25590, r25588, MPFR_RNDN);
        mpfr_add(r25620, r25619, r25587, MPFR_RNDN);
        mpfr_mul(r25621, r25620, r25620, MPFR_RNDN);
        mpfr_div(r25622, r25587, r25621, MPFR_RNDN);
        mpfr_div(r25623, r25599, r25620, MPFR_RNDN);
        mpfr_add(r25624, r25601, r25623, MPFR_RNDN);
        mpfr_mul(r25625, r25622, r25624, MPFR_RNDN);
        mpfr_div(r25626, r25625, r25620, MPFR_RNDN);
        mpfr_div(r25627, r25595, r25620, MPFR_RNDN);
        mpfr_add(r25628, r25627, r25597, MPFR_RNDN);
        mpfr_div(r25629, r25628, r25620, MPFR_RNDN);
        mpfr_add(r25630, r25629, r25594, MPFR_RNDN);
        mpfr_add(r25631, r25626, r25630, MPFR_RNDN);
        mpfr_div(r25632, r25587, r25620, MPFR_RNDN);
        mpfr_exp(r25633, r25612, MPFR_RNDN);
        mpfr_div(r25634, r25632, r25633, MPFR_RNDN);
        mpfr_mul(r25635, r25631, r25634, MPFR_RNDN);
        mpfr_sub(r25636, r25587, r25635, MPFR_RNDN);
        mpfr_cbrt(r25637, r25636, MPFR_RNDN);
        mpfr_mul(r25638, r25618, r25637, MPFR_RNDN);
        mpfr_cbrt(r25639, r25638, MPFR_RNDN);
        mpfr_mul(r25640, r25617, r25639, MPFR_RNDN);
        mpfr_mul(r25641, r25640, r25637, MPFR_RNDN);
        mpfr_cbrt(r25642, r25641, MPFR_RNDN);
        mpfr_mul(r25643, r25617, r25642, MPFR_RNDN);
        mpfr_mul(r25644, r25643, r25637, MPFR_RNDN);
        return mpfr_get_d(r25644, MPFR_RNDN);
}

