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

char *name = "Jmat.Real.gamma, branch z less than 0.5";

double f_if(float z) {
        float r17255 = atan2(1.0, 0.0);
        float r17256 = z;
        float r17257 = r17255 * r17256;
        float r17258 = sin(r17257);
        float r17259 = r17255 / r17258;
        float r17260 = 2.0f;
        float r17261 = r17255 * r17260;
        float r17262 = sqrt(r17261);
        float r17263 = 1.0f;
        float r17264 = r17263 - r17256;
        float r17265 = r17264 - r17263;
        float r17266 = 7.0f;
        float r17267 = r17265 + r17266;
        float r17268 = 0.5f;
        float r17269 = r17267 + r17268;
        float r17270 = r17265 + r17268;
        float r17271 = pow(r17269, r17270);
        float r17272 = r17262 * r17271;
        float r17273 = -r17269;
        float r17274 = exp(r17273);
        float r17275 = r17272 * r17274;
        float r17276 = 0.9999999999998099f;
        float r17277 = 676.5203681218851f;
        float r17278 = r17265 + r17263;
        float r17279 = r17277 / r17278;
        float r17280 = r17276 + r17279;
        float r17281 = -1259.1392167224028f;
        float r17282 = r17265 + r17260;
        float r17283 = r17281 / r17282;
        float r17284 = r17280 + r17283;
        float r17285 = 771.3234287776531f;
        float r17286 = 3.0f;
        float r17287 = r17265 + r17286;
        float r17288 = r17285 / r17287;
        float r17289 = r17284 + r17288;
        float r17290 = -176.6150291621406f;
        float r17291 = 4.0f;
        float r17292 = r17265 + r17291;
        float r17293 = r17290 / r17292;
        float r17294 = r17289 + r17293;
        float r17295 = 12.507343278686905f;
        float r17296 = 5.0f;
        float r17297 = r17265 + r17296;
        float r17298 = r17295 / r17297;
        float r17299 = r17294 + r17298;
        float r17300 = -0.13857109526572012f;
        float r17301 = 6.0f;
        float r17302 = r17265 + r17301;
        float r17303 = r17300 / r17302;
        float r17304 = r17299 + r17303;
        float r17305 = 9.984369578019572e-06f;
        float r17306 = r17305 / r17267;
        float r17307 = r17304 + r17306;
        float r17308 = 1.5056327351493116e-07f;
        float r17309 = 8.0f;
        float r17310 = r17265 + r17309;
        float r17311 = r17308 / r17310;
        float r17312 = r17307 + r17311;
        float r17313 = r17275 * r17312;
        float r17314 = r17259 * r17313;
        return r17314;
}

double f_id(double z) {
        double r17315 = atan2(1.0, 0.0);
        double r17316 = z;
        double r17317 = r17315 * r17316;
        double r17318 = sin(r17317);
        double r17319 = r17315 / r17318;
        double r17320 = 2.0;
        double r17321 = r17315 * r17320;
        double r17322 = sqrt(r17321);
        double r17323 = 1.0;
        double r17324 = r17323 - r17316;
        double r17325 = r17324 - r17323;
        double r17326 = 7.0;
        double r17327 = r17325 + r17326;
        double r17328 = 0.5;
        double r17329 = r17327 + r17328;
        double r17330 = r17325 + r17328;
        double r17331 = pow(r17329, r17330);
        double r17332 = r17322 * r17331;
        double r17333 = -r17329;
        double r17334 = exp(r17333);
        double r17335 = r17332 * r17334;
        double r17336 = 0.9999999999998099;
        double r17337 = 676.5203681218851;
        double r17338 = r17325 + r17323;
        double r17339 = r17337 / r17338;
        double r17340 = r17336 + r17339;
        double r17341 = -1259.1392167224028;
        double r17342 = r17325 + r17320;
        double r17343 = r17341 / r17342;
        double r17344 = r17340 + r17343;
        double r17345 = 771.3234287776531;
        double r17346 = 3.0;
        double r17347 = r17325 + r17346;
        double r17348 = r17345 / r17347;
        double r17349 = r17344 + r17348;
        double r17350 = -176.6150291621406;
        double r17351 = 4.0;
        double r17352 = r17325 + r17351;
        double r17353 = r17350 / r17352;
        double r17354 = r17349 + r17353;
        double r17355 = 12.507343278686905;
        double r17356 = 5.0;
        double r17357 = r17325 + r17356;
        double r17358 = r17355 / r17357;
        double r17359 = r17354 + r17358;
        double r17360 = -0.13857109526572012;
        double r17361 = 6.0;
        double r17362 = r17325 + r17361;
        double r17363 = r17360 / r17362;
        double r17364 = r17359 + r17363;
        double r17365 = 9.984369578019572e-06;
        double r17366 = r17365 / r17327;
        double r17367 = r17364 + r17366;
        double r17368 = 1.5056327351493116e-07;
        double r17369 = 8.0;
        double r17370 = r17325 + r17369;
        double r17371 = r17368 / r17370;
        double r17372 = r17367 + r17371;
        double r17373 = r17335 * r17372;
        double r17374 = r17319 * r17373;
        return r17374;
}


double f_of(float z) {
        float r17375 = atan2(1.0, 0.0);
        float r17376 = 2.0f;
        float r17377 = r17375 * r17376;
        float r17378 = sqrt(r17377);
        float r17379 = r17375 * r17378;
        float r17380 = z;
        float r17381 = r17380 * r17375;
        float r17382 = sin(r17381);
        float r17383 = r17379 / r17382;
        float r17384 = 0.5f;
        float r17385 = 7.0f;
        float r17386 = r17384 + r17385;
        float r17387 = 1.0f;
        float r17388 = r17387 + r17380;
        float r17389 = r17387 - r17388;
        float r17390 = r17386 + r17389;
        float r17391 = r17387 + r17384;
        float r17392 = r17391 - r17388;
        float r17393 = pow(r17390, r17392);
        float r17394 = -r17380;
        float r17395 = exp(r17394);
        float r17396 = log(r17395);
        float r17397 = r17386 + r17396;
        float r17398 = exp(r17397);
        float r17399 = r17393 / r17398;
        float r17400 = r17383 * r17399;
        float r17401 = 1.5056327351493116e-07f;
        float r17402 = 8.0f;
        float r17403 = r17387 + r17402;
        float r17404 = r17403 - r17388;
        float r17405 = r17401 / r17404;
        float r17406 = -0.13857109526572012f;
        float r17407 = r17387 - r17380;
        float r17408 = 6.0f;
        float r17409 = r17387 - r17408;
        float r17410 = r17407 - r17409;
        float r17411 = r17406 / r17410;
        float r17412 = 9.984369578019572e-06f;
        float r17413 = -1.0f;
        float r17414 = fma(r17380, r17413, r17385);
        float r17415 = r17412 / r17414;
        float r17416 = r17411 + r17415;
        float r17417 = r17405 + r17416;
        float r17418 = -176.6150291621406f;
        float r17419 = 4.0f;
        float r17420 = r17387 - r17419;
        float r17421 = r17407 - r17420;
        float r17422 = r17418 / r17421;
        float r17423 = 12.507343278686905f;
        float r17424 = 5.0f;
        float r17425 = r17387 + r17424;
        float r17426 = r17425 - r17388;
        float r17427 = r17423 / r17426;
        float r17428 = r17422 + r17427;
        float r17429 = 0.9999999999998099f;
        float r17430 = 676.5203681218851f;
        float r17431 = 0.0f;
        float r17432 = r17407 - r17431;
        float r17433 = r17430 / r17432;
        float r17434 = r17429 + r17433;
        float r17435 = r17428 + r17434;
        float r17436 = 771.3234287776531f;
        float r17437 = 3.0f;
        float r17438 = r17387 + r17437;
        float r17439 = r17438 - r17388;
        float r17440 = r17436 / r17439;
        float r17441 = -1259.1392167224028f;
        float r17442 = r17387 - r17376;
        float r17443 = r17407 - r17442;
        float r17444 = r17441 / r17443;
        float r17445 = r17440 + r17444;
        float r17446 = r17435 + r17445;
        float r17447 = r17417 + r17446;
        float r17448 = r17400 * r17447;
        return r17448;
}

double f_od(double z) {
        double r17449 = atan2(1.0, 0.0);
        double r17450 = 2.0;
        double r17451 = r17449 * r17450;
        double r17452 = sqrt(r17451);
        double r17453 = r17449 * r17452;
        double r17454 = z;
        double r17455 = r17454 * r17449;
        double r17456 = sin(r17455);
        double r17457 = r17453 / r17456;
        double r17458 = 0.5;
        double r17459 = 7.0;
        double r17460 = r17458 + r17459;
        double r17461 = 1.0;
        double r17462 = r17461 + r17454;
        double r17463 = r17461 - r17462;
        double r17464 = r17460 + r17463;
        double r17465 = r17461 + r17458;
        double r17466 = r17465 - r17462;
        double r17467 = pow(r17464, r17466);
        double r17468 = -r17454;
        double r17469 = exp(r17468);
        double r17470 = log(r17469);
        double r17471 = r17460 + r17470;
        double r17472 = exp(r17471);
        double r17473 = r17467 / r17472;
        double r17474 = r17457 * r17473;
        double r17475 = 1.5056327351493116e-07;
        double r17476 = 8.0;
        double r17477 = r17461 + r17476;
        double r17478 = r17477 - r17462;
        double r17479 = r17475 / r17478;
        double r17480 = -0.13857109526572012;
        double r17481 = r17461 - r17454;
        double r17482 = 6.0;
        double r17483 = r17461 - r17482;
        double r17484 = r17481 - r17483;
        double r17485 = r17480 / r17484;
        double r17486 = 9.984369578019572e-06;
        double r17487 = -1.0;
        double r17488 = fma(r17454, r17487, r17459);
        double r17489 = r17486 / r17488;
        double r17490 = r17485 + r17489;
        double r17491 = r17479 + r17490;
        double r17492 = -176.6150291621406;
        double r17493 = 4.0;
        double r17494 = r17461 - r17493;
        double r17495 = r17481 - r17494;
        double r17496 = r17492 / r17495;
        double r17497 = 12.507343278686905;
        double r17498 = 5.0;
        double r17499 = r17461 + r17498;
        double r17500 = r17499 - r17462;
        double r17501 = r17497 / r17500;
        double r17502 = r17496 + r17501;
        double r17503 = 0.9999999999998099;
        double r17504 = 676.5203681218851;
        double r17505 = 0.0;
        double r17506 = r17481 - r17505;
        double r17507 = r17504 / r17506;
        double r17508 = r17503 + r17507;
        double r17509 = r17502 + r17508;
        double r17510 = 771.3234287776531;
        double r17511 = 3.0;
        double r17512 = r17461 + r17511;
        double r17513 = r17512 - r17462;
        double r17514 = r17510 / r17513;
        double r17515 = -1259.1392167224028;
        double r17516 = r17461 - r17450;
        double r17517 = r17481 - r17516;
        double r17518 = r17515 / r17517;
        double r17519 = r17514 + r17518;
        double r17520 = r17509 + r17519;
        double r17521 = r17491 + r17520;
        double r17522 = r17474 * r17521;
        return r17522;
}

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 r17523, r17524, r17525, r17526, r17527, r17528, r17529, r17530, r17531, r17532, r17533, r17534, r17535, r17536, r17537, r17538, r17539, r17540, r17541, r17542, r17543, r17544, r17545, r17546, r17547, r17548, r17549, r17550, r17551, r17552, r17553, r17554, r17555, r17556, r17557, r17558, r17559, r17560, r17561, r17562, r17563, r17564, r17565, r17566, r17567, r17568, r17569, r17570, r17571, r17572, r17573, r17574, r17575, r17576, r17577, r17578, r17579, r17580, r17581, r17582;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init(r17523);
        mpfr_init(r17524);
        mpfr_init(r17525);
        mpfr_init(r17526);
        mpfr_init(r17527);
        mpfr_init_set_str(r17528, "2", 10, MPFR_RNDN);
        mpfr_init(r17529);
        mpfr_init(r17530);
        mpfr_init_set_str(r17531, "1", 10, MPFR_RNDN);
        mpfr_init(r17532);
        mpfr_init(r17533);
        mpfr_init_set_str(r17534, "7", 10, MPFR_RNDN);
        mpfr_init(r17535);
        mpfr_init_set_str(r17536, "0.5", 10, MPFR_RNDN);
        mpfr_init(r17537);
        mpfr_init(r17538);
        mpfr_init(r17539);
        mpfr_init(r17540);
        mpfr_init(r17541);
        mpfr_init(r17542);
        mpfr_init(r17543);
        mpfr_init_set_str(r17544, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r17545, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r17546);
        mpfr_init(r17547);
        mpfr_init(r17548);
        mpfr_init_set_str(r17549, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r17550);
        mpfr_init(r17551);
        mpfr_init(r17552);
        mpfr_init_set_str(r17553, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r17554, "3", 10, MPFR_RNDN);
        mpfr_init(r17555);
        mpfr_init(r17556);
        mpfr_init(r17557);
        mpfr_init_set_str(r17558, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r17559, "4", 10, MPFR_RNDN);
        mpfr_init(r17560);
        mpfr_init(r17561);
        mpfr_init(r17562);
        mpfr_init_set_str(r17563, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r17564, "5", 10, MPFR_RNDN);
        mpfr_init(r17565);
        mpfr_init(r17566);
        mpfr_init(r17567);
        mpfr_init_set_str(r17568, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r17569, "6", 10, MPFR_RNDN);
        mpfr_init(r17570);
        mpfr_init(r17571);
        mpfr_init(r17572);
        mpfr_init_set_str(r17573, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r17574);
        mpfr_init(r17575);
        mpfr_init_set_str(r17576, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r17577, "8", 10, MPFR_RNDN);
        mpfr_init(r17578);
        mpfr_init(r17579);
        mpfr_init(r17580);
        mpfr_init(r17581);
        mpfr_init(r17582);
}

double f_im(double z) {
        mpfr_const_pi(r17523, MPFR_RNDN);
        mpfr_set_d(r17524, z, MPFR_RNDN);
        mpfr_mul(r17525, r17523, r17524, MPFR_RNDN);
        mpfr_sin(r17526, r17525, MPFR_RNDN);
        mpfr_div(r17527, r17523, r17526, MPFR_RNDN);
        ;
        mpfr_mul(r17529, r17523, r17528, MPFR_RNDN);
        mpfr_sqrt(r17530, r17529, MPFR_RNDN);
        ;
        mpfr_sub(r17532, r17531, r17524, MPFR_RNDN);
        mpfr_sub(r17533, r17532, r17531, MPFR_RNDN);
        ;
        mpfr_add(r17535, r17533, r17534, MPFR_RNDN);
        ;
        mpfr_add(r17537, r17535, r17536, MPFR_RNDN);
        mpfr_add(r17538, r17533, r17536, MPFR_RNDN);
        mpfr_pow(r17539, r17537, r17538, MPFR_RNDN);
        mpfr_mul(r17540, r17530, r17539, MPFR_RNDN);
        mpfr_neg(r17541, r17537, MPFR_RNDN);
        mpfr_exp(r17542, r17541, MPFR_RNDN);
        mpfr_mul(r17543, r17540, r17542, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17546, r17533, r17531, MPFR_RNDN);
        mpfr_div(r17547, r17545, r17546, MPFR_RNDN);
        mpfr_add(r17548, r17544, r17547, MPFR_RNDN);
        ;
        mpfr_add(r17550, r17533, r17528, MPFR_RNDN);
        mpfr_div(r17551, r17549, r17550, MPFR_RNDN);
        mpfr_add(r17552, r17548, r17551, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17555, r17533, r17554, MPFR_RNDN);
        mpfr_div(r17556, r17553, r17555, MPFR_RNDN);
        mpfr_add(r17557, r17552, r17556, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17560, r17533, r17559, MPFR_RNDN);
        mpfr_div(r17561, r17558, r17560, MPFR_RNDN);
        mpfr_add(r17562, r17557, r17561, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17565, r17533, r17564, MPFR_RNDN);
        mpfr_div(r17566, r17563, r17565, MPFR_RNDN);
        mpfr_add(r17567, r17562, r17566, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17570, r17533, r17569, MPFR_RNDN);
        mpfr_div(r17571, r17568, r17570, MPFR_RNDN);
        mpfr_add(r17572, r17567, r17571, MPFR_RNDN);
        ;
        mpfr_div(r17574, r17573, r17535, MPFR_RNDN);
        mpfr_add(r17575, r17572, r17574, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17578, r17533, r17577, MPFR_RNDN);
        mpfr_div(r17579, r17576, r17578, MPFR_RNDN);
        mpfr_add(r17580, r17575, r17579, MPFR_RNDN);
        mpfr_mul(r17581, r17543, r17580, MPFR_RNDN);
        mpfr_mul(r17582, r17527, r17581, MPFR_RNDN);
        return mpfr_get_d(r17582, MPFR_RNDN);
}

static mpfr_t r17583, r17584, r17585, r17586, r17587, r17588, r17589, r17590, r17591, r17592, r17593, r17594, r17595, r17596, r17597, r17598, r17599, r17600, r17601, r17602, r17603, r17604, r17605, r17606, r17607, r17608, r17609, r17610, r17611, r17612, r17613, r17614, r17615, r17616, r17617, r17618, r17619, r17620, r17621, r17622, r17623, r17624, r17625, r17626, r17627, r17628, r17629, r17630, r17631, r17632, r17633, r17634, r17635, r17636, r17637, r17638, r17639, r17640, r17641, r17642, r17643, r17644, r17645, r17646, r17647, r17648, r17649, r17650, r17651, r17652, r17653, r17654, r17655, r17656;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17583);
        mpfr_init_set_str(r17584, "2", 10, MPFR_RNDN);
        mpfr_init(r17585);
        mpfr_init(r17586);
        mpfr_init(r17587);
        mpfr_init(r17588);
        mpfr_init(r17589);
        mpfr_init(r17590);
        mpfr_init(r17591);
        mpfr_init_set_str(r17592, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r17593, "7", 10, MPFR_RNDN);
        mpfr_init(r17594);
        mpfr_init_set_str(r17595, "1", 10, MPFR_RNDN);
        mpfr_init(r17596);
        mpfr_init(r17597);
        mpfr_init(r17598);
        mpfr_init(r17599);
        mpfr_init(r17600);
        mpfr_init(r17601);
        mpfr_init(r17602);
        mpfr_init(r17603);
        mpfr_init(r17604);
        mpfr_init(r17605);
        mpfr_init(r17606);
        mpfr_init(r17607);
        mpfr_init(r17608);
        mpfr_init_set_str(r17609, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r17610, "8", 10, MPFR_RNDN);
        mpfr_init(r17611);
        mpfr_init(r17612);
        mpfr_init(r17613);
        mpfr_init_set_str(r17614, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init(r17615);
        mpfr_init_set_str(r17616, "6", 10, MPFR_RNDN);
        mpfr_init(r17617);
        mpfr_init(r17618);
        mpfr_init(r17619);
        mpfr_init_set_str(r17620, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r17621, "-1", 10, MPFR_RNDN);
        mpfr_init(r17622);
        mpfr_init(r17623);
        mpfr_init(r17624);
        mpfr_init(r17625);
        mpfr_init_set_str(r17626, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r17627, "4", 10, MPFR_RNDN);
        mpfr_init(r17628);
        mpfr_init(r17629);
        mpfr_init(r17630);
        mpfr_init_set_str(r17631, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r17632, "5", 10, MPFR_RNDN);
        mpfr_init(r17633);
        mpfr_init(r17634);
        mpfr_init(r17635);
        mpfr_init(r17636);
        mpfr_init_set_str(r17637, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r17638, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r17639, "0", 10, MPFR_RNDN);
        mpfr_init(r17640);
        mpfr_init(r17641);
        mpfr_init(r17642);
        mpfr_init(r17643);
        mpfr_init_set_str(r17644, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r17645, "3", 10, MPFR_RNDN);
        mpfr_init(r17646);
        mpfr_init(r17647);
        mpfr_init(r17648);
        mpfr_init_set_str(r17649, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r17650);
        mpfr_init(r17651);
        mpfr_init(r17652);
        mpfr_init(r17653);
        mpfr_init(r17654);
        mpfr_init(r17655);
        mpfr_init(r17656);
}

double f_fm(double z) {
        mpfr_const_pi(r17583, MPFR_RNDN);
        ;
        mpfr_mul(r17585, r17583, r17584, MPFR_RNDN);
        mpfr_sqrt(r17586, r17585, MPFR_RNDN);
        mpfr_mul(r17587, r17583, r17586, MPFR_RNDN);
        mpfr_set_d(r17588, z, MPFR_RNDN);
        mpfr_mul(r17589, r17588, r17583, MPFR_RNDN);
        mpfr_sin(r17590, r17589, MPFR_RNDN);
        mpfr_div(r17591, r17587, r17590, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17594, r17592, r17593, MPFR_RNDN);
        ;
        mpfr_add(r17596, r17595, r17588, MPFR_RNDN);
        mpfr_sub(r17597, r17595, r17596, MPFR_RNDN);
        mpfr_add(r17598, r17594, r17597, MPFR_RNDN);
        mpfr_add(r17599, r17595, r17592, MPFR_RNDN);
        mpfr_sub(r17600, r17599, r17596, MPFR_RNDN);
        mpfr_pow(r17601, r17598, r17600, MPFR_RNDN);
        mpfr_neg(r17602, r17588, MPFR_RNDN);
        mpfr_exp(r17603, r17602, MPFR_RNDN);
        mpfr_log(r17604, r17603, MPFR_RNDN);
        mpfr_add(r17605, r17594, r17604, MPFR_RNDN);
        mpfr_exp(r17606, r17605, MPFR_RNDN);
        mpfr_div(r17607, r17601, r17606, MPFR_RNDN);
        mpfr_mul(r17608, r17591, r17607, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17611, r17595, r17610, MPFR_RNDN);
        mpfr_sub(r17612, r17611, r17596, MPFR_RNDN);
        mpfr_div(r17613, r17609, r17612, MPFR_RNDN);
        ;
        mpfr_sub(r17615, r17595, r17588, MPFR_RNDN);
        ;
        mpfr_sub(r17617, r17595, r17616, MPFR_RNDN);
        mpfr_sub(r17618, r17615, r17617, MPFR_RNDN);
        mpfr_div(r17619, r17614, r17618, MPFR_RNDN);
        ;
        ;
        mpfr_fma(r17622, r17588, r17621, r17593, MPFR_RNDN);
        mpfr_div(r17623, r17620, r17622, MPFR_RNDN);
        mpfr_add(r17624, r17619, r17623, MPFR_RNDN);
        mpfr_add(r17625, r17613, r17624, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17628, r17595, r17627, MPFR_RNDN);
        mpfr_sub(r17629, r17615, r17628, MPFR_RNDN);
        mpfr_div(r17630, r17626, r17629, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17633, r17595, r17632, MPFR_RNDN);
        mpfr_sub(r17634, r17633, r17596, MPFR_RNDN);
        mpfr_div(r17635, r17631, r17634, MPFR_RNDN);
        mpfr_add(r17636, r17630, r17635, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_sub(r17640, r17615, r17639, MPFR_RNDN);
        mpfr_div(r17641, r17638, r17640, MPFR_RNDN);
        mpfr_add(r17642, r17637, r17641, MPFR_RNDN);
        mpfr_add(r17643, r17636, r17642, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17646, r17595, r17645, MPFR_RNDN);
        mpfr_sub(r17647, r17646, r17596, MPFR_RNDN);
        mpfr_div(r17648, r17644, r17647, MPFR_RNDN);
        ;
        mpfr_sub(r17650, r17595, r17584, MPFR_RNDN);
        mpfr_sub(r17651, r17615, r17650, MPFR_RNDN);
        mpfr_div(r17652, r17649, r17651, MPFR_RNDN);
        mpfr_add(r17653, r17648, r17652, MPFR_RNDN);
        mpfr_add(r17654, r17643, r17653, MPFR_RNDN);
        mpfr_add(r17655, r17625, r17654, MPFR_RNDN);
        mpfr_mul(r17656, r17608, r17655, MPFR_RNDN);
        return mpfr_get_d(r17656, MPFR_RNDN);
}

static mpfr_t r17657, r17658, r17659, r17660, r17661, r17662, r17663, r17664, r17665, r17666, r17667, r17668, r17669, r17670, r17671, r17672, r17673, r17674, r17675, r17676, r17677, r17678, r17679, r17680, r17681, r17682, r17683, r17684, r17685, r17686, r17687, r17688, r17689, r17690, r17691, r17692, r17693, r17694, r17695, r17696, r17697, r17698, r17699, r17700, r17701, r17702, r17703, r17704, r17705, r17706, r17707, r17708, r17709, r17710, r17711, r17712, r17713, r17714, r17715, r17716, r17717, r17718, r17719, r17720, r17721, r17722, r17723, r17724, r17725, r17726, r17727, r17728, r17729, r17730;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17657);
        mpfr_init_set_str(r17658, "2", 10, MPFR_RNDN);
        mpfr_init(r17659);
        mpfr_init(r17660);
        mpfr_init(r17661);
        mpfr_init(r17662);
        mpfr_init(r17663);
        mpfr_init(r17664);
        mpfr_init(r17665);
        mpfr_init_set_str(r17666, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r17667, "7", 10, MPFR_RNDN);
        mpfr_init(r17668);
        mpfr_init_set_str(r17669, "1", 10, MPFR_RNDN);
        mpfr_init(r17670);
        mpfr_init(r17671);
        mpfr_init(r17672);
        mpfr_init(r17673);
        mpfr_init(r17674);
        mpfr_init(r17675);
        mpfr_init(r17676);
        mpfr_init(r17677);
        mpfr_init(r17678);
        mpfr_init(r17679);
        mpfr_init(r17680);
        mpfr_init(r17681);
        mpfr_init(r17682);
        mpfr_init_set_str(r17683, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r17684, "8", 10, MPFR_RNDN);
        mpfr_init(r17685);
        mpfr_init(r17686);
        mpfr_init(r17687);
        mpfr_init_set_str(r17688, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init(r17689);
        mpfr_init_set_str(r17690, "6", 10, MPFR_RNDN);
        mpfr_init(r17691);
        mpfr_init(r17692);
        mpfr_init(r17693);
        mpfr_init_set_str(r17694, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r17695, "-1", 10, MPFR_RNDN);
        mpfr_init(r17696);
        mpfr_init(r17697);
        mpfr_init(r17698);
        mpfr_init(r17699);
        mpfr_init_set_str(r17700, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r17701, "4", 10, MPFR_RNDN);
        mpfr_init(r17702);
        mpfr_init(r17703);
        mpfr_init(r17704);
        mpfr_init_set_str(r17705, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r17706, "5", 10, MPFR_RNDN);
        mpfr_init(r17707);
        mpfr_init(r17708);
        mpfr_init(r17709);
        mpfr_init(r17710);
        mpfr_init_set_str(r17711, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r17712, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r17713, "0", 10, MPFR_RNDN);
        mpfr_init(r17714);
        mpfr_init(r17715);
        mpfr_init(r17716);
        mpfr_init(r17717);
        mpfr_init_set_str(r17718, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r17719, "3", 10, MPFR_RNDN);
        mpfr_init(r17720);
        mpfr_init(r17721);
        mpfr_init(r17722);
        mpfr_init_set_str(r17723, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r17724);
        mpfr_init(r17725);
        mpfr_init(r17726);
        mpfr_init(r17727);
        mpfr_init(r17728);
        mpfr_init(r17729);
        mpfr_init(r17730);
}

double f_dm(double z) {
        mpfr_const_pi(r17657, MPFR_RNDN);
        ;
        mpfr_mul(r17659, r17657, r17658, MPFR_RNDN);
        mpfr_sqrt(r17660, r17659, MPFR_RNDN);
        mpfr_mul(r17661, r17657, r17660, MPFR_RNDN);
        mpfr_set_d(r17662, z, MPFR_RNDN);
        mpfr_mul(r17663, r17662, r17657, MPFR_RNDN);
        mpfr_sin(r17664, r17663, MPFR_RNDN);
        mpfr_div(r17665, r17661, r17664, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17668, r17666, r17667, MPFR_RNDN);
        ;
        mpfr_add(r17670, r17669, r17662, MPFR_RNDN);
        mpfr_sub(r17671, r17669, r17670, MPFR_RNDN);
        mpfr_add(r17672, r17668, r17671, MPFR_RNDN);
        mpfr_add(r17673, r17669, r17666, MPFR_RNDN);
        mpfr_sub(r17674, r17673, r17670, MPFR_RNDN);
        mpfr_pow(r17675, r17672, r17674, MPFR_RNDN);
        mpfr_neg(r17676, r17662, MPFR_RNDN);
        mpfr_exp(r17677, r17676, MPFR_RNDN);
        mpfr_log(r17678, r17677, MPFR_RNDN);
        mpfr_add(r17679, r17668, r17678, MPFR_RNDN);
        mpfr_exp(r17680, r17679, MPFR_RNDN);
        mpfr_div(r17681, r17675, r17680, MPFR_RNDN);
        mpfr_mul(r17682, r17665, r17681, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17685, r17669, r17684, MPFR_RNDN);
        mpfr_sub(r17686, r17685, r17670, MPFR_RNDN);
        mpfr_div(r17687, r17683, r17686, MPFR_RNDN);
        ;
        mpfr_sub(r17689, r17669, r17662, MPFR_RNDN);
        ;
        mpfr_sub(r17691, r17669, r17690, MPFR_RNDN);
        mpfr_sub(r17692, r17689, r17691, MPFR_RNDN);
        mpfr_div(r17693, r17688, r17692, MPFR_RNDN);
        ;
        ;
        mpfr_fma(r17696, r17662, r17695, r17667, MPFR_RNDN);
        mpfr_div(r17697, r17694, r17696, MPFR_RNDN);
        mpfr_add(r17698, r17693, r17697, MPFR_RNDN);
        mpfr_add(r17699, r17687, r17698, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17702, r17669, r17701, MPFR_RNDN);
        mpfr_sub(r17703, r17689, r17702, MPFR_RNDN);
        mpfr_div(r17704, r17700, r17703, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17707, r17669, r17706, MPFR_RNDN);
        mpfr_sub(r17708, r17707, r17670, MPFR_RNDN);
        mpfr_div(r17709, r17705, r17708, MPFR_RNDN);
        mpfr_add(r17710, r17704, r17709, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_sub(r17714, r17689, r17713, MPFR_RNDN);
        mpfr_div(r17715, r17712, r17714, MPFR_RNDN);
        mpfr_add(r17716, r17711, r17715, MPFR_RNDN);
        mpfr_add(r17717, r17710, r17716, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17720, r17669, r17719, MPFR_RNDN);
        mpfr_sub(r17721, r17720, r17670, MPFR_RNDN);
        mpfr_div(r17722, r17718, r17721, MPFR_RNDN);
        ;
        mpfr_sub(r17724, r17669, r17658, MPFR_RNDN);
        mpfr_sub(r17725, r17689, r17724, MPFR_RNDN);
        mpfr_div(r17726, r17723, r17725, MPFR_RNDN);
        mpfr_add(r17727, r17722, r17726, MPFR_RNDN);
        mpfr_add(r17728, r17717, r17727, MPFR_RNDN);
        mpfr_add(r17729, r17699, r17728, MPFR_RNDN);
        mpfr_mul(r17730, r17682, r17729, MPFR_RNDN);
        return mpfr_get_d(r17730, MPFR_RNDN);
}

