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

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

double f_if(float z) {
        float r17283 = atan2(1.0, 0.0);
        float r17284 = 2.0f;
        float r17285 = r17283 * r17284;
        float r17286 = sqrt(r17285);
        float r17287 = z;
        float r17288 = 1.0f;
        float r17289 = r17287 - r17288;
        float r17290 = 7.0f;
        float r17291 = r17289 + r17290;
        float r17292 = 0.5f;
        float r17293 = r17291 + r17292;
        float r17294 = r17289 + r17292;
        float r17295 = pow(r17293, r17294);
        float r17296 = r17286 * r17295;
        float r17297 = -r17293;
        float r17298 = exp(r17297);
        float r17299 = r17296 * r17298;
        float r17300 = 0.9999999999998099f;
        float r17301 = 676.5203681218851f;
        float r17302 = r17289 + r17288;
        float r17303 = r17301 / r17302;
        float r17304 = r17300 + r17303;
        float r17305 = -1259.1392167224028f;
        float r17306 = r17289 + r17284;
        float r17307 = r17305 / r17306;
        float r17308 = r17304 + r17307;
        float r17309 = 771.3234287776531f;
        float r17310 = 3.0f;
        float r17311 = r17289 + r17310;
        float r17312 = r17309 / r17311;
        float r17313 = r17308 + r17312;
        float r17314 = -176.6150291621406f;
        float r17315 = 4.0f;
        float r17316 = r17289 + r17315;
        float r17317 = r17314 / r17316;
        float r17318 = r17313 + r17317;
        float r17319 = 12.507343278686905f;
        float r17320 = 5.0f;
        float r17321 = r17289 + r17320;
        float r17322 = r17319 / r17321;
        float r17323 = r17318 + r17322;
        float r17324 = -0.13857109526572012f;
        float r17325 = 6.0f;
        float r17326 = r17289 + r17325;
        float r17327 = r17324 / r17326;
        float r17328 = r17323 + r17327;
        float r17329 = 9.984369578019572e-06f;
        float r17330 = r17329 / r17291;
        float r17331 = r17328 + r17330;
        float r17332 = 1.5056327351493116e-07f;
        float r17333 = 8.0f;
        float r17334 = r17289 + r17333;
        float r17335 = r17332 / r17334;
        float r17336 = r17331 + r17335;
        float r17337 = r17299 * r17336;
        return r17337;
}

double f_id(double z) {
        double r17338 = atan2(1.0, 0.0);
        double r17339 = 2.0;
        double r17340 = r17338 * r17339;
        double r17341 = sqrt(r17340);
        double r17342 = z;
        double r17343 = 1.0;
        double r17344 = r17342 - r17343;
        double r17345 = 7.0;
        double r17346 = r17344 + r17345;
        double r17347 = 0.5;
        double r17348 = r17346 + r17347;
        double r17349 = r17344 + r17347;
        double r17350 = pow(r17348, r17349);
        double r17351 = r17341 * r17350;
        double r17352 = -r17348;
        double r17353 = exp(r17352);
        double r17354 = r17351 * r17353;
        double r17355 = 0.9999999999998099;
        double r17356 = 676.5203681218851;
        double r17357 = r17344 + r17343;
        double r17358 = r17356 / r17357;
        double r17359 = r17355 + r17358;
        double r17360 = -1259.1392167224028;
        double r17361 = r17344 + r17339;
        double r17362 = r17360 / r17361;
        double r17363 = r17359 + r17362;
        double r17364 = 771.3234287776531;
        double r17365 = 3.0;
        double r17366 = r17344 + r17365;
        double r17367 = r17364 / r17366;
        double r17368 = r17363 + r17367;
        double r17369 = -176.6150291621406;
        double r17370 = 4.0;
        double r17371 = r17344 + r17370;
        double r17372 = r17369 / r17371;
        double r17373 = r17368 + r17372;
        double r17374 = 12.507343278686905;
        double r17375 = 5.0;
        double r17376 = r17344 + r17375;
        double r17377 = r17374 / r17376;
        double r17378 = r17373 + r17377;
        double r17379 = -0.13857109526572012;
        double r17380 = 6.0;
        double r17381 = r17344 + r17380;
        double r17382 = r17379 / r17381;
        double r17383 = r17378 + r17382;
        double r17384 = 9.984369578019572e-06;
        double r17385 = r17384 / r17346;
        double r17386 = r17383 + r17385;
        double r17387 = 1.5056327351493116e-07;
        double r17388 = 8.0;
        double r17389 = r17344 + r17388;
        double r17390 = r17387 / r17389;
        double r17391 = r17386 + r17390;
        double r17392 = r17354 * r17391;
        return r17392;
}


double f_of(float z) {
        float r17393 = 1.5056327351493116e-07f;
        float r17394 = z;
        float r17395 = 8.0f;
        float r17396 = r17394 + r17395;
        float r17397 = 1.0f;
        float r17398 = r17396 - r17397;
        float r17399 = r17393 / r17398;
        float r17400 = 9.984369578019572e-06f;
        float r17401 = 7.0f;
        float r17402 = r17394 - r17397;
        float r17403 = r17401 + r17402;
        float r17404 = r17400 / r17403;
        float r17405 = r17399 + r17404;
        float r17406 = -0.13857109526572012f;
        float r17407 = 6.0f;
        float r17408 = r17402 + r17407;
        float r17409 = r17406 / r17408;
        float r17410 = 12.507343278686905f;
        float r17411 = 5.0f;
        float r17412 = r17397 - r17411;
        float r17413 = r17394 - r17412;
        float r17414 = r17410 / r17413;
        float r17415 = r17409 + r17414;
        float r17416 = r17405 + r17415;
        float r17417 = -1259.1392167224028f;
        float r17418 = 2.0f;
        float r17419 = r17397 - r17418;
        float r17420 = r17394 - r17419;
        float r17421 = r17417 / r17420;
        float r17422 = 771.3234287776531f;
        float r17423 = 3.0f;
        float r17424 = r17402 + r17423;
        float r17425 = r17422 / r17424;
        float r17426 = r17421 + r17425;
        float r17427 = 676.5203681218851f;
        float r17428 = 0.0f;
        float r17429 = r17394 - r17428;
        float r17430 = r17427 / r17429;
        float r17431 = 0.9999999999998099f;
        float r17432 = r17430 + r17431;
        float r17433 = -176.6150291621406f;
        float r17434 = 4.0f;
        float r17435 = r17394 + r17434;
        float r17436 = r17435 - r17397;
        float r17437 = r17433 / r17436;
        float r17438 = r17432 + r17437;
        float r17439 = r17426 + r17438;
        float r17440 = r17416 + r17439;
        float r17441 = 0.5f;
        float r17442 = r17441 + r17401;
        float r17443 = r17402 + r17442;
        float r17444 = r17441 + r17402;
        float r17445 = pow(r17443, r17444);
        float r17446 = r17445 / r17397;
        float r17447 = r17440 * r17446;
        float r17448 = atan2(1.0, 0.0);
        float r17449 = r17418 * r17448;
        float r17450 = sqrt(r17449);
        float r17451 = exp(r17443);
        float r17452 = r17450 / r17451;
        float r17453 = r17447 * r17452;
        return r17453;
}

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

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 r17515, r17516, r17517, r17518, r17519, r17520, r17521, r17522, 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;

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

double f_im(double z) {
        mpfr_const_pi(r17515, MPFR_RNDN);
        ;
        mpfr_mul(r17517, r17515, r17516, MPFR_RNDN);
        mpfr_sqrt(r17518, r17517, MPFR_RNDN);
        mpfr_set_d(r17519, z, MPFR_RNDN);
        ;
        mpfr_sub(r17521, r17519, r17520, MPFR_RNDN);
        ;
        mpfr_add(r17523, r17521, r17522, MPFR_RNDN);
        ;
        mpfr_add(r17525, r17523, r17524, MPFR_RNDN);
        mpfr_add(r17526, r17521, r17524, MPFR_RNDN);
        mpfr_pow(r17527, r17525, r17526, MPFR_RNDN);
        mpfr_mul(r17528, r17518, r17527, MPFR_RNDN);
        mpfr_neg(r17529, r17525, MPFR_RNDN);
        mpfr_exp(r17530, r17529, MPFR_RNDN);
        mpfr_mul(r17531, r17528, r17530, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17534, r17521, r17520, MPFR_RNDN);
        mpfr_div(r17535, r17533, r17534, MPFR_RNDN);
        mpfr_add(r17536, r17532, r17535, MPFR_RNDN);
        ;
        mpfr_add(r17538, r17521, r17516, MPFR_RNDN);
        mpfr_div(r17539, r17537, r17538, MPFR_RNDN);
        mpfr_add(r17540, r17536, r17539, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17543, r17521, r17542, MPFR_RNDN);
        mpfr_div(r17544, r17541, r17543, MPFR_RNDN);
        mpfr_add(r17545, r17540, r17544, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17548, r17521, r17547, MPFR_RNDN);
        mpfr_div(r17549, r17546, r17548, MPFR_RNDN);
        mpfr_add(r17550, r17545, r17549, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17553, r17521, r17552, MPFR_RNDN);
        mpfr_div(r17554, r17551, r17553, MPFR_RNDN);
        mpfr_add(r17555, r17550, r17554, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17558, r17521, r17557, MPFR_RNDN);
        mpfr_div(r17559, r17556, r17558, MPFR_RNDN);
        mpfr_add(r17560, r17555, r17559, MPFR_RNDN);
        ;
        mpfr_div(r17562, r17561, r17523, MPFR_RNDN);
        mpfr_add(r17563, r17560, r17562, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17566, r17521, r17565, MPFR_RNDN);
        mpfr_div(r17567, r17564, r17566, MPFR_RNDN);
        mpfr_add(r17568, r17563, r17567, MPFR_RNDN);
        mpfr_mul(r17569, r17531, r17568, MPFR_RNDN);
        return mpfr_get_d(r17569, MPFR_RNDN);
}

static mpfr_t r17570, r17571, r17572, r17573, r17574, r17575, r17576, r17577, r17578, r17579, r17580, r17581, r17582, 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;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r17570, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init(r17571);
        mpfr_init_set_str(r17572, "8", 10, MPFR_RNDN);
        mpfr_init(r17573);
        mpfr_init_set_str(r17574, "1", 10, MPFR_RNDN);
        mpfr_init(r17575);
        mpfr_init(r17576);
        mpfr_init_set_str(r17577, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r17578, "7", 10, MPFR_RNDN);
        mpfr_init(r17579);
        mpfr_init(r17580);
        mpfr_init(r17581);
        mpfr_init(r17582);
        mpfr_init_set_str(r17583, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r17584, "6", 10, MPFR_RNDN);
        mpfr_init(r17585);
        mpfr_init(r17586);
        mpfr_init_set_str(r17587, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r17588, "5", 10, MPFR_RNDN);
        mpfr_init(r17589);
        mpfr_init(r17590);
        mpfr_init(r17591);
        mpfr_init(r17592);
        mpfr_init(r17593);
        mpfr_init_set_str(r17594, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init_set_str(r17595, "2", 10, MPFR_RNDN);
        mpfr_init(r17596);
        mpfr_init(r17597);
        mpfr_init(r17598);
        mpfr_init_set_str(r17599, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r17600, "3", 10, MPFR_RNDN);
        mpfr_init(r17601);
        mpfr_init(r17602);
        mpfr_init(r17603);
        mpfr_init_set_str(r17604, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r17605, "0", 10, MPFR_RNDN);
        mpfr_init(r17606);
        mpfr_init(r17607);
        mpfr_init_set_str(r17608, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init(r17609);
        mpfr_init_set_str(r17610, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r17611, "4", 10, MPFR_RNDN);
        mpfr_init(r17612);
        mpfr_init(r17613);
        mpfr_init(r17614);
        mpfr_init(r17615);
        mpfr_init(r17616);
        mpfr_init(r17617);
        mpfr_init_set_str(r17618, "0.5", 10, MPFR_RNDN);
        mpfr_init(r17619);
        mpfr_init(r17620);
        mpfr_init(r17621);
        mpfr_init(r17622);
        mpfr_init(r17623);
        mpfr_init(r17624);
        mpfr_init(r17625);
        mpfr_init(r17626);
        mpfr_init(r17627);
        mpfr_init(r17628);
        mpfr_init(r17629);
        mpfr_init(r17630);
}

double f_fm(double z) {
        ;
        mpfr_set_d(r17571, z, MPFR_RNDN);
        ;
        mpfr_add(r17573, r17571, r17572, MPFR_RNDN);
        ;
        mpfr_sub(r17575, r17573, r17574, MPFR_RNDN);
        mpfr_div(r17576, r17570, r17575, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17579, r17571, r17574, MPFR_RNDN);
        mpfr_add(r17580, r17578, r17579, MPFR_RNDN);
        mpfr_div(r17581, r17577, r17580, MPFR_RNDN);
        mpfr_add(r17582, r17576, r17581, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17585, r17579, r17584, MPFR_RNDN);
        mpfr_div(r17586, r17583, r17585, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17589, r17574, r17588, MPFR_RNDN);
        mpfr_sub(r17590, r17571, r17589, MPFR_RNDN);
        mpfr_div(r17591, r17587, r17590, MPFR_RNDN);
        mpfr_add(r17592, r17586, r17591, MPFR_RNDN);
        mpfr_add(r17593, r17582, r17592, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17596, r17574, r17595, MPFR_RNDN);
        mpfr_sub(r17597, r17571, r17596, MPFR_RNDN);
        mpfr_div(r17598, r17594, r17597, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17601, r17579, r17600, MPFR_RNDN);
        mpfr_div(r17602, r17599, r17601, MPFR_RNDN);
        mpfr_add(r17603, r17598, r17602, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17606, r17571, r17605, MPFR_RNDN);
        mpfr_div(r17607, r17604, r17606, MPFR_RNDN);
        ;
        mpfr_add(r17609, r17607, r17608, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17612, r17571, r17611, MPFR_RNDN);
        mpfr_sub(r17613, r17612, r17574, MPFR_RNDN);
        mpfr_div(r17614, r17610, r17613, MPFR_RNDN);
        mpfr_add(r17615, r17609, r17614, MPFR_RNDN);
        mpfr_add(r17616, r17603, r17615, MPFR_RNDN);
        mpfr_add(r17617, r17593, r17616, MPFR_RNDN);
        ;
        mpfr_add(r17619, r17618, r17578, MPFR_RNDN);
        mpfr_add(r17620, r17579, r17619, MPFR_RNDN);
        mpfr_add(r17621, r17618, r17579, MPFR_RNDN);
        mpfr_pow(r17622, r17620, r17621, MPFR_RNDN);
        mpfr_div(r17623, r17622, r17574, MPFR_RNDN);
        mpfr_mul(r17624, r17617, r17623, MPFR_RNDN);
        mpfr_const_pi(r17625, MPFR_RNDN);
        mpfr_mul(r17626, r17595, r17625, MPFR_RNDN);
        mpfr_sqrt(r17627, r17626, MPFR_RNDN);
        mpfr_exp(r17628, r17620, MPFR_RNDN);
        mpfr_div(r17629, r17627, r17628, MPFR_RNDN);
        mpfr_mul(r17630, r17624, r17629, MPFR_RNDN);
        return mpfr_get_d(r17630, MPFR_RNDN);
}

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

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r17631, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init(r17632);
        mpfr_init_set_str(r17633, "8", 10, MPFR_RNDN);
        mpfr_init(r17634);
        mpfr_init_set_str(r17635, "1", 10, MPFR_RNDN);
        mpfr_init(r17636);
        mpfr_init(r17637);
        mpfr_init_set_str(r17638, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r17639, "7", 10, MPFR_RNDN);
        mpfr_init(r17640);
        mpfr_init(r17641);
        mpfr_init(r17642);
        mpfr_init(r17643);
        mpfr_init_set_str(r17644, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r17645, "6", 10, MPFR_RNDN);
        mpfr_init(r17646);
        mpfr_init(r17647);
        mpfr_init_set_str(r17648, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r17649, "5", 10, MPFR_RNDN);
        mpfr_init(r17650);
        mpfr_init(r17651);
        mpfr_init(r17652);
        mpfr_init(r17653);
        mpfr_init(r17654);
        mpfr_init_set_str(r17655, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init_set_str(r17656, "2", 10, MPFR_RNDN);
        mpfr_init(r17657);
        mpfr_init(r17658);
        mpfr_init(r17659);
        mpfr_init_set_str(r17660, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r17661, "3", 10, MPFR_RNDN);
        mpfr_init(r17662);
        mpfr_init(r17663);
        mpfr_init(r17664);
        mpfr_init_set_str(r17665, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r17666, "0", 10, MPFR_RNDN);
        mpfr_init(r17667);
        mpfr_init(r17668);
        mpfr_init_set_str(r17669, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init(r17670);
        mpfr_init_set_str(r17671, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r17672, "4", 10, MPFR_RNDN);
        mpfr_init(r17673);
        mpfr_init(r17674);
        mpfr_init(r17675);
        mpfr_init(r17676);
        mpfr_init(r17677);
        mpfr_init(r17678);
        mpfr_init_set_str(r17679, "0.5", 10, MPFR_RNDN);
        mpfr_init(r17680);
        mpfr_init(r17681);
        mpfr_init(r17682);
        mpfr_init(r17683);
        mpfr_init(r17684);
        mpfr_init(r17685);
        mpfr_init(r17686);
        mpfr_init(r17687);
        mpfr_init(r17688);
        mpfr_init(r17689);
        mpfr_init(r17690);
        mpfr_init(r17691);
}

double f_dm(double z) {
        ;
        mpfr_set_d(r17632, z, MPFR_RNDN);
        ;
        mpfr_add(r17634, r17632, r17633, MPFR_RNDN);
        ;
        mpfr_sub(r17636, r17634, r17635, MPFR_RNDN);
        mpfr_div(r17637, r17631, r17636, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17640, r17632, r17635, MPFR_RNDN);
        mpfr_add(r17641, r17639, r17640, MPFR_RNDN);
        mpfr_div(r17642, r17638, r17641, MPFR_RNDN);
        mpfr_add(r17643, r17637, r17642, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17646, r17640, r17645, MPFR_RNDN);
        mpfr_div(r17647, r17644, r17646, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17650, r17635, r17649, MPFR_RNDN);
        mpfr_sub(r17651, r17632, r17650, MPFR_RNDN);
        mpfr_div(r17652, r17648, r17651, MPFR_RNDN);
        mpfr_add(r17653, r17647, r17652, MPFR_RNDN);
        mpfr_add(r17654, r17643, r17653, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17657, r17635, r17656, MPFR_RNDN);
        mpfr_sub(r17658, r17632, r17657, MPFR_RNDN);
        mpfr_div(r17659, r17655, r17658, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17662, r17640, r17661, MPFR_RNDN);
        mpfr_div(r17663, r17660, r17662, MPFR_RNDN);
        mpfr_add(r17664, r17659, r17663, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r17667, r17632, r17666, MPFR_RNDN);
        mpfr_div(r17668, r17665, r17667, MPFR_RNDN);
        ;
        mpfr_add(r17670, r17668, r17669, MPFR_RNDN);
        ;
        ;
        mpfr_add(r17673, r17632, r17672, MPFR_RNDN);
        mpfr_sub(r17674, r17673, r17635, MPFR_RNDN);
        mpfr_div(r17675, r17671, r17674, MPFR_RNDN);
        mpfr_add(r17676, r17670, r17675, MPFR_RNDN);
        mpfr_add(r17677, r17664, r17676, MPFR_RNDN);
        mpfr_add(r17678, r17654, r17677, MPFR_RNDN);
        ;
        mpfr_add(r17680, r17679, r17639, MPFR_RNDN);
        mpfr_add(r17681, r17640, r17680, MPFR_RNDN);
        mpfr_add(r17682, r17679, r17640, MPFR_RNDN);
        mpfr_pow(r17683, r17681, r17682, MPFR_RNDN);
        mpfr_div(r17684, r17683, r17635, MPFR_RNDN);
        mpfr_mul(r17685, r17678, r17684, MPFR_RNDN);
        mpfr_const_pi(r17686, MPFR_RNDN);
        mpfr_mul(r17687, r17656, r17686, MPFR_RNDN);
        mpfr_sqrt(r17688, r17687, MPFR_RNDN);
        mpfr_exp(r17689, r17681, MPFR_RNDN);
        mpfr_div(r17690, r17688, r17689, MPFR_RNDN);
        mpfr_mul(r17691, r17685, r17690, MPFR_RNDN);
        return mpfr_get_d(r17691, MPFR_RNDN);
}

