#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 r22411 = atan2(1.0, 0.0);
        float r22412 = z;
        float r22413 = r22411 * r22412;
        float r22414 = sin(r22413);
        float r22415 = r22411 / r22414;
        float r22416 = 2;
        float r22417 = r22411 * r22416;
        float r22418 = sqrt(r22417);
        float r22419 = 1;
        float r22420 = r22419 - r22412;
        float r22421 = r22420 - r22419;
        float r22422 = 7;
        float r22423 = r22421 + r22422;
        float r22424 = 0.5;
        float r22425 = r22423 + r22424;
        float r22426 = r22421 + r22424;
        float r22427 = pow(r22425, r22426);
        float r22428 = r22418 * r22427;
        float r22429 = -r22425;
        float r22430 = exp(r22429);
        float r22431 = r22428 * r22430;
        float r22432 = 0.9999999999998099;
        float r22433 = 676.5203681218851;
        float r22434 = r22421 + r22419;
        float r22435 = r22433 / r22434;
        float r22436 = r22432 + r22435;
        float r22437 = -1259.1392167224028;
        float r22438 = r22421 + r22416;
        float r22439 = r22437 / r22438;
        float r22440 = r22436 + r22439;
        float r22441 = 771.3234287776531;
        float r22442 = 3;
        float r22443 = r22421 + r22442;
        float r22444 = r22441 / r22443;
        float r22445 = r22440 + r22444;
        float r22446 = -176.6150291621406;
        float r22447 = 4;
        float r22448 = r22421 + r22447;
        float r22449 = r22446 / r22448;
        float r22450 = r22445 + r22449;
        float r22451 = 12.507343278686905;
        float r22452 = 5;
        float r22453 = r22421 + r22452;
        float r22454 = r22451 / r22453;
        float r22455 = r22450 + r22454;
        float r22456 = -0.13857109526572012;
        float r22457 = 6;
        float r22458 = r22421 + r22457;
        float r22459 = r22456 / r22458;
        float r22460 = r22455 + r22459;
        float r22461 = 9.984369578019572e-06;
        float r22462 = r22461 / r22423;
        float r22463 = r22460 + r22462;
        float r22464 = 1.5056327351493116e-07;
        float r22465 = 8;
        float r22466 = r22421 + r22465;
        float r22467 = r22464 / r22466;
        float r22468 = r22463 + r22467;
        float r22469 = r22431 * r22468;
        float r22470 = r22415 * r22469;
        return r22470;
}

double f_id(double z) {
        double r22471 = atan2(1.0, 0.0);
        double r22472 = z;
        double r22473 = r22471 * r22472;
        double r22474 = sin(r22473);
        double r22475 = r22471 / r22474;
        double r22476 = 2;
        double r22477 = r22471 * r22476;
        double r22478 = sqrt(r22477);
        double r22479 = 1;
        double r22480 = r22479 - r22472;
        double r22481 = r22480 - r22479;
        double r22482 = 7;
        double r22483 = r22481 + r22482;
        double r22484 = 0.5;
        double r22485 = r22483 + r22484;
        double r22486 = r22481 + r22484;
        double r22487 = pow(r22485, r22486);
        double r22488 = r22478 * r22487;
        double r22489 = -r22485;
        double r22490 = exp(r22489);
        double r22491 = r22488 * r22490;
        double r22492 = 0.9999999999998099;
        double r22493 = 676.5203681218851;
        double r22494 = r22481 + r22479;
        double r22495 = r22493 / r22494;
        double r22496 = r22492 + r22495;
        double r22497 = -1259.1392167224028;
        double r22498 = r22481 + r22476;
        double r22499 = r22497 / r22498;
        double r22500 = r22496 + r22499;
        double r22501 = 771.3234287776531;
        double r22502 = 3;
        double r22503 = r22481 + r22502;
        double r22504 = r22501 / r22503;
        double r22505 = r22500 + r22504;
        double r22506 = -176.6150291621406;
        double r22507 = 4;
        double r22508 = r22481 + r22507;
        double r22509 = r22506 / r22508;
        double r22510 = r22505 + r22509;
        double r22511 = 12.507343278686905;
        double r22512 = 5;
        double r22513 = r22481 + r22512;
        double r22514 = r22511 / r22513;
        double r22515 = r22510 + r22514;
        double r22516 = -0.13857109526572012;
        double r22517 = 6;
        double r22518 = r22481 + r22517;
        double r22519 = r22516 / r22518;
        double r22520 = r22515 + r22519;
        double r22521 = 9.984369578019572e-06;
        double r22522 = r22521 / r22483;
        double r22523 = r22520 + r22522;
        double r22524 = 1.5056327351493116e-07;
        double r22525 = 8;
        double r22526 = r22481 + r22525;
        double r22527 = r22524 / r22526;
        double r22528 = r22523 + r22527;
        double r22529 = r22491 * r22528;
        double r22530 = r22475 * r22529;
        return r22530;
}


double f_of(float z) {
        float r22531 = 1.5056327351493116e-07;
        float r22532 = 8;
        float r22533 = 0;
        float r22534 = r22532 + r22533;
        float r22535 = z;
        float r22536 = r22534 - r22535;
        float r22537 = r22531 / r22536;
        float r22538 = 9.984369578019572e-06;
        float r22539 = 7;
        float r22540 = r22539 + r22533;
        float r22541 = r22540 - r22535;
        float r22542 = r22538 / r22541;
        float r22543 = r22537 + r22542;
        float r22544 = 0.9999999999998099;
        float r22545 = 676.5203681218851;
        float r22546 = 1;
        float r22547 = r22546 - r22535;
        float r22548 = r22545 / r22547;
        float r22549 = r22544 + r22548;
        float r22550 = -1259.1392167224028;
        float r22551 = 2;
        float r22552 = r22533 - r22535;
        float r22553 = r22551 + r22552;
        float r22554 = r22550 / r22553;
        float r22555 = r22549 + r22554;
        float r22556 = r22543 + r22555;
        float r22557 = -176.6150291621406;
        float r22558 = 4;
        float r22559 = r22552 + r22558;
        float r22560 = r22557 / r22559;
        float r22561 = 771.3234287776531;
        float r22562 = 3;
        float r22563 = r22562 + r22552;
        float r22564 = r22561 / r22563;
        float r22565 = r22560 + r22564;
        float r22566 = -0.13857109526572012;
        float r22567 = 6;
        float r22568 = r22567 + r22552;
        float r22569 = r22566 / r22568;
        float r22570 = 12.507343278686905;
        float r22571 = 5;
        float r22572 = r22571 + r22533;
        float r22573 = r22572 - r22535;
        float r22574 = r22570 / r22573;
        float r22575 = r22569 + r22574;
        float r22576 = r22565 + r22575;
        float r22577 = r22556 + r22576;
        float r22578 = atan2(1.0, 0.0);
        float r22579 = r22535 * r22578;
        float r22580 = sin(r22579);
        float r22581 = r22578 / r22580;
        float r22582 = r22578 + r22578;
        float r22583 = sqrt(r22582);
        float r22584 = r22583 * r22582;
        float r22585 = 1/3;
        float r22586 = pow(r22584, r22585);
        float r22587 = r22581 * r22586;
        float r22588 = 0.5;
        float r22589 = r22539 + r22588;
        float r22590 = r22589 + r22552;
        float r22591 = exp(r22590);
        float r22592 = r22535 - r22588;
        float r22593 = r22533 - r22592;
        float r22594 = pow(r22590, r22593);
        float r22595 = r22591 / r22594;
        float r22596 = r22587 / r22595;
        float r22597 = r22577 * r22596;
        return r22597;
}

double f_od(double z) {
        double r22598 = 1.5056327351493116e-07;
        double r22599 = 8;
        double r22600 = 0;
        double r22601 = r22599 + r22600;
        double r22602 = z;
        double r22603 = r22601 - r22602;
        double r22604 = r22598 / r22603;
        double r22605 = 9.984369578019572e-06;
        double r22606 = 7;
        double r22607 = r22606 + r22600;
        double r22608 = r22607 - r22602;
        double r22609 = r22605 / r22608;
        double r22610 = r22604 + r22609;
        double r22611 = 0.9999999999998099;
        double r22612 = 676.5203681218851;
        double r22613 = 1;
        double r22614 = r22613 - r22602;
        double r22615 = r22612 / r22614;
        double r22616 = r22611 + r22615;
        double r22617 = -1259.1392167224028;
        double r22618 = 2;
        double r22619 = r22600 - r22602;
        double r22620 = r22618 + r22619;
        double r22621 = r22617 / r22620;
        double r22622 = r22616 + r22621;
        double r22623 = r22610 + r22622;
        double r22624 = -176.6150291621406;
        double r22625 = 4;
        double r22626 = r22619 + r22625;
        double r22627 = r22624 / r22626;
        double r22628 = 771.3234287776531;
        double r22629 = 3;
        double r22630 = r22629 + r22619;
        double r22631 = r22628 / r22630;
        double r22632 = r22627 + r22631;
        double r22633 = -0.13857109526572012;
        double r22634 = 6;
        double r22635 = r22634 + r22619;
        double r22636 = r22633 / r22635;
        double r22637 = 12.507343278686905;
        double r22638 = 5;
        double r22639 = r22638 + r22600;
        double r22640 = r22639 - r22602;
        double r22641 = r22637 / r22640;
        double r22642 = r22636 + r22641;
        double r22643 = r22632 + r22642;
        double r22644 = r22623 + r22643;
        double r22645 = atan2(1.0, 0.0);
        double r22646 = r22602 * r22645;
        double r22647 = sin(r22646);
        double r22648 = r22645 / r22647;
        double r22649 = r22645 + r22645;
        double r22650 = sqrt(r22649);
        double r22651 = r22650 * r22649;
        double r22652 = 1/3;
        double r22653 = pow(r22651, r22652);
        double r22654 = r22648 * r22653;
        double r22655 = 0.5;
        double r22656 = r22606 + r22655;
        double r22657 = r22656 + r22619;
        double r22658 = exp(r22657);
        double r22659 = r22602 - r22655;
        double r22660 = r22600 - r22659;
        double r22661 = pow(r22657, r22660);
        double r22662 = r22658 / r22661;
        double r22663 = r22654 / r22662;
        double r22664 = r22644 * r22663;
        return r22664;
}

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 r22665, r22666, r22667, r22668, r22669, r22670, r22671, r22672, r22673, r22674, r22675, r22676, r22677, r22678, r22679, r22680, r22681, r22682, r22683, r22684, r22685, r22686, r22687, r22688, r22689, r22690, r22691, r22692, r22693, r22694, r22695, r22696, r22697, r22698, r22699, r22700, r22701, r22702, r22703, r22704, r22705, r22706, r22707, r22708, r22709, r22710, r22711, r22712, r22713, r22714, r22715, r22716, r22717, r22718, r22719, r22720, r22721, r22722, r22723, r22724;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r22665);
        mpfr_init(r22666);
        mpfr_init(r22667);
        mpfr_init(r22668);
        mpfr_init(r22669);
        mpfr_init_set_str(r22670, "2", 10, MPFR_RNDN);
        mpfr_init(r22671);
        mpfr_init(r22672);
        mpfr_init_set_str(r22673, "1", 10, MPFR_RNDN);
        mpfr_init(r22674);
        mpfr_init(r22675);
        mpfr_init_set_str(r22676, "7", 10, MPFR_RNDN);
        mpfr_init(r22677);
        mpfr_init_set_str(r22678, "0.5", 10, MPFR_RNDN);
        mpfr_init(r22679);
        mpfr_init(r22680);
        mpfr_init(r22681);
        mpfr_init(r22682);
        mpfr_init(r22683);
        mpfr_init(r22684);
        mpfr_init(r22685);
        mpfr_init_set_str(r22686, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r22687, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r22688);
        mpfr_init(r22689);
        mpfr_init(r22690);
        mpfr_init_set_str(r22691, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r22692);
        mpfr_init(r22693);
        mpfr_init(r22694);
        mpfr_init_set_str(r22695, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r22696, "3", 10, MPFR_RNDN);
        mpfr_init(r22697);
        mpfr_init(r22698);
        mpfr_init(r22699);
        mpfr_init_set_str(r22700, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r22701, "4", 10, MPFR_RNDN);
        mpfr_init(r22702);
        mpfr_init(r22703);
        mpfr_init(r22704);
        mpfr_init_set_str(r22705, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r22706, "5", 10, MPFR_RNDN);
        mpfr_init(r22707);
        mpfr_init(r22708);
        mpfr_init(r22709);
        mpfr_init_set_str(r22710, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r22711, "6", 10, MPFR_RNDN);
        mpfr_init(r22712);
        mpfr_init(r22713);
        mpfr_init(r22714);
        mpfr_init_set_str(r22715, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r22716);
        mpfr_init(r22717);
        mpfr_init_set_str(r22718, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r22719, "8", 10, MPFR_RNDN);
        mpfr_init(r22720);
        mpfr_init(r22721);
        mpfr_init(r22722);
        mpfr_init(r22723);
        mpfr_init(r22724);
}

double f_im(double z) {
        mpfr_const_pi(r22665, MPFR_RNDN);
        mpfr_set_d(r22666, z, MPFR_RNDN);
        mpfr_mul(r22667, r22665, r22666, MPFR_RNDN);
        mpfr_sin(r22668, r22667, MPFR_RNDN);
        mpfr_div(r22669, r22665, r22668, MPFR_RNDN);
        ;
        mpfr_mul(r22671, r22665, r22670, MPFR_RNDN);
        mpfr_sqrt(r22672, r22671, MPFR_RNDN);
        ;
        mpfr_sub(r22674, r22673, r22666, MPFR_RNDN);
        mpfr_sub(r22675, r22674, r22673, MPFR_RNDN);
        ;
        mpfr_add(r22677, r22675, r22676, MPFR_RNDN);
        ;
        mpfr_add(r22679, r22677, r22678, MPFR_RNDN);
        mpfr_add(r22680, r22675, r22678, MPFR_RNDN);
        mpfr_pow(r22681, r22679, r22680, MPFR_RNDN);
        mpfr_mul(r22682, r22672, r22681, MPFR_RNDN);
        mpfr_neg(r22683, r22679, MPFR_RNDN);
        mpfr_exp(r22684, r22683, MPFR_RNDN);
        mpfr_mul(r22685, r22682, r22684, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22688, r22675, r22673, MPFR_RNDN);
        mpfr_div(r22689, r22687, r22688, MPFR_RNDN);
        mpfr_add(r22690, r22686, r22689, MPFR_RNDN);
        ;
        mpfr_add(r22692, r22675, r22670, MPFR_RNDN);
        mpfr_div(r22693, r22691, r22692, MPFR_RNDN);
        mpfr_add(r22694, r22690, r22693, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22697, r22675, r22696, MPFR_RNDN);
        mpfr_div(r22698, r22695, r22697, MPFR_RNDN);
        mpfr_add(r22699, r22694, r22698, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22702, r22675, r22701, MPFR_RNDN);
        mpfr_div(r22703, r22700, r22702, MPFR_RNDN);
        mpfr_add(r22704, r22699, r22703, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22707, r22675, r22706, MPFR_RNDN);
        mpfr_div(r22708, r22705, r22707, MPFR_RNDN);
        mpfr_add(r22709, r22704, r22708, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22712, r22675, r22711, MPFR_RNDN);
        mpfr_div(r22713, r22710, r22712, MPFR_RNDN);
        mpfr_add(r22714, r22709, r22713, MPFR_RNDN);
        ;
        mpfr_div(r22716, r22715, r22677, MPFR_RNDN);
        mpfr_add(r22717, r22714, r22716, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22720, r22675, r22719, MPFR_RNDN);
        mpfr_div(r22721, r22718, r22720, MPFR_RNDN);
        mpfr_add(r22722, r22717, r22721, MPFR_RNDN);
        mpfr_mul(r22723, r22685, r22722, MPFR_RNDN);
        mpfr_mul(r22724, r22669, r22723, MPFR_RNDN);
        return mpfr_get_d(r22724, MPFR_RNDN);
}

static mpfr_t r22725, r22726, r22727, r22728, r22729, r22730, r22731, r22732, r22733, r22734, r22735, r22736, r22737, r22738, r22739, r22740, r22741, r22742, r22743, r22744, r22745, r22746, r22747, r22748, r22749, r22750, r22751, r22752, r22753, r22754, r22755, r22756, r22757, r22758, r22759, r22760, r22761, r22762, r22763, r22764, r22765, r22766, r22767, r22768, r22769, r22770, r22771, r22772, r22773, r22774, r22775, r22776, r22777, r22778, r22779, r22780, r22781, r22782, r22783, r22784, r22785, r22786, r22787, r22788, r22789, r22790, r22791;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r22725, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r22726, "8", 10, MPFR_RNDN);
        mpfr_init_set_str(r22727, "0", 10, MPFR_RNDN);
        mpfr_init(r22728);
        mpfr_init(r22729);
        mpfr_init(r22730);
        mpfr_init(r22731);
        mpfr_init_set_str(r22732, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r22733, "7", 10, MPFR_RNDN);
        mpfr_init(r22734);
        mpfr_init(r22735);
        mpfr_init(r22736);
        mpfr_init(r22737);
        mpfr_init_set_str(r22738, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r22739, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r22740, "1", 10, MPFR_RNDN);
        mpfr_init(r22741);
        mpfr_init(r22742);
        mpfr_init(r22743);
        mpfr_init_set_str(r22744, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init_set_str(r22745, "2", 10, MPFR_RNDN);
        mpfr_init(r22746);
        mpfr_init(r22747);
        mpfr_init(r22748);
        mpfr_init(r22749);
        mpfr_init(r22750);
        mpfr_init_set_str(r22751, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r22752, "4", 10, MPFR_RNDN);
        mpfr_init(r22753);
        mpfr_init(r22754);
        mpfr_init_set_str(r22755, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r22756, "3", 10, MPFR_RNDN);
        mpfr_init(r22757);
        mpfr_init(r22758);
        mpfr_init(r22759);
        mpfr_init_set_str(r22760, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r22761, "6", 10, MPFR_RNDN);
        mpfr_init(r22762);
        mpfr_init(r22763);
        mpfr_init_set_str(r22764, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r22765, "5", 10, MPFR_RNDN);
        mpfr_init(r22766);
        mpfr_init(r22767);
        mpfr_init(r22768);
        mpfr_init(r22769);
        mpfr_init(r22770);
        mpfr_init(r22771);
        mpfr_init(r22772);
        mpfr_init(r22773);
        mpfr_init(r22774);
        mpfr_init(r22775);
        mpfr_init(r22776);
        mpfr_init(r22777);
        mpfr_init(r22778);
        mpfr_init_set_str(r22779, "1/3", 10, MPFR_RNDN);
        mpfr_init(r22780);
        mpfr_init(r22781);
        mpfr_init_set_str(r22782, "0.5", 10, MPFR_RNDN);
        mpfr_init(r22783);
        mpfr_init(r22784);
        mpfr_init(r22785);
        mpfr_init(r22786);
        mpfr_init(r22787);
        mpfr_init(r22788);
        mpfr_init(r22789);
        mpfr_init(r22790);
        mpfr_init(r22791);
}

double f_fm(double z) {
        ;
        ;
        ;
        mpfr_add(r22728, r22726, r22727, MPFR_RNDN);
        mpfr_set_d(r22729, z, MPFR_RNDN);
        mpfr_sub(r22730, r22728, r22729, MPFR_RNDN);
        mpfr_div(r22731, r22725, r22730, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22734, r22733, r22727, MPFR_RNDN);
        mpfr_sub(r22735, r22734, r22729, MPFR_RNDN);
        mpfr_div(r22736, r22732, r22735, MPFR_RNDN);
        mpfr_add(r22737, r22731, r22736, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_sub(r22741, r22740, r22729, MPFR_RNDN);
        mpfr_div(r22742, r22739, r22741, MPFR_RNDN);
        mpfr_add(r22743, r22738, r22742, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r22746, r22727, r22729, MPFR_RNDN);
        mpfr_add(r22747, r22745, r22746, MPFR_RNDN);
        mpfr_div(r22748, r22744, r22747, MPFR_RNDN);
        mpfr_add(r22749, r22743, r22748, MPFR_RNDN);
        mpfr_add(r22750, r22737, r22749, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22753, r22746, r22752, MPFR_RNDN);
        mpfr_div(r22754, r22751, r22753, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22757, r22756, r22746, MPFR_RNDN);
        mpfr_div(r22758, r22755, r22757, MPFR_RNDN);
        mpfr_add(r22759, r22754, r22758, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22762, r22761, r22746, MPFR_RNDN);
        mpfr_div(r22763, r22760, r22762, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22766, r22765, r22727, MPFR_RNDN);
        mpfr_sub(r22767, r22766, r22729, MPFR_RNDN);
        mpfr_div(r22768, r22764, r22767, MPFR_RNDN);
        mpfr_add(r22769, r22763, r22768, MPFR_RNDN);
        mpfr_add(r22770, r22759, r22769, MPFR_RNDN);
        mpfr_add(r22771, r22750, r22770, MPFR_RNDN);
        mpfr_const_pi(r22772, MPFR_RNDN);
        mpfr_mul(r22773, r22729, r22772, MPFR_RNDN);
        mpfr_sin(r22774, r22773, MPFR_RNDN);
        mpfr_div(r22775, r22772, r22774, MPFR_RNDN);
        mpfr_add(r22776, r22772, r22772, MPFR_RNDN);
        mpfr_sqrt(r22777, r22776, MPFR_RNDN);
        mpfr_mul(r22778, r22777, r22776, MPFR_RNDN);
        ;
        mpfr_pow(r22780, r22778, r22779, MPFR_RNDN);
        mpfr_mul(r22781, r22775, r22780, MPFR_RNDN);
        ;
        mpfr_add(r22783, r22733, r22782, MPFR_RNDN);
        mpfr_add(r22784, r22783, r22746, MPFR_RNDN);
        mpfr_exp(r22785, r22784, MPFR_RNDN);
        mpfr_sub(r22786, r22729, r22782, MPFR_RNDN);
        mpfr_sub(r22787, r22727, r22786, MPFR_RNDN);
        mpfr_pow(r22788, r22784, r22787, MPFR_RNDN);
        mpfr_div(r22789, r22785, r22788, MPFR_RNDN);
        mpfr_div(r22790, r22781, r22789, MPFR_RNDN);
        mpfr_mul(r22791, r22771, r22790, MPFR_RNDN);
        return mpfr_get_d(r22791, MPFR_RNDN);
}

static mpfr_t r22792, r22793, r22794, r22795, r22796, r22797, r22798, r22799, r22800, r22801, r22802, r22803, r22804, r22805, r22806, r22807, r22808, r22809, r22810, r22811, r22812, r22813, r22814, r22815, r22816, r22817, r22818, r22819, r22820, r22821, r22822, r22823, r22824, r22825, r22826, r22827, r22828, r22829, r22830, r22831, r22832, r22833, r22834, r22835, r22836, r22837, r22838, r22839, r22840, r22841, r22842, r22843, r22844, r22845, r22846, r22847, r22848, r22849, r22850, r22851, r22852, r22853, r22854, r22855, r22856, r22857, r22858;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r22792, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r22793, "8", 10, MPFR_RNDN);
        mpfr_init_set_str(r22794, "0", 10, MPFR_RNDN);
        mpfr_init(r22795);
        mpfr_init(r22796);
        mpfr_init(r22797);
        mpfr_init(r22798);
        mpfr_init_set_str(r22799, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init_set_str(r22800, "7", 10, MPFR_RNDN);
        mpfr_init(r22801);
        mpfr_init(r22802);
        mpfr_init(r22803);
        mpfr_init(r22804);
        mpfr_init_set_str(r22805, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r22806, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r22807, "1", 10, MPFR_RNDN);
        mpfr_init(r22808);
        mpfr_init(r22809);
        mpfr_init(r22810);
        mpfr_init_set_str(r22811, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init_set_str(r22812, "2", 10, MPFR_RNDN);
        mpfr_init(r22813);
        mpfr_init(r22814);
        mpfr_init(r22815);
        mpfr_init(r22816);
        mpfr_init(r22817);
        mpfr_init_set_str(r22818, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r22819, "4", 10, MPFR_RNDN);
        mpfr_init(r22820);
        mpfr_init(r22821);
        mpfr_init_set_str(r22822, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r22823, "3", 10, MPFR_RNDN);
        mpfr_init(r22824);
        mpfr_init(r22825);
        mpfr_init(r22826);
        mpfr_init_set_str(r22827, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r22828, "6", 10, MPFR_RNDN);
        mpfr_init(r22829);
        mpfr_init(r22830);
        mpfr_init_set_str(r22831, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r22832, "5", 10, MPFR_RNDN);
        mpfr_init(r22833);
        mpfr_init(r22834);
        mpfr_init(r22835);
        mpfr_init(r22836);
        mpfr_init(r22837);
        mpfr_init(r22838);
        mpfr_init(r22839);
        mpfr_init(r22840);
        mpfr_init(r22841);
        mpfr_init(r22842);
        mpfr_init(r22843);
        mpfr_init(r22844);
        mpfr_init(r22845);
        mpfr_init_set_str(r22846, "1/3", 10, MPFR_RNDN);
        mpfr_init(r22847);
        mpfr_init(r22848);
        mpfr_init_set_str(r22849, "0.5", 10, MPFR_RNDN);
        mpfr_init(r22850);
        mpfr_init(r22851);
        mpfr_init(r22852);
        mpfr_init(r22853);
        mpfr_init(r22854);
        mpfr_init(r22855);
        mpfr_init(r22856);
        mpfr_init(r22857);
        mpfr_init(r22858);
}

double f_dm(double z) {
        ;
        ;
        ;
        mpfr_add(r22795, r22793, r22794, MPFR_RNDN);
        mpfr_set_d(r22796, z, MPFR_RNDN);
        mpfr_sub(r22797, r22795, r22796, MPFR_RNDN);
        mpfr_div(r22798, r22792, r22797, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22801, r22800, r22794, MPFR_RNDN);
        mpfr_sub(r22802, r22801, r22796, MPFR_RNDN);
        mpfr_div(r22803, r22799, r22802, MPFR_RNDN);
        mpfr_add(r22804, r22798, r22803, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_sub(r22808, r22807, r22796, MPFR_RNDN);
        mpfr_div(r22809, r22806, r22808, MPFR_RNDN);
        mpfr_add(r22810, r22805, r22809, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r22813, r22794, r22796, MPFR_RNDN);
        mpfr_add(r22814, r22812, r22813, MPFR_RNDN);
        mpfr_div(r22815, r22811, r22814, MPFR_RNDN);
        mpfr_add(r22816, r22810, r22815, MPFR_RNDN);
        mpfr_add(r22817, r22804, r22816, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22820, r22813, r22819, MPFR_RNDN);
        mpfr_div(r22821, r22818, r22820, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22824, r22823, r22813, MPFR_RNDN);
        mpfr_div(r22825, r22822, r22824, MPFR_RNDN);
        mpfr_add(r22826, r22821, r22825, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22829, r22828, r22813, MPFR_RNDN);
        mpfr_div(r22830, r22827, r22829, MPFR_RNDN);
        ;
        ;
        mpfr_add(r22833, r22832, r22794, MPFR_RNDN);
        mpfr_sub(r22834, r22833, r22796, MPFR_RNDN);
        mpfr_div(r22835, r22831, r22834, MPFR_RNDN);
        mpfr_add(r22836, r22830, r22835, MPFR_RNDN);
        mpfr_add(r22837, r22826, r22836, MPFR_RNDN);
        mpfr_add(r22838, r22817, r22837, MPFR_RNDN);
        mpfr_const_pi(r22839, MPFR_RNDN);
        mpfr_mul(r22840, r22796, r22839, MPFR_RNDN);
        mpfr_sin(r22841, r22840, MPFR_RNDN);
        mpfr_div(r22842, r22839, r22841, MPFR_RNDN);
        mpfr_add(r22843, r22839, r22839, MPFR_RNDN);
        mpfr_sqrt(r22844, r22843, MPFR_RNDN);
        mpfr_mul(r22845, r22844, r22843, MPFR_RNDN);
        ;
        mpfr_pow(r22847, r22845, r22846, MPFR_RNDN);
        mpfr_mul(r22848, r22842, r22847, MPFR_RNDN);
        ;
        mpfr_add(r22850, r22800, r22849, MPFR_RNDN);
        mpfr_add(r22851, r22850, r22813, MPFR_RNDN);
        mpfr_exp(r22852, r22851, MPFR_RNDN);
        mpfr_sub(r22853, r22796, r22849, MPFR_RNDN);
        mpfr_sub(r22854, r22794, r22853, MPFR_RNDN);
        mpfr_pow(r22855, r22851, r22854, MPFR_RNDN);
        mpfr_div(r22856, r22852, r22855, MPFR_RNDN);
        mpfr_div(r22857, r22848, r22856, MPFR_RNDN);
        mpfr_mul(r22858, r22838, r22857, MPFR_RNDN);
        return mpfr_get_d(r22858, MPFR_RNDN);
}

