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

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

double f_if(float x) {
        float r25234 = 1;
        float r25235 = 0.1049934947;
        float r25236 = x;
        float r25237 = r25236 * r25236;
        float r25238 = r25235 * r25237;
        float r25239 = r25234 + r25238;
        float r25240 = 0.0424060604;
        float r25241 = r25237 * r25237;
        float r25242 = r25240 * r25241;
        float r25243 = r25239 + r25242;
        float r25244 = 0.0072644182;
        float r25245 = r25241 * r25237;
        float r25246 = r25244 * r25245;
        float r25247 = r25243 + r25246;
        float r25248 = 0.0005064034;
        float r25249 = r25245 * r25237;
        float r25250 = r25248 * r25249;
        float r25251 = r25247 + r25250;
        float r25252 = 0.0001789971;
        float r25253 = r25249 * r25237;
        float r25254 = r25252 * r25253;
        float r25255 = r25251 + r25254;
        float r25256 = 0.7715471019;
        float r25257 = r25256 * r25237;
        float r25258 = r25234 + r25257;
        float r25259 = 0.2909738639;
        float r25260 = r25259 * r25241;
        float r25261 = r25258 + r25260;
        float r25262 = 0.0694555761;
        float r25263 = r25262 * r25245;
        float r25264 = r25261 + r25263;
        float r25265 = 0.0140005442;
        float r25266 = r25265 * r25249;
        float r25267 = r25264 + r25266;
        float r25268 = 0.0008327945;
        float r25269 = r25268 * r25253;
        float r25270 = r25267 + r25269;
        float r25271 = 2;
        float r25272 = r25271 * r25252;
        float r25273 = r25253 * r25237;
        float r25274 = r25272 * r25273;
        float r25275 = r25270 + r25274;
        float r25276 = r25255 / r25275;
        float r25277 = r25276 * r25236;
        return r25277;
}

double f_id(double x) {
        double r25278 = 1;
        double r25279 = 0.1049934947;
        double r25280 = x;
        double r25281 = r25280 * r25280;
        double r25282 = r25279 * r25281;
        double r25283 = r25278 + r25282;
        double r25284 = 0.0424060604;
        double r25285 = r25281 * r25281;
        double r25286 = r25284 * r25285;
        double r25287 = r25283 + r25286;
        double r25288 = 0.0072644182;
        double r25289 = r25285 * r25281;
        double r25290 = r25288 * r25289;
        double r25291 = r25287 + r25290;
        double r25292 = 0.0005064034;
        double r25293 = r25289 * r25281;
        double r25294 = r25292 * r25293;
        double r25295 = r25291 + r25294;
        double r25296 = 0.0001789971;
        double r25297 = r25293 * r25281;
        double r25298 = r25296 * r25297;
        double r25299 = r25295 + r25298;
        double r25300 = 0.7715471019;
        double r25301 = r25300 * r25281;
        double r25302 = r25278 + r25301;
        double r25303 = 0.2909738639;
        double r25304 = r25303 * r25285;
        double r25305 = r25302 + r25304;
        double r25306 = 0.0694555761;
        double r25307 = r25306 * r25289;
        double r25308 = r25305 + r25307;
        double r25309 = 0.0140005442;
        double r25310 = r25309 * r25293;
        double r25311 = r25308 + r25310;
        double r25312 = 0.0008327945;
        double r25313 = r25312 * r25297;
        double r25314 = r25311 + r25313;
        double r25315 = 2;
        double r25316 = r25315 * r25296;
        double r25317 = r25297 * r25281;
        double r25318 = r25316 * r25317;
        double r25319 = r25314 + r25318;
        double r25320 = r25299 / r25319;
        double r25321 = r25320 * r25280;
        return r25321;
}


double f_of(float x) {
        float r25322 = 0.5;
        float r25323 = x;
        float r25324 = r25322 / r25323;
        float r25325 = 0.2514179000665375;
        float r25326 = 4;
        float r25327 = pow(r25323, r25326);
        float r25328 = r25325 / r25327;
        float r25329 = 0.15298196345929327;
        float r25330 = 6;
        float r25331 = pow(r25323, r25330);
        float r25332 = r25329 / r25331;
        float r25333 = r25328 + r25332;
        float r25334 = r25333 * r25323;
        float r25335 = r25324 + r25334;
        float r25336 = -2.2087331437784703e-15;
        bool r25337 = r25335 <= r25336;
        float r25338 = 3;
        float r25339 = pow(r25323, r25338);
        float r25340 = r25339 * r25339;
        float r25341 = 0.0005064034;
        float r25342 = 0.0001789971;
        float r25343 = r25342 * r25323;
        float r25344 = r25343 * r25323;
        float r25345 = r25341 + r25344;
        float r25346 = r25340 * r25345;
        float r25347 = r25339 * r25346;
        float r25348 = r25323 * r25323;
        float r25349 = 0.0072644182;
        float r25350 = r25348 * r25349;
        float r25351 = r25348 * r25348;
        float r25352 = r25350 * r25351;
        float r25353 = 0.1049934947;
        float r25354 = r25348 * r25353;
        float r25355 = 0.0424060604;
        float r25356 = r25323 * r25355;
        float r25357 = r25356 * r25339;
        float r25358 = 1;
        float r25359 = r25357 + r25358;
        float r25360 = r25354 + r25359;
        float r25361 = r25352 + r25360;
        float r25362 = r25361 * r25323;
        float r25363 = r25347 + r25362;
        float r25364 = 0.0140005442;
        float r25365 = r25338 + r25358;
        float r25366 = pow(r25348, r25365);
        float r25367 = r25364 * r25366;
        float r25368 = 0.0008327945;
        float r25369 = r25348 * r25368;
        float r25370 = r25369 * r25366;
        float r25371 = r25367 + r25370;
        float r25372 = r25342 + r25342;
        float r25373 = r25348 * r25372;
        float r25374 = r25366 * r25348;
        float r25375 = r25373 * r25374;
        float r25376 = 0.0694555761;
        float r25377 = r25348 * r25376;
        float r25378 = r25377 * r25351;
        float r25379 = r25378 + r25358;
        float r25380 = r25375 + r25379;
        float r25381 = 0.2909738639;
        float r25382 = r25381 * r25323;
        float r25383 = r25382 * r25339;
        float r25384 = 0.7715471019;
        float r25385 = r25384 * r25348;
        float r25386 = r25383 + r25385;
        float r25387 = r25380 + r25386;
        float r25388 = r25371 + r25387;
        float r25389 = r25363 / r25388;
        float r25390 = 6.998455985774796e-13;
        bool r25391 = r25335 <= r25390;
        float r25392 = r25340 * r25349;
        float r25393 = r25392 + r25358;
        float r25394 = r25355 * r25323;
        float r25395 = r25394 * r25323;
        float r25396 = r25395 + r25353;
        float r25397 = r25348 * r25396;
        float r25398 = r25393 + r25397;
        float r25399 = r25342 * r25348;
        float r25400 = r25399 * r25340;
        float r25401 = r25341 * r25340;
        float r25402 = r25400 + r25401;
        float r25403 = r25348 * r25402;
        float r25404 = r25398 + r25403;
        float r25405 = r25340 * r25364;
        float r25406 = r25368 * r25348;
        float r25407 = r25406 * r25340;
        float r25408 = r25405 + r25407;
        float r25409 = r25348 * r25408;
        float r25410 = r25351 * r25340;
        float r25411 = r25373 * r25410;
        float r25412 = r25340 * r25376;
        float r25413 = r25385 + r25358;
        float r25414 = r25412 + r25413;
        float r25415 = r25411 + r25414;
        float r25416 = r25351 * r25381;
        float r25417 = r25415 + r25416;
        float r25418 = r25409 + r25417;
        float r25419 = r25404 / r25418;
        float r25420 = pow(r25419, r25338);
        float r25421 = cbrt(r25420);
        float r25422 = r25421 * r25323;
        float r25423 = r25391 ? r25335 : r25422;
        float r25424 = r25337 ? r25389 : r25423;
        return r25424;
}

double f_od(double x) {
        double r25425 = 0.5;
        double r25426 = x;
        double r25427 = r25425 / r25426;
        double r25428 = 0.2514179000665375;
        double r25429 = 4;
        double r25430 = pow(r25426, r25429);
        double r25431 = r25428 / r25430;
        double r25432 = 0.15298196345929327;
        double r25433 = 6;
        double r25434 = pow(r25426, r25433);
        double r25435 = r25432 / r25434;
        double r25436 = r25431 + r25435;
        double r25437 = r25436 * r25426;
        double r25438 = r25427 + r25437;
        double r25439 = -2.2087331437784703e-15;
        bool r25440 = r25438 <= r25439;
        double r25441 = 3;
        double r25442 = pow(r25426, r25441);
        double r25443 = r25442 * r25442;
        double r25444 = 0.0005064034;
        double r25445 = 0.0001789971;
        double r25446 = r25445 * r25426;
        double r25447 = r25446 * r25426;
        double r25448 = r25444 + r25447;
        double r25449 = r25443 * r25448;
        double r25450 = r25442 * r25449;
        double r25451 = r25426 * r25426;
        double r25452 = 0.0072644182;
        double r25453 = r25451 * r25452;
        double r25454 = r25451 * r25451;
        double r25455 = r25453 * r25454;
        double r25456 = 0.1049934947;
        double r25457 = r25451 * r25456;
        double r25458 = 0.0424060604;
        double r25459 = r25426 * r25458;
        double r25460 = r25459 * r25442;
        double r25461 = 1;
        double r25462 = r25460 + r25461;
        double r25463 = r25457 + r25462;
        double r25464 = r25455 + r25463;
        double r25465 = r25464 * r25426;
        double r25466 = r25450 + r25465;
        double r25467 = 0.0140005442;
        double r25468 = r25441 + r25461;
        double r25469 = pow(r25451, r25468);
        double r25470 = r25467 * r25469;
        double r25471 = 0.0008327945;
        double r25472 = r25451 * r25471;
        double r25473 = r25472 * r25469;
        double r25474 = r25470 + r25473;
        double r25475 = r25445 + r25445;
        double r25476 = r25451 * r25475;
        double r25477 = r25469 * r25451;
        double r25478 = r25476 * r25477;
        double r25479 = 0.0694555761;
        double r25480 = r25451 * r25479;
        double r25481 = r25480 * r25454;
        double r25482 = r25481 + r25461;
        double r25483 = r25478 + r25482;
        double r25484 = 0.2909738639;
        double r25485 = r25484 * r25426;
        double r25486 = r25485 * r25442;
        double r25487 = 0.7715471019;
        double r25488 = r25487 * r25451;
        double r25489 = r25486 + r25488;
        double r25490 = r25483 + r25489;
        double r25491 = r25474 + r25490;
        double r25492 = r25466 / r25491;
        double r25493 = 6.998455985774796e-13;
        bool r25494 = r25438 <= r25493;
        double r25495 = r25443 * r25452;
        double r25496 = r25495 + r25461;
        double r25497 = r25458 * r25426;
        double r25498 = r25497 * r25426;
        double r25499 = r25498 + r25456;
        double r25500 = r25451 * r25499;
        double r25501 = r25496 + r25500;
        double r25502 = r25445 * r25451;
        double r25503 = r25502 * r25443;
        double r25504 = r25444 * r25443;
        double r25505 = r25503 + r25504;
        double r25506 = r25451 * r25505;
        double r25507 = r25501 + r25506;
        double r25508 = r25443 * r25467;
        double r25509 = r25471 * r25451;
        double r25510 = r25509 * r25443;
        double r25511 = r25508 + r25510;
        double r25512 = r25451 * r25511;
        double r25513 = r25454 * r25443;
        double r25514 = r25476 * r25513;
        double r25515 = r25443 * r25479;
        double r25516 = r25488 + r25461;
        double r25517 = r25515 + r25516;
        double r25518 = r25514 + r25517;
        double r25519 = r25454 * r25484;
        double r25520 = r25518 + r25519;
        double r25521 = r25512 + r25520;
        double r25522 = r25507 / r25521;
        double r25523 = pow(r25522, r25441);
        double r25524 = cbrt(r25523);
        double r25525 = r25524 * r25426;
        double r25526 = r25494 ? r25438 : r25525;
        double r25527 = r25440 ? r25492 : r25526;
        return r25527;
}

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 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, r25557, r25558, r25559, r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568, r25569, r25570, r25571;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25528, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25529, "0.1049934947", 10, MPFR_RNDN);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init_set_str(r25534, "0.0424060604", 10, MPFR_RNDN);
        mpfr_init(r25535);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init_set_str(r25538, "0.0072644182", 10, MPFR_RNDN);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init_set_str(r25542, "0.0005064034", 10, MPFR_RNDN);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init_set_str(r25546, "0.0001789971", 10, MPFR_RNDN);
        mpfr_init(r25547);
        mpfr_init(r25548);
        mpfr_init(r25549);
        mpfr_init_set_str(r25550, "0.7715471019", 10, MPFR_RNDN);
        mpfr_init(r25551);
        mpfr_init(r25552);
        mpfr_init_set_str(r25553, "0.2909738639", 10, MPFR_RNDN);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init_set_str(r25556, "0.0694555761", 10, MPFR_RNDN);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init_set_str(r25559, "0.0140005442", 10, MPFR_RNDN);
        mpfr_init(r25560);
        mpfr_init(r25561);
        mpfr_init_set_str(r25562, "0.0008327945", 10, MPFR_RNDN);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init_set_str(r25565, "2", 10, MPFR_RNDN);
        mpfr_init(r25566);
        mpfr_init(r25567);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init(r25571);
}

double f_im(double x) {
        ;
        ;
        mpfr_set_d(r25530, x, MPFR_RNDN);
        mpfr_mul(r25531, r25530, r25530, MPFR_RNDN);
        mpfr_mul(r25532, r25529, r25531, MPFR_RNDN);
        mpfr_add(r25533, r25528, r25532, MPFR_RNDN);
        ;
        mpfr_mul(r25535, r25531, r25531, MPFR_RNDN);
        mpfr_mul(r25536, r25534, r25535, MPFR_RNDN);
        mpfr_add(r25537, r25533, r25536, MPFR_RNDN);
        ;
        mpfr_mul(r25539, r25535, r25531, MPFR_RNDN);
        mpfr_mul(r25540, r25538, r25539, MPFR_RNDN);
        mpfr_add(r25541, r25537, r25540, MPFR_RNDN);
        ;
        mpfr_mul(r25543, r25539, r25531, MPFR_RNDN);
        mpfr_mul(r25544, r25542, r25543, MPFR_RNDN);
        mpfr_add(r25545, r25541, r25544, MPFR_RNDN);
        ;
        mpfr_mul(r25547, r25543, r25531, MPFR_RNDN);
        mpfr_mul(r25548, r25546, r25547, MPFR_RNDN);
        mpfr_add(r25549, r25545, r25548, MPFR_RNDN);
        ;
        mpfr_mul(r25551, r25550, r25531, MPFR_RNDN);
        mpfr_add(r25552, r25528, r25551, MPFR_RNDN);
        ;
        mpfr_mul(r25554, r25553, r25535, MPFR_RNDN);
        mpfr_add(r25555, r25552, r25554, MPFR_RNDN);
        ;
        mpfr_mul(r25557, r25556, r25539, MPFR_RNDN);
        mpfr_add(r25558, r25555, r25557, MPFR_RNDN);
        ;
        mpfr_mul(r25560, r25559, r25543, MPFR_RNDN);
        mpfr_add(r25561, r25558, r25560, MPFR_RNDN);
        ;
        mpfr_mul(r25563, r25562, r25547, MPFR_RNDN);
        mpfr_add(r25564, r25561, r25563, MPFR_RNDN);
        ;
        mpfr_mul(r25566, r25565, r25546, MPFR_RNDN);
        mpfr_mul(r25567, r25547, r25531, MPFR_RNDN);
        mpfr_mul(r25568, r25566, r25567, MPFR_RNDN);
        mpfr_add(r25569, r25564, r25568, MPFR_RNDN);
        mpfr_div(r25570, r25549, r25569, MPFR_RNDN);
        mpfr_mul(r25571, r25570, r25530, MPFR_RNDN);
        return mpfr_get_d(r25571, MPFR_RNDN);
}

static mpfr_t r25572, r25573, r25574, r25575, r25576, r25577, r25578, r25579, r25580, r25581, 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, 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, r25674;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25572, "0.5", 10, MPFR_RNDN);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init_set_str(r25575, "0.2514179000665375", 10, MPFR_RNDN);
        mpfr_init_set_str(r25576, "4", 10, MPFR_RNDN);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init_set_str(r25579, "0.15298196345929327", 10, MPFR_RNDN);
        mpfr_init_set_str(r25580, "6", 10, MPFR_RNDN);
        mpfr_init(r25581);
        mpfr_init(r25582);
        mpfr_init(r25583);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init_set_str(r25586, "-2.2087331437784703e-15", 10, MPFR_RNDN);
        mpfr_init(r25587);
        mpfr_init_set_str(r25588, "3", 10, MPFR_RNDN);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init_set_str(r25591, "0.0005064034", 10, MPFR_RNDN);
        mpfr_init_set_str(r25592, "0.0001789971", 10, MPFR_RNDN);
        mpfr_init(r25593);
        mpfr_init(r25594);
        mpfr_init(r25595);
        mpfr_init(r25596);
        mpfr_init(r25597);
        mpfr_init(r25598);
        mpfr_init_set_str(r25599, "0.0072644182", 10, MPFR_RNDN);
        mpfr_init(r25600);
        mpfr_init(r25601);
        mpfr_init(r25602);
        mpfr_init_set_str(r25603, "0.1049934947", 10, MPFR_RNDN);
        mpfr_init(r25604);
        mpfr_init_set_str(r25605, "0.0424060604", 10, MPFR_RNDN);
        mpfr_init(r25606);
        mpfr_init(r25607);
        mpfr_init_set_str(r25608, "1", 10, MPFR_RNDN);
        mpfr_init(r25609);
        mpfr_init(r25610);
        mpfr_init(r25611);
        mpfr_init(r25612);
        mpfr_init(r25613);
        mpfr_init_set_str(r25614, "0.0140005442", 10, MPFR_RNDN);
        mpfr_init(r25615);
        mpfr_init(r25616);
        mpfr_init(r25617);
        mpfr_init_set_str(r25618, "0.0008327945", 10, MPFR_RNDN);
        mpfr_init(r25619);
        mpfr_init(r25620);
        mpfr_init(r25621);
        mpfr_init(r25622);
        mpfr_init(r25623);
        mpfr_init(r25624);
        mpfr_init(r25625);
        mpfr_init_set_str(r25626, "0.0694555761", 10, MPFR_RNDN);
        mpfr_init(r25627);
        mpfr_init(r25628);
        mpfr_init(r25629);
        mpfr_init(r25630);
        mpfr_init_set_str(r25631, "0.2909738639", 10, MPFR_RNDN);
        mpfr_init(r25632);
        mpfr_init(r25633);
        mpfr_init_set_str(r25634, "0.7715471019", 10, MPFR_RNDN);
        mpfr_init(r25635);
        mpfr_init(r25636);
        mpfr_init(r25637);
        mpfr_init(r25638);
        mpfr_init(r25639);
        mpfr_init_set_str(r25640, "6.998455985774796e-13", 10, MPFR_RNDN);
        mpfr_init(r25641);
        mpfr_init(r25642);
        mpfr_init(r25643);
        mpfr_init(r25644);
        mpfr_init(r25645);
        mpfr_init(r25646);
        mpfr_init(r25647);
        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(r25658);
        mpfr_init(r25659);
        mpfr_init(r25660);
        mpfr_init(r25661);
        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);
        mpfr_init(r25674);
}

double f_fm(double x) {
        ;
        mpfr_set_d(r25573, x, MPFR_RNDN);
        mpfr_div(r25574, r25572, r25573, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r25577, r25573, r25576, MPFR_RNDN);
        mpfr_div(r25578, r25575, r25577, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r25581, r25573, r25580, MPFR_RNDN);
        mpfr_div(r25582, r25579, r25581, MPFR_RNDN);
        mpfr_add(r25583, r25578, r25582, MPFR_RNDN);
        mpfr_mul(r25584, r25583, r25573, MPFR_RNDN);
        mpfr_add(r25585, r25574, r25584, MPFR_RNDN);
        ;
        mpfr_set_si(r25587, mpfr_cmp(r25585, r25586) <= 0, MPFR_RNDN);
        ;
        mpfr_pow(r25589, r25573, r25588, MPFR_RNDN);
        mpfr_mul(r25590, r25589, r25589, MPFR_RNDN);
        ;
        ;
        mpfr_mul(r25593, r25592, r25573, MPFR_RNDN);
        mpfr_mul(r25594, r25593, r25573, MPFR_RNDN);
        mpfr_add(r25595, r25591, r25594, MPFR_RNDN);
        mpfr_mul(r25596, r25590, r25595, MPFR_RNDN);
        mpfr_mul(r25597, r25589, r25596, MPFR_RNDN);
        mpfr_mul(r25598, r25573, r25573, MPFR_RNDN);
        ;
        mpfr_mul(r25600, r25598, r25599, MPFR_RNDN);
        mpfr_mul(r25601, r25598, r25598, MPFR_RNDN);
        mpfr_mul(r25602, r25600, r25601, MPFR_RNDN);
        ;
        mpfr_mul(r25604, r25598, r25603, MPFR_RNDN);
        ;
        mpfr_mul(r25606, r25573, r25605, MPFR_RNDN);
        mpfr_mul(r25607, r25606, r25589, MPFR_RNDN);
        ;
        mpfr_add(r25609, r25607, r25608, MPFR_RNDN);
        mpfr_add(r25610, r25604, r25609, MPFR_RNDN);
        mpfr_add(r25611, r25602, r25610, MPFR_RNDN);
        mpfr_mul(r25612, r25611, r25573, MPFR_RNDN);
        mpfr_add(r25613, r25597, r25612, MPFR_RNDN);
        ;
        mpfr_add(r25615, r25588, r25608, MPFR_RNDN);
        mpfr_pow(r25616, r25598, r25615, MPFR_RNDN);
        mpfr_mul(r25617, r25614, r25616, MPFR_RNDN);
        ;
        mpfr_mul(r25619, r25598, r25618, MPFR_RNDN);
        mpfr_mul(r25620, r25619, r25616, MPFR_RNDN);
        mpfr_add(r25621, r25617, r25620, MPFR_RNDN);
        mpfr_add(r25622, r25592, r25592, MPFR_RNDN);
        mpfr_mul(r25623, r25598, r25622, MPFR_RNDN);
        mpfr_mul(r25624, r25616, r25598, MPFR_RNDN);
        mpfr_mul(r25625, r25623, r25624, MPFR_RNDN);
        ;
        mpfr_mul(r25627, r25598, r25626, MPFR_RNDN);
        mpfr_mul(r25628, r25627, r25601, MPFR_RNDN);
        mpfr_add(r25629, r25628, r25608, MPFR_RNDN);
        mpfr_add(r25630, r25625, r25629, MPFR_RNDN);
        ;
        mpfr_mul(r25632, r25631, r25573, MPFR_RNDN);
        mpfr_mul(r25633, r25632, r25589, MPFR_RNDN);
        ;
        mpfr_mul(r25635, r25634, r25598, MPFR_RNDN);
        mpfr_add(r25636, r25633, r25635, MPFR_RNDN);
        mpfr_add(r25637, r25630, r25636, MPFR_RNDN);
        mpfr_add(r25638, r25621, r25637, MPFR_RNDN);
        mpfr_div(r25639, r25613, r25638, MPFR_RNDN);
        ;
        mpfr_set_si(r25641, mpfr_cmp(r25585, r25640) <= 0, MPFR_RNDN);
        mpfr_mul(r25642, r25590, r25599, MPFR_RNDN);
        mpfr_add(r25643, r25642, r25608, MPFR_RNDN);
        mpfr_mul(r25644, r25605, r25573, MPFR_RNDN);
        mpfr_mul(r25645, r25644, r25573, MPFR_RNDN);
        mpfr_add(r25646, r25645, r25603, MPFR_RNDN);
        mpfr_mul(r25647, r25598, r25646, MPFR_RNDN);
        mpfr_add(r25648, r25643, r25647, MPFR_RNDN);
        mpfr_mul(r25649, r25592, r25598, MPFR_RNDN);
        mpfr_mul(r25650, r25649, r25590, MPFR_RNDN);
        mpfr_mul(r25651, r25591, r25590, MPFR_RNDN);
        mpfr_add(r25652, r25650, r25651, MPFR_RNDN);
        mpfr_mul(r25653, r25598, r25652, MPFR_RNDN);
        mpfr_add(r25654, r25648, r25653, MPFR_RNDN);
        mpfr_mul(r25655, r25590, r25614, MPFR_RNDN);
        mpfr_mul(r25656, r25618, r25598, MPFR_RNDN);
        mpfr_mul(r25657, r25656, r25590, MPFR_RNDN);
        mpfr_add(r25658, r25655, r25657, MPFR_RNDN);
        mpfr_mul(r25659, r25598, r25658, MPFR_RNDN);
        mpfr_mul(r25660, r25601, r25590, MPFR_RNDN);
        mpfr_mul(r25661, r25623, r25660, MPFR_RNDN);
        mpfr_mul(r25662, r25590, r25626, MPFR_RNDN);
        mpfr_add(r25663, r25635, r25608, MPFR_RNDN);
        mpfr_add(r25664, r25662, r25663, MPFR_RNDN);
        mpfr_add(r25665, r25661, r25664, MPFR_RNDN);
        mpfr_mul(r25666, r25601, r25631, MPFR_RNDN);
        mpfr_add(r25667, r25665, r25666, MPFR_RNDN);
        mpfr_add(r25668, r25659, r25667, MPFR_RNDN);
        mpfr_div(r25669, r25654, r25668, MPFR_RNDN);
        mpfr_pow(r25670, r25669, r25588, MPFR_RNDN);
        mpfr_cbrt(r25671, r25670, MPFR_RNDN);
        mpfr_mul(r25672, r25671, r25573, MPFR_RNDN);
        if (mpfr_get_si(r25641, MPFR_RNDN)) { mpfr_set(r25673, r25585, MPFR_RNDN); } else { mpfr_set(r25673, r25672, MPFR_RNDN); };
        if (mpfr_get_si(r25587, MPFR_RNDN)) { mpfr_set(r25674, r25639, MPFR_RNDN); } else { mpfr_set(r25674, r25673, MPFR_RNDN); };
        return mpfr_get_d(r25674, MPFR_RNDN);
}

static mpfr_t r25675, r25676, r25677, r25678, r25679, r25680, r25681, r25682, r25683, r25684, r25685, r25686, r25687, r25688, r25689, r25690, r25691, r25692, r25693, r25694, r25695, r25696, r25697, r25698, r25699, r25700, r25701, r25702, r25703, r25704, r25705, r25706, r25707, r25708, r25709, r25710, r25711, r25712, r25713, r25714, r25715, r25716, r25717, r25718, r25719, r25720, r25721, r25722, r25723, r25724, r25725, r25726, r25727, r25728, r25729, r25730, r25731, r25732, r25733, r25734, r25735, r25736, r25737, r25738, r25739, r25740, r25741, r25742, r25743, r25744, r25745, r25746, r25747, r25748, r25749, r25750, r25751, r25752, r25753, r25754, r25755, r25756, r25757, r25758, r25759, r25760, r25761, r25762, r25763, r25764, r25765, r25766, r25767, r25768, r25769, r25770, r25771, r25772, r25773, r25774, r25775, r25776, r25777;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r25675, "0.5", 10, MPFR_RNDN);
        mpfr_init(r25676);
        mpfr_init(r25677);
        mpfr_init_set_str(r25678, "0.2514179000665375", 10, MPFR_RNDN);
        mpfr_init_set_str(r25679, "4", 10, MPFR_RNDN);
        mpfr_init(r25680);
        mpfr_init(r25681);
        mpfr_init_set_str(r25682, "0.15298196345929327", 10, MPFR_RNDN);
        mpfr_init_set_str(r25683, "6", 10, MPFR_RNDN);
        mpfr_init(r25684);
        mpfr_init(r25685);
        mpfr_init(r25686);
        mpfr_init(r25687);
        mpfr_init(r25688);
        mpfr_init_set_str(r25689, "-2.2087331437784703e-15", 10, MPFR_RNDN);
        mpfr_init(r25690);
        mpfr_init_set_str(r25691, "3", 10, MPFR_RNDN);
        mpfr_init(r25692);
        mpfr_init(r25693);
        mpfr_init_set_str(r25694, "0.0005064034", 10, MPFR_RNDN);
        mpfr_init_set_str(r25695, "0.0001789971", 10, MPFR_RNDN);
        mpfr_init(r25696);
        mpfr_init(r25697);
        mpfr_init(r25698);
        mpfr_init(r25699);
        mpfr_init(r25700);
        mpfr_init(r25701);
        mpfr_init_set_str(r25702, "0.0072644182", 10, MPFR_RNDN);
        mpfr_init(r25703);
        mpfr_init(r25704);
        mpfr_init(r25705);
        mpfr_init_set_str(r25706, "0.1049934947", 10, MPFR_RNDN);
        mpfr_init(r25707);
        mpfr_init_set_str(r25708, "0.0424060604", 10, MPFR_RNDN);
        mpfr_init(r25709);
        mpfr_init(r25710);
        mpfr_init_set_str(r25711, "1", 10, MPFR_RNDN);
        mpfr_init(r25712);
        mpfr_init(r25713);
        mpfr_init(r25714);
        mpfr_init(r25715);
        mpfr_init(r25716);
        mpfr_init_set_str(r25717, "0.0140005442", 10, MPFR_RNDN);
        mpfr_init(r25718);
        mpfr_init(r25719);
        mpfr_init(r25720);
        mpfr_init_set_str(r25721, "0.0008327945", 10, MPFR_RNDN);
        mpfr_init(r25722);
        mpfr_init(r25723);
        mpfr_init(r25724);
        mpfr_init(r25725);
        mpfr_init(r25726);
        mpfr_init(r25727);
        mpfr_init(r25728);
        mpfr_init_set_str(r25729, "0.0694555761", 10, MPFR_RNDN);
        mpfr_init(r25730);
        mpfr_init(r25731);
        mpfr_init(r25732);
        mpfr_init(r25733);
        mpfr_init_set_str(r25734, "0.2909738639", 10, MPFR_RNDN);
        mpfr_init(r25735);
        mpfr_init(r25736);
        mpfr_init_set_str(r25737, "0.7715471019", 10, MPFR_RNDN);
        mpfr_init(r25738);
        mpfr_init(r25739);
        mpfr_init(r25740);
        mpfr_init(r25741);
        mpfr_init(r25742);
        mpfr_init_set_str(r25743, "6.998455985774796e-13", 10, MPFR_RNDN);
        mpfr_init(r25744);
        mpfr_init(r25745);
        mpfr_init(r25746);
        mpfr_init(r25747);
        mpfr_init(r25748);
        mpfr_init(r25749);
        mpfr_init(r25750);
        mpfr_init(r25751);
        mpfr_init(r25752);
        mpfr_init(r25753);
        mpfr_init(r25754);
        mpfr_init(r25755);
        mpfr_init(r25756);
        mpfr_init(r25757);
        mpfr_init(r25758);
        mpfr_init(r25759);
        mpfr_init(r25760);
        mpfr_init(r25761);
        mpfr_init(r25762);
        mpfr_init(r25763);
        mpfr_init(r25764);
        mpfr_init(r25765);
        mpfr_init(r25766);
        mpfr_init(r25767);
        mpfr_init(r25768);
        mpfr_init(r25769);
        mpfr_init(r25770);
        mpfr_init(r25771);
        mpfr_init(r25772);
        mpfr_init(r25773);
        mpfr_init(r25774);
        mpfr_init(r25775);
        mpfr_init(r25776);
        mpfr_init(r25777);
}

double f_dm(double x) {
        ;
        mpfr_set_d(r25676, x, MPFR_RNDN);
        mpfr_div(r25677, r25675, r25676, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r25680, r25676, r25679, MPFR_RNDN);
        mpfr_div(r25681, r25678, r25680, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r25684, r25676, r25683, MPFR_RNDN);
        mpfr_div(r25685, r25682, r25684, MPFR_RNDN);
        mpfr_add(r25686, r25681, r25685, MPFR_RNDN);
        mpfr_mul(r25687, r25686, r25676, MPFR_RNDN);
        mpfr_add(r25688, r25677, r25687, MPFR_RNDN);
        ;
        mpfr_set_si(r25690, mpfr_cmp(r25688, r25689) <= 0, MPFR_RNDN);
        ;
        mpfr_pow(r25692, r25676, r25691, MPFR_RNDN);
        mpfr_mul(r25693, r25692, r25692, MPFR_RNDN);
        ;
        ;
        mpfr_mul(r25696, r25695, r25676, MPFR_RNDN);
        mpfr_mul(r25697, r25696, r25676, MPFR_RNDN);
        mpfr_add(r25698, r25694, r25697, MPFR_RNDN);
        mpfr_mul(r25699, r25693, r25698, MPFR_RNDN);
        mpfr_mul(r25700, r25692, r25699, MPFR_RNDN);
        mpfr_mul(r25701, r25676, r25676, MPFR_RNDN);
        ;
        mpfr_mul(r25703, r25701, r25702, MPFR_RNDN);
        mpfr_mul(r25704, r25701, r25701, MPFR_RNDN);
        mpfr_mul(r25705, r25703, r25704, MPFR_RNDN);
        ;
        mpfr_mul(r25707, r25701, r25706, MPFR_RNDN);
        ;
        mpfr_mul(r25709, r25676, r25708, MPFR_RNDN);
        mpfr_mul(r25710, r25709, r25692, MPFR_RNDN);
        ;
        mpfr_add(r25712, r25710, r25711, MPFR_RNDN);
        mpfr_add(r25713, r25707, r25712, MPFR_RNDN);
        mpfr_add(r25714, r25705, r25713, MPFR_RNDN);
        mpfr_mul(r25715, r25714, r25676, MPFR_RNDN);
        mpfr_add(r25716, r25700, r25715, MPFR_RNDN);
        ;
        mpfr_add(r25718, r25691, r25711, MPFR_RNDN);
        mpfr_pow(r25719, r25701, r25718, MPFR_RNDN);
        mpfr_mul(r25720, r25717, r25719, MPFR_RNDN);
        ;
        mpfr_mul(r25722, r25701, r25721, MPFR_RNDN);
        mpfr_mul(r25723, r25722, r25719, MPFR_RNDN);
        mpfr_add(r25724, r25720, r25723, MPFR_RNDN);
        mpfr_add(r25725, r25695, r25695, MPFR_RNDN);
        mpfr_mul(r25726, r25701, r25725, MPFR_RNDN);
        mpfr_mul(r25727, r25719, r25701, MPFR_RNDN);
        mpfr_mul(r25728, r25726, r25727, MPFR_RNDN);
        ;
        mpfr_mul(r25730, r25701, r25729, MPFR_RNDN);
        mpfr_mul(r25731, r25730, r25704, MPFR_RNDN);
        mpfr_add(r25732, r25731, r25711, MPFR_RNDN);
        mpfr_add(r25733, r25728, r25732, MPFR_RNDN);
        ;
        mpfr_mul(r25735, r25734, r25676, MPFR_RNDN);
        mpfr_mul(r25736, r25735, r25692, MPFR_RNDN);
        ;
        mpfr_mul(r25738, r25737, r25701, MPFR_RNDN);
        mpfr_add(r25739, r25736, r25738, MPFR_RNDN);
        mpfr_add(r25740, r25733, r25739, MPFR_RNDN);
        mpfr_add(r25741, r25724, r25740, MPFR_RNDN);
        mpfr_div(r25742, r25716, r25741, MPFR_RNDN);
        ;
        mpfr_set_si(r25744, mpfr_cmp(r25688, r25743) <= 0, MPFR_RNDN);
        mpfr_mul(r25745, r25693, r25702, MPFR_RNDN);
        mpfr_add(r25746, r25745, r25711, MPFR_RNDN);
        mpfr_mul(r25747, r25708, r25676, MPFR_RNDN);
        mpfr_mul(r25748, r25747, r25676, MPFR_RNDN);
        mpfr_add(r25749, r25748, r25706, MPFR_RNDN);
        mpfr_mul(r25750, r25701, r25749, MPFR_RNDN);
        mpfr_add(r25751, r25746, r25750, MPFR_RNDN);
        mpfr_mul(r25752, r25695, r25701, MPFR_RNDN);
        mpfr_mul(r25753, r25752, r25693, MPFR_RNDN);
        mpfr_mul(r25754, r25694, r25693, MPFR_RNDN);
        mpfr_add(r25755, r25753, r25754, MPFR_RNDN);
        mpfr_mul(r25756, r25701, r25755, MPFR_RNDN);
        mpfr_add(r25757, r25751, r25756, MPFR_RNDN);
        mpfr_mul(r25758, r25693, r25717, MPFR_RNDN);
        mpfr_mul(r25759, r25721, r25701, MPFR_RNDN);
        mpfr_mul(r25760, r25759, r25693, MPFR_RNDN);
        mpfr_add(r25761, r25758, r25760, MPFR_RNDN);
        mpfr_mul(r25762, r25701, r25761, MPFR_RNDN);
        mpfr_mul(r25763, r25704, r25693, MPFR_RNDN);
        mpfr_mul(r25764, r25726, r25763, MPFR_RNDN);
        mpfr_mul(r25765, r25693, r25729, MPFR_RNDN);
        mpfr_add(r25766, r25738, r25711, MPFR_RNDN);
        mpfr_add(r25767, r25765, r25766, MPFR_RNDN);
        mpfr_add(r25768, r25764, r25767, MPFR_RNDN);
        mpfr_mul(r25769, r25704, r25734, MPFR_RNDN);
        mpfr_add(r25770, r25768, r25769, MPFR_RNDN);
        mpfr_add(r25771, r25762, r25770, MPFR_RNDN);
        mpfr_div(r25772, r25757, r25771, MPFR_RNDN);
        mpfr_pow(r25773, r25772, r25691, MPFR_RNDN);
        mpfr_cbrt(r25774, r25773, MPFR_RNDN);
        mpfr_mul(r25775, r25774, r25676, MPFR_RNDN);
        if (mpfr_get_si(r25744, MPFR_RNDN)) { mpfr_set(r25776, r25688, MPFR_RNDN); } else { mpfr_set(r25776, r25775, MPFR_RNDN); };
        if (mpfr_get_si(r25690, MPFR_RNDN)) { mpfr_set(r25777, r25742, MPFR_RNDN); } else { mpfr_set(r25777, r25776, MPFR_RNDN); };
        return mpfr_get_d(r25777, MPFR_RNDN);
}

