#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 r25190 = 1;
        float r25191 = 0.3275911;
        float r25192 = x;
        float r25193 = fabs(r25192);
        float r25194 = r25191 * r25193;
        float r25195 = r25190 + r25194;
        float r25196 = r25190 / r25195;
        float r25197 = 0.254829592;
        float r25198 = -0.284496736;
        float r25199 = 1.421413741;
        float r25200 = -1.453152027;
        float r25201 = 1.061405429;
        float r25202 = r25196 * r25201;
        float r25203 = r25200 + r25202;
        float r25204 = r25196 * r25203;
        float r25205 = r25199 + r25204;
        float r25206 = r25196 * r25205;
        float r25207 = r25198 + r25206;
        float r25208 = r25196 * r25207;
        float r25209 = r25197 + r25208;
        float r25210 = r25196 * r25209;
        float r25211 = r25193 * r25193;
        float r25212 = -r25211;
        float r25213 = exp(r25212);
        float r25214 = r25210 * r25213;
        float r25215 = r25190 - r25214;
        return r25215;
}

double f_id(double x) {
        double r25216 = 1;
        double r25217 = 0.3275911;
        double r25218 = x;
        double r25219 = fabs(r25218);
        double r25220 = r25217 * r25219;
        double r25221 = r25216 + r25220;
        double r25222 = r25216 / r25221;
        double r25223 = 0.254829592;
        double r25224 = -0.284496736;
        double r25225 = 1.421413741;
        double r25226 = -1.453152027;
        double r25227 = 1.061405429;
        double r25228 = r25222 * r25227;
        double r25229 = r25226 + r25228;
        double r25230 = r25222 * r25229;
        double r25231 = r25225 + r25230;
        double r25232 = r25222 * r25231;
        double r25233 = r25224 + r25232;
        double r25234 = r25222 * r25233;
        double r25235 = r25223 + r25234;
        double r25236 = r25222 * r25235;
        double r25237 = r25219 * r25219;
        double r25238 = -r25237;
        double r25239 = exp(r25238);
        double r25240 = r25236 * r25239;
        double r25241 = r25216 - r25240;
        return r25241;
}


double f_of(float x) {
        float r25242 = x;
        float r25243 = -7.295683619394441e-16;
        bool r25244 = r25242 <= r25243;
        float r25245 = 1;
        float r25246 = 0.3275911;
        float r25247 = fabs(r25242);
        float r25248 = fma(r25246, r25247, r25245);
        float r25249 = r25245 / r25248;
        float r25250 = -1.453152027;
        float r25251 = 1.061405429;
        float r25252 = r25251 / r25248;
        float r25253 = r25250 + r25252;
        float r25254 = 1.421413741;
        float r25255 = fma(r25253, r25249, r25254);
        float r25256 = -0.284496736;
        float r25257 = fma(r25249, r25255, r25256);
        float r25258 = r25249 * r25249;
        float r25259 = -r25245;
        float r25260 = r25247 * r25247;
        float r25261 = exp(r25260);
        float r25262 = r25259 / r25261;
        float r25263 = r25258 * r25262;
        float r25264 = 0.254829592;
        float r25265 = r25264 / r25248;
        float r25266 = fma(r25265, r25262, r25245);
        float r25267 = fma(r25257, r25263, r25266);
        float r25268 = 3;
        float r25269 = pow(r25267, r25268);
        float r25270 = cbrt(r25269);
        float r25271 = cbrt(r25270);
        float r25272 = fma(r25247, r25246, r25245);
        float r25273 = r25251 / r25272;
        float r25274 = r25250 + r25273;
        float r25275 = r25245 / r25272;
        float r25276 = fma(r25274, r25275, r25254);
        float r25277 = fma(r25276, r25275, r25256);
        float r25278 = pow(r25277, r25268);
        float r25279 = cbrt(r25278);
        float r25280 = r25275 * r25275;
        float r25281 = r25264 / r25272;
        float r25282 = fma(r25279, r25280, r25281);
        float r25283 = fma(r25262, r25282, r25245);
        float r25284 = cbrt(r25283);
        float r25285 = r25284 * r25284;
        float r25286 = r25271 * r25285;
        float r25287 = 7.609989951004465e-18;
        bool r25288 = r25242 <= r25287;
        float r25289 = r25246 * r25247;
        float r25290 = r25289 + r25245;
        float r25291 = 2;
        float r25292 = pow(r25247, r25291);
        float r25293 = exp(r25292);
        float r25294 = r25290 * r25293;
        float r25295 = 5;
        float r25296 = pow(r25290, r25295);
        float r25297 = r25293 * r25296;
        float r25298 = pow(r25290, r25268);
        float r25299 = r25293 * r25298;
        float r25300 = r25297 * r25299;
        float r25301 = r25294 * r25300;
        float r25302 = pow(r25245, r25268);
        float r25303 = 0.284496736;
        float r25304 = pow(r25290, r25291);
        float r25305 = r25293 * r25304;
        float r25306 = r25245 / r25305;
        float r25307 = r25303 * r25306;
        float r25308 = 4;
        float r25309 = pow(r25290, r25308);
        float r25310 = r25309 * r25293;
        float r25311 = r25245 / r25310;
        float r25312 = 1.453152027;
        float r25313 = r25311 * r25312;
        float r25314 = r25307 + r25313;
        float r25315 = pow(r25314, r25268);
        float r25316 = r25302 + r25315;
        float r25317 = r25301 * r25316;
        float r25318 = r25314 * r25314;
        float r25319 = r25318 - r25314;
        float r25320 = r25319 + r25245;
        float r25321 = r25254 * r25297;
        float r25322 = r25251 * r25299;
        float r25323 = r25321 + r25322;
        float r25324 = r25294 * r25323;
        float r25325 = r25264 * r25300;
        float r25326 = r25324 + r25325;
        float r25327 = r25320 * r25326;
        float r25328 = r25317 - r25327;
        float r25329 = r25320 * r25301;
        float r25330 = r25328 / r25329;
        float r25331 = cbrt(r25330);
        float r25332 = r25331 * r25284;
        float r25333 = r25284 * r25332;
        float r25334 = r25245 + r25307;
        float r25335 = r25334 + r25313;
        float r25336 = r25245 / r25297;
        float r25337 = r25251 * r25336;
        float r25338 = r25245 / r25294;
        float r25339 = r25338 * r25264;
        float r25340 = r25245 / r25299;
        float r25341 = r25254 * r25340;
        float r25342 = r25339 + r25341;
        float r25343 = r25337 + r25342;
        float r25344 = r25335 - r25343;
        float r25345 = cbrt(r25344);
        float r25346 = r25245 + r25314;
        float r25347 = r25341 + r25337;
        float r25348 = r25339 + r25347;
        float r25349 = r25346 - r25348;
        float r25350 = cbrt(r25349);
        float r25351 = r25345 * r25350;
        float r25352 = r25284 * r25351;
        float r25353 = r25288 ? r25333 : r25352;
        float r25354 = r25244 ? r25286 : r25353;
        return r25354;
}

double f_od(double x) {
        double r25355 = x;
        double r25356 = -7.295683619394441e-16;
        bool r25357 = r25355 <= r25356;
        double r25358 = 1;
        double r25359 = 0.3275911;
        double r25360 = fabs(r25355);
        double r25361 = fma(r25359, r25360, r25358);
        double r25362 = r25358 / r25361;
        double r25363 = -1.453152027;
        double r25364 = 1.061405429;
        double r25365 = r25364 / r25361;
        double r25366 = r25363 + r25365;
        double r25367 = 1.421413741;
        double r25368 = fma(r25366, r25362, r25367);
        double r25369 = -0.284496736;
        double r25370 = fma(r25362, r25368, r25369);
        double r25371 = r25362 * r25362;
        double r25372 = -r25358;
        double r25373 = r25360 * r25360;
        double r25374 = exp(r25373);
        double r25375 = r25372 / r25374;
        double r25376 = r25371 * r25375;
        double r25377 = 0.254829592;
        double r25378 = r25377 / r25361;
        double r25379 = fma(r25378, r25375, r25358);
        double r25380 = fma(r25370, r25376, r25379);
        double r25381 = 3;
        double r25382 = pow(r25380, r25381);
        double r25383 = cbrt(r25382);
        double r25384 = cbrt(r25383);
        double r25385 = fma(r25360, r25359, r25358);
        double r25386 = r25364 / r25385;
        double r25387 = r25363 + r25386;
        double r25388 = r25358 / r25385;
        double r25389 = fma(r25387, r25388, r25367);
        double r25390 = fma(r25389, r25388, r25369);
        double r25391 = pow(r25390, r25381);
        double r25392 = cbrt(r25391);
        double r25393 = r25388 * r25388;
        double r25394 = r25377 / r25385;
        double r25395 = fma(r25392, r25393, r25394);
        double r25396 = fma(r25375, r25395, r25358);
        double r25397 = cbrt(r25396);
        double r25398 = r25397 * r25397;
        double r25399 = r25384 * r25398;
        double r25400 = 7.609989951004465e-18;
        bool r25401 = r25355 <= r25400;
        double r25402 = r25359 * r25360;
        double r25403 = r25402 + r25358;
        double r25404 = 2;
        double r25405 = pow(r25360, r25404);
        double r25406 = exp(r25405);
        double r25407 = r25403 * r25406;
        double r25408 = 5;
        double r25409 = pow(r25403, r25408);
        double r25410 = r25406 * r25409;
        double r25411 = pow(r25403, r25381);
        double r25412 = r25406 * r25411;
        double r25413 = r25410 * r25412;
        double r25414 = r25407 * r25413;
        double r25415 = pow(r25358, r25381);
        double r25416 = 0.284496736;
        double r25417 = pow(r25403, r25404);
        double r25418 = r25406 * r25417;
        double r25419 = r25358 / r25418;
        double r25420 = r25416 * r25419;
        double r25421 = 4;
        double r25422 = pow(r25403, r25421);
        double r25423 = r25422 * r25406;
        double r25424 = r25358 / r25423;
        double r25425 = 1.453152027;
        double r25426 = r25424 * r25425;
        double r25427 = r25420 + r25426;
        double r25428 = pow(r25427, r25381);
        double r25429 = r25415 + r25428;
        double r25430 = r25414 * r25429;
        double r25431 = r25427 * r25427;
        double r25432 = r25431 - r25427;
        double r25433 = r25432 + r25358;
        double r25434 = r25367 * r25410;
        double r25435 = r25364 * r25412;
        double r25436 = r25434 + r25435;
        double r25437 = r25407 * r25436;
        double r25438 = r25377 * r25413;
        double r25439 = r25437 + r25438;
        double r25440 = r25433 * r25439;
        double r25441 = r25430 - r25440;
        double r25442 = r25433 * r25414;
        double r25443 = r25441 / r25442;
        double r25444 = cbrt(r25443);
        double r25445 = r25444 * r25397;
        double r25446 = r25397 * r25445;
        double r25447 = r25358 + r25420;
        double r25448 = r25447 + r25426;
        double r25449 = r25358 / r25410;
        double r25450 = r25364 * r25449;
        double r25451 = r25358 / r25407;
        double r25452 = r25451 * r25377;
        double r25453 = r25358 / r25412;
        double r25454 = r25367 * r25453;
        double r25455 = r25452 + r25454;
        double r25456 = r25450 + r25455;
        double r25457 = r25448 - r25456;
        double r25458 = cbrt(r25457);
        double r25459 = r25358 + r25427;
        double r25460 = r25454 + r25450;
        double r25461 = r25452 + r25460;
        double r25462 = r25459 - r25461;
        double r25463 = cbrt(r25462);
        double r25464 = r25458 * r25463;
        double r25465 = r25397 * r25464;
        double r25466 = r25401 ? r25446 : r25465;
        double r25467 = r25357 ? r25399 : r25466;
        return r25467;
}

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 r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481, r25482, r25483, r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init_set_str(r25468, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25469, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init_set_str(r25475, "0.254829592", 10, MPFR_RNDN);
        mpfr_init_set_str(r25476, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init_set_str(r25477, "1.421413741", 10, MPFR_RNDN);
        mpfr_init_set_str(r25478, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init_set_str(r25479, "1.061405429", 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(r25490);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init(r25493);
}

double f_im(double x) {
        ;
        ;
        mpfr_set_d(r25470, x, MPFR_RNDN);
        mpfr_abs(r25471, r25470, MPFR_RNDN);
        mpfr_mul(r25472, r25469, r25471, MPFR_RNDN);
        mpfr_add(r25473, r25468, r25472, MPFR_RNDN);
        mpfr_div(r25474, r25468, r25473, MPFR_RNDN);
        ;
        ;
        ;
        ;
        ;
        mpfr_mul(r25480, r25474, r25479, MPFR_RNDN);
        mpfr_add(r25481, r25478, r25480, MPFR_RNDN);
        mpfr_mul(r25482, r25474, r25481, MPFR_RNDN);
        mpfr_add(r25483, r25477, r25482, MPFR_RNDN);
        mpfr_mul(r25484, r25474, r25483, MPFR_RNDN);
        mpfr_add(r25485, r25476, r25484, MPFR_RNDN);
        mpfr_mul(r25486, r25474, r25485, MPFR_RNDN);
        mpfr_add(r25487, r25475, r25486, MPFR_RNDN);
        mpfr_mul(r25488, r25474, r25487, MPFR_RNDN);
        mpfr_mul(r25489, r25471, r25471, MPFR_RNDN);
        mpfr_neg(r25490, r25489, MPFR_RNDN);
        mpfr_exp(r25491, r25490, MPFR_RNDN);
        mpfr_mul(r25492, r25488, r25491, MPFR_RNDN);
        mpfr_sub(r25493, r25468, r25492, MPFR_RNDN);
        return mpfr_get_d(r25493, MPFR_RNDN);
}

static mpfr_t 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, 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, 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, r25593, r25594, r25595, r25596, r25597, r25598, r25599, r25600, r25601, r25602, r25603, r25604, r25605, r25606;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r25494);
        mpfr_init_set_str(r25495, "-7.295683619394441e-16", 10, MPFR_RNDN);
        mpfr_init(r25496);
        mpfr_init_set_str(r25497, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25498, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init_set_str(r25502, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init_set_str(r25503, "1.061405429", 10, MPFR_RNDN);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init_set_str(r25506, "1.421413741", 10, MPFR_RNDN);
        mpfr_init(r25507);
        mpfr_init_set_str(r25508, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25509);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
        mpfr_init_set_str(r25516, "0.254829592", 10, MPFR_RNDN);
        mpfr_init(r25517);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init_set_str(r25520, "3", 10, MPFR_RNDN);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        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(r25535);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init_set_str(r25539, "7.609989951004465e-18", 10, MPFR_RNDN);
        mpfr_init(r25540);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init_set_str(r25543, "2", 10, MPFR_RNDN);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init(r25546);
        mpfr_init_set_str(r25547, "5", 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_set_str(r25555, "0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25556);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
        mpfr_init_set_str(r25560, "4", 10, MPFR_RNDN);
        mpfr_init(r25561);
        mpfr_init(r25562);
        mpfr_init(r25563);
        mpfr_init_set_str(r25564, "1.453152027", 10, MPFR_RNDN);
        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);
        mpfr_init(r25587);
        mpfr_init(r25588);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init(r25591);
        mpfr_init(r25592);
        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(r25601);
        mpfr_init(r25602);
        mpfr_init(r25603);
        mpfr_init(r25604);
        mpfr_init(r25605);
        mpfr_init(r25606);
}

double f_fm(double x) {
        mpfr_set_d(r25494, x, MPFR_RNDN);
        ;
        mpfr_set_si(r25496, mpfr_cmp(r25494, r25495) <= 0, MPFR_RNDN);
        ;
        ;
        mpfr_abs(r25499, r25494, MPFR_RNDN);
        mpfr_fma(r25500, r25498, r25499, r25497, MPFR_RNDN);
        mpfr_div(r25501, r25497, r25500, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25504, r25503, r25500, MPFR_RNDN);
        mpfr_add(r25505, r25502, r25504, MPFR_RNDN);
        ;
        mpfr_fma(r25507, r25505, r25501, r25506, MPFR_RNDN);
        ;
        mpfr_fma(r25509, r25501, r25507, r25508, MPFR_RNDN);
        mpfr_mul(r25510, r25501, r25501, MPFR_RNDN);
        mpfr_neg(r25511, r25497, MPFR_RNDN);
        mpfr_mul(r25512, r25499, r25499, MPFR_RNDN);
        mpfr_exp(r25513, r25512, MPFR_RNDN);
        mpfr_div(r25514, r25511, r25513, MPFR_RNDN);
        mpfr_mul(r25515, r25510, r25514, MPFR_RNDN);
        ;
        mpfr_div(r25517, r25516, r25500, MPFR_RNDN);
        mpfr_fma(r25518, r25517, r25514, r25497, MPFR_RNDN);
        mpfr_fma(r25519, r25509, r25515, r25518, MPFR_RNDN);
        ;
        mpfr_pow(r25521, r25519, r25520, MPFR_RNDN);
        mpfr_cbrt(r25522, r25521, MPFR_RNDN);
        mpfr_cbrt(r25523, r25522, MPFR_RNDN);
        mpfr_fma(r25524, r25499, r25498, r25497, MPFR_RNDN);
        mpfr_div(r25525, r25503, r25524, MPFR_RNDN);
        mpfr_add(r25526, r25502, r25525, MPFR_RNDN);
        mpfr_div(r25527, r25497, r25524, MPFR_RNDN);
        mpfr_fma(r25528, r25526, r25527, r25506, MPFR_RNDN);
        mpfr_fma(r25529, r25528, r25527, r25508, MPFR_RNDN);
        mpfr_pow(r25530, r25529, r25520, MPFR_RNDN);
        mpfr_cbrt(r25531, r25530, MPFR_RNDN);
        mpfr_mul(r25532, r25527, r25527, MPFR_RNDN);
        mpfr_div(r25533, r25516, r25524, MPFR_RNDN);
        mpfr_fma(r25534, r25531, r25532, r25533, MPFR_RNDN);
        mpfr_fma(r25535, r25514, r25534, r25497, MPFR_RNDN);
        mpfr_cbrt(r25536, r25535, MPFR_RNDN);
        mpfr_mul(r25537, r25536, r25536, MPFR_RNDN);
        mpfr_mul(r25538, r25523, r25537, MPFR_RNDN);
        ;
        mpfr_set_si(r25540, mpfr_cmp(r25494, r25539) <= 0, MPFR_RNDN);
        mpfr_mul(r25541, r25498, r25499, MPFR_RNDN);
        mpfr_add(r25542, r25541, r25497, MPFR_RNDN);
        ;
        mpfr_pow(r25544, r25499, r25543, MPFR_RNDN);
        mpfr_exp(r25545, r25544, MPFR_RNDN);
        mpfr_mul(r25546, r25542, r25545, MPFR_RNDN);
        ;
        mpfr_pow(r25548, r25542, r25547, MPFR_RNDN);
        mpfr_mul(r25549, r25545, r25548, MPFR_RNDN);
        mpfr_pow(r25550, r25542, r25520, MPFR_RNDN);
        mpfr_mul(r25551, r25545, r25550, MPFR_RNDN);
        mpfr_mul(r25552, r25549, r25551, MPFR_RNDN);
        mpfr_mul(r25553, r25546, r25552, MPFR_RNDN);
        mpfr_pow(r25554, r25497, r25520, MPFR_RNDN);
        ;
        mpfr_pow(r25556, r25542, r25543, MPFR_RNDN);
        mpfr_mul(r25557, r25545, r25556, MPFR_RNDN);
        mpfr_div(r25558, r25497, r25557, MPFR_RNDN);
        mpfr_mul(r25559, r25555, r25558, MPFR_RNDN);
        ;
        mpfr_pow(r25561, r25542, r25560, MPFR_RNDN);
        mpfr_mul(r25562, r25561, r25545, MPFR_RNDN);
        mpfr_div(r25563, r25497, r25562, MPFR_RNDN);
        ;
        mpfr_mul(r25565, r25563, r25564, MPFR_RNDN);
        mpfr_add(r25566, r25559, r25565, MPFR_RNDN);
        mpfr_pow(r25567, r25566, r25520, MPFR_RNDN);
        mpfr_add(r25568, r25554, r25567, MPFR_RNDN);
        mpfr_mul(r25569, r25553, r25568, MPFR_RNDN);
        mpfr_mul(r25570, r25566, r25566, MPFR_RNDN);
        mpfr_sub(r25571, r25570, r25566, MPFR_RNDN);
        mpfr_add(r25572, r25571, r25497, MPFR_RNDN);
        mpfr_mul(r25573, r25506, r25549, MPFR_RNDN);
        mpfr_mul(r25574, r25503, r25551, MPFR_RNDN);
        mpfr_add(r25575, r25573, r25574, MPFR_RNDN);
        mpfr_mul(r25576, r25546, r25575, MPFR_RNDN);
        mpfr_mul(r25577, r25516, r25552, MPFR_RNDN);
        mpfr_add(r25578, r25576, r25577, MPFR_RNDN);
        mpfr_mul(r25579, r25572, r25578, MPFR_RNDN);
        mpfr_sub(r25580, r25569, r25579, MPFR_RNDN);
        mpfr_mul(r25581, r25572, r25553, MPFR_RNDN);
        mpfr_div(r25582, r25580, r25581, MPFR_RNDN);
        mpfr_cbrt(r25583, r25582, MPFR_RNDN);
        mpfr_mul(r25584, r25583, r25536, MPFR_RNDN);
        mpfr_mul(r25585, r25536, r25584, MPFR_RNDN);
        mpfr_add(r25586, r25497, r25559, MPFR_RNDN);
        mpfr_add(r25587, r25586, r25565, MPFR_RNDN);
        mpfr_div(r25588, r25497, r25549, MPFR_RNDN);
        mpfr_mul(r25589, r25503, r25588, MPFR_RNDN);
        mpfr_div(r25590, r25497, r25546, MPFR_RNDN);
        mpfr_mul(r25591, r25590, r25516, MPFR_RNDN);
        mpfr_div(r25592, r25497, r25551, MPFR_RNDN);
        mpfr_mul(r25593, r25506, r25592, MPFR_RNDN);
        mpfr_add(r25594, r25591, r25593, MPFR_RNDN);
        mpfr_add(r25595, r25589, r25594, MPFR_RNDN);
        mpfr_sub(r25596, r25587, r25595, MPFR_RNDN);
        mpfr_cbrt(r25597, r25596, MPFR_RNDN);
        mpfr_add(r25598, r25497, r25566, MPFR_RNDN);
        mpfr_add(r25599, r25593, r25589, MPFR_RNDN);
        mpfr_add(r25600, r25591, r25599, MPFR_RNDN);
        mpfr_sub(r25601, r25598, r25600, MPFR_RNDN);
        mpfr_cbrt(r25602, r25601, MPFR_RNDN);
        mpfr_mul(r25603, r25597, r25602, MPFR_RNDN);
        mpfr_mul(r25604, r25536, r25603, MPFR_RNDN);
        if (mpfr_get_si(r25540, MPFR_RNDN)) { mpfr_set(r25605, r25585, MPFR_RNDN); } else { mpfr_set(r25605, r25604, MPFR_RNDN); };
        if (mpfr_get_si(r25496, MPFR_RNDN)) { mpfr_set(r25606, r25538, MPFR_RNDN); } else { mpfr_set(r25606, r25605, MPFR_RNDN); };
        return mpfr_get_d(r25606, MPFR_RNDN);
}

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

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r25607);
        mpfr_init_set_str(r25608, "-7.295683619394441e-16", 10, MPFR_RNDN);
        mpfr_init(r25609);
        mpfr_init_set_str(r25610, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r25611, "0.3275911", 10, MPFR_RNDN);
        mpfr_init(r25612);
        mpfr_init(r25613);
        mpfr_init(r25614);
        mpfr_init_set_str(r25615, "-1.453152027", 10, MPFR_RNDN);
        mpfr_init_set_str(r25616, "1.061405429", 10, MPFR_RNDN);
        mpfr_init(r25617);
        mpfr_init(r25618);
        mpfr_init_set_str(r25619, "1.421413741", 10, MPFR_RNDN);
        mpfr_init(r25620);
        mpfr_init_set_str(r25621, "-0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25622);
        mpfr_init(r25623);
        mpfr_init(r25624);
        mpfr_init(r25625);
        mpfr_init(r25626);
        mpfr_init(r25627);
        mpfr_init(r25628);
        mpfr_init_set_str(r25629, "0.254829592", 10, MPFR_RNDN);
        mpfr_init(r25630);
        mpfr_init(r25631);
        mpfr_init(r25632);
        mpfr_init_set_str(r25633, "3", 10, MPFR_RNDN);
        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);
        mpfr_init(r25645);
        mpfr_init(r25646);
        mpfr_init(r25647);
        mpfr_init(r25648);
        mpfr_init(r25649);
        mpfr_init(r25650);
        mpfr_init(r25651);
        mpfr_init_set_str(r25652, "7.609989951004465e-18", 10, MPFR_RNDN);
        mpfr_init(r25653);
        mpfr_init(r25654);
        mpfr_init(r25655);
        mpfr_init_set_str(r25656, "2", 10, MPFR_RNDN);
        mpfr_init(r25657);
        mpfr_init(r25658);
        mpfr_init(r25659);
        mpfr_init_set_str(r25660, "5", 10, MPFR_RNDN);
        mpfr_init(r25661);
        mpfr_init(r25662);
        mpfr_init(r25663);
        mpfr_init(r25664);
        mpfr_init(r25665);
        mpfr_init(r25666);
        mpfr_init(r25667);
        mpfr_init_set_str(r25668, "0.284496736", 10, MPFR_RNDN);
        mpfr_init(r25669);
        mpfr_init(r25670);
        mpfr_init(r25671);
        mpfr_init(r25672);
        mpfr_init_set_str(r25673, "4", 10, MPFR_RNDN);
        mpfr_init(r25674);
        mpfr_init(r25675);
        mpfr_init(r25676);
        mpfr_init_set_str(r25677, "1.453152027", 10, MPFR_RNDN);
        mpfr_init(r25678);
        mpfr_init(r25679);
        mpfr_init(r25680);
        mpfr_init(r25681);
        mpfr_init(r25682);
        mpfr_init(r25683);
        mpfr_init(r25684);
        mpfr_init(r25685);
        mpfr_init(r25686);
        mpfr_init(r25687);
        mpfr_init(r25688);
        mpfr_init(r25689);
        mpfr_init(r25690);
        mpfr_init(r25691);
        mpfr_init(r25692);
        mpfr_init(r25693);
        mpfr_init(r25694);
        mpfr_init(r25695);
        mpfr_init(r25696);
        mpfr_init(r25697);
        mpfr_init(r25698);
        mpfr_init(r25699);
        mpfr_init(r25700);
        mpfr_init(r25701);
        mpfr_init(r25702);
        mpfr_init(r25703);
        mpfr_init(r25704);
        mpfr_init(r25705);
        mpfr_init(r25706);
        mpfr_init(r25707);
        mpfr_init(r25708);
        mpfr_init(r25709);
        mpfr_init(r25710);
        mpfr_init(r25711);
        mpfr_init(r25712);
        mpfr_init(r25713);
        mpfr_init(r25714);
        mpfr_init(r25715);
        mpfr_init(r25716);
        mpfr_init(r25717);
        mpfr_init(r25718);
        mpfr_init(r25719);
}

double f_dm(double x) {
        mpfr_set_d(r25607, x, MPFR_RNDN);
        ;
        mpfr_set_si(r25609, mpfr_cmp(r25607, r25608) <= 0, MPFR_RNDN);
        ;
        ;
        mpfr_abs(r25612, r25607, MPFR_RNDN);
        mpfr_fma(r25613, r25611, r25612, r25610, MPFR_RNDN);
        mpfr_div(r25614, r25610, r25613, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25617, r25616, r25613, MPFR_RNDN);
        mpfr_add(r25618, r25615, r25617, MPFR_RNDN);
        ;
        mpfr_fma(r25620, r25618, r25614, r25619, MPFR_RNDN);
        ;
        mpfr_fma(r25622, r25614, r25620, r25621, MPFR_RNDN);
        mpfr_mul(r25623, r25614, r25614, MPFR_RNDN);
        mpfr_neg(r25624, r25610, MPFR_RNDN);
        mpfr_mul(r25625, r25612, r25612, MPFR_RNDN);
        mpfr_exp(r25626, r25625, MPFR_RNDN);
        mpfr_div(r25627, r25624, r25626, MPFR_RNDN);
        mpfr_mul(r25628, r25623, r25627, MPFR_RNDN);
        ;
        mpfr_div(r25630, r25629, r25613, MPFR_RNDN);
        mpfr_fma(r25631, r25630, r25627, r25610, MPFR_RNDN);
        mpfr_fma(r25632, r25622, r25628, r25631, MPFR_RNDN);
        ;
        mpfr_pow(r25634, r25632, r25633, MPFR_RNDN);
        mpfr_cbrt(r25635, r25634, MPFR_RNDN);
        mpfr_cbrt(r25636, r25635, MPFR_RNDN);
        mpfr_fma(r25637, r25612, r25611, r25610, MPFR_RNDN);
        mpfr_div(r25638, r25616, r25637, MPFR_RNDN);
        mpfr_add(r25639, r25615, r25638, MPFR_RNDN);
        mpfr_div(r25640, r25610, r25637, MPFR_RNDN);
        mpfr_fma(r25641, r25639, r25640, r25619, MPFR_RNDN);
        mpfr_fma(r25642, r25641, r25640, r25621, MPFR_RNDN);
        mpfr_pow(r25643, r25642, r25633, MPFR_RNDN);
        mpfr_cbrt(r25644, r25643, MPFR_RNDN);
        mpfr_mul(r25645, r25640, r25640, MPFR_RNDN);
        mpfr_div(r25646, r25629, r25637, MPFR_RNDN);
        mpfr_fma(r25647, r25644, r25645, r25646, MPFR_RNDN);
        mpfr_fma(r25648, r25627, r25647, r25610, MPFR_RNDN);
        mpfr_cbrt(r25649, r25648, MPFR_RNDN);
        mpfr_mul(r25650, r25649, r25649, MPFR_RNDN);
        mpfr_mul(r25651, r25636, r25650, MPFR_RNDN);
        ;
        mpfr_set_si(r25653, mpfr_cmp(r25607, r25652) <= 0, MPFR_RNDN);
        mpfr_mul(r25654, r25611, r25612, MPFR_RNDN);
        mpfr_add(r25655, r25654, r25610, MPFR_RNDN);
        ;
        mpfr_pow(r25657, r25612, r25656, MPFR_RNDN);
        mpfr_exp(r25658, r25657, MPFR_RNDN);
        mpfr_mul(r25659, r25655, r25658, MPFR_RNDN);
        ;
        mpfr_pow(r25661, r25655, r25660, MPFR_RNDN);
        mpfr_mul(r25662, r25658, r25661, MPFR_RNDN);
        mpfr_pow(r25663, r25655, r25633, MPFR_RNDN);
        mpfr_mul(r25664, r25658, r25663, MPFR_RNDN);
        mpfr_mul(r25665, r25662, r25664, MPFR_RNDN);
        mpfr_mul(r25666, r25659, r25665, MPFR_RNDN);
        mpfr_pow(r25667, r25610, r25633, MPFR_RNDN);
        ;
        mpfr_pow(r25669, r25655, r25656, MPFR_RNDN);
        mpfr_mul(r25670, r25658, r25669, MPFR_RNDN);
        mpfr_div(r25671, r25610, r25670, MPFR_RNDN);
        mpfr_mul(r25672, r25668, r25671, MPFR_RNDN);
        ;
        mpfr_pow(r25674, r25655, r25673, MPFR_RNDN);
        mpfr_mul(r25675, r25674, r25658, MPFR_RNDN);
        mpfr_div(r25676, r25610, r25675, MPFR_RNDN);
        ;
        mpfr_mul(r25678, r25676, r25677, MPFR_RNDN);
        mpfr_add(r25679, r25672, r25678, MPFR_RNDN);
        mpfr_pow(r25680, r25679, r25633, MPFR_RNDN);
        mpfr_add(r25681, r25667, r25680, MPFR_RNDN);
        mpfr_mul(r25682, r25666, r25681, MPFR_RNDN);
        mpfr_mul(r25683, r25679, r25679, MPFR_RNDN);
        mpfr_sub(r25684, r25683, r25679, MPFR_RNDN);
        mpfr_add(r25685, r25684, r25610, MPFR_RNDN);
        mpfr_mul(r25686, r25619, r25662, MPFR_RNDN);
        mpfr_mul(r25687, r25616, r25664, MPFR_RNDN);
        mpfr_add(r25688, r25686, r25687, MPFR_RNDN);
        mpfr_mul(r25689, r25659, r25688, MPFR_RNDN);
        mpfr_mul(r25690, r25629, r25665, MPFR_RNDN);
        mpfr_add(r25691, r25689, r25690, MPFR_RNDN);
        mpfr_mul(r25692, r25685, r25691, MPFR_RNDN);
        mpfr_sub(r25693, r25682, r25692, MPFR_RNDN);
        mpfr_mul(r25694, r25685, r25666, MPFR_RNDN);
        mpfr_div(r25695, r25693, r25694, MPFR_RNDN);
        mpfr_cbrt(r25696, r25695, MPFR_RNDN);
        mpfr_mul(r25697, r25696, r25649, MPFR_RNDN);
        mpfr_mul(r25698, r25649, r25697, MPFR_RNDN);
        mpfr_add(r25699, r25610, r25672, MPFR_RNDN);
        mpfr_add(r25700, r25699, r25678, MPFR_RNDN);
        mpfr_div(r25701, r25610, r25662, MPFR_RNDN);
        mpfr_mul(r25702, r25616, r25701, MPFR_RNDN);
        mpfr_div(r25703, r25610, r25659, MPFR_RNDN);
        mpfr_mul(r25704, r25703, r25629, MPFR_RNDN);
        mpfr_div(r25705, r25610, r25664, MPFR_RNDN);
        mpfr_mul(r25706, r25619, r25705, MPFR_RNDN);
        mpfr_add(r25707, r25704, r25706, MPFR_RNDN);
        mpfr_add(r25708, r25702, r25707, MPFR_RNDN);
        mpfr_sub(r25709, r25700, r25708, MPFR_RNDN);
        mpfr_cbrt(r25710, r25709, MPFR_RNDN);
        mpfr_add(r25711, r25610, r25679, MPFR_RNDN);
        mpfr_add(r25712, r25706, r25702, MPFR_RNDN);
        mpfr_add(r25713, r25704, r25712, MPFR_RNDN);
        mpfr_sub(r25714, r25711, r25713, MPFR_RNDN);
        mpfr_cbrt(r25715, r25714, MPFR_RNDN);
        mpfr_mul(r25716, r25710, r25715, MPFR_RNDN);
        mpfr_mul(r25717, r25649, r25716, MPFR_RNDN);
        if (mpfr_get_si(r25653, MPFR_RNDN)) { mpfr_set(r25718, r25698, MPFR_RNDN); } else { mpfr_set(r25718, r25717, MPFR_RNDN); };
        if (mpfr_get_si(r25609, MPFR_RNDN)) { mpfr_set(r25719, r25651, MPFR_RNDN); } else { mpfr_set(r25719, r25718, MPFR_RNDN); };
        return mpfr_get_d(r25719, MPFR_RNDN);
}

