#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 r24616 = atan2(1.0, 0.0);
        float r24617 = z;
        float r24618 = r24616 * r24617;
        float r24619 = sin(r24618);
        float r24620 = r24616 / r24619;
        float r24621 = 2;
        float r24622 = r24616 * r24621;
        float r24623 = sqrt(r24622);
        float r24624 = 1;
        float r24625 = r24624 - r24617;
        float r24626 = r24625 - r24624;
        float r24627 = 7;
        float r24628 = r24626 + r24627;
        float r24629 = 0.5;
        float r24630 = r24628 + r24629;
        float r24631 = r24626 + r24629;
        float r24632 = pow(r24630, r24631);
        float r24633 = r24623 * r24632;
        float r24634 = -r24630;
        float r24635 = exp(r24634);
        float r24636 = r24633 * r24635;
        float r24637 = 0.9999999999998099;
        float r24638 = 676.5203681218851;
        float r24639 = r24626 + r24624;
        float r24640 = r24638 / r24639;
        float r24641 = r24637 + r24640;
        float r24642 = -1259.1392167224028;
        float r24643 = r24626 + r24621;
        float r24644 = r24642 / r24643;
        float r24645 = r24641 + r24644;
        float r24646 = 771.3234287776531;
        float r24647 = 3;
        float r24648 = r24626 + r24647;
        float r24649 = r24646 / r24648;
        float r24650 = r24645 + r24649;
        float r24651 = -176.6150291621406;
        float r24652 = 4;
        float r24653 = r24626 + r24652;
        float r24654 = r24651 / r24653;
        float r24655 = r24650 + r24654;
        float r24656 = 12.507343278686905;
        float r24657 = 5;
        float r24658 = r24626 + r24657;
        float r24659 = r24656 / r24658;
        float r24660 = r24655 + r24659;
        float r24661 = -0.13857109526572012;
        float r24662 = 6;
        float r24663 = r24626 + r24662;
        float r24664 = r24661 / r24663;
        float r24665 = r24660 + r24664;
        float r24666 = 9.984369578019572e-06;
        float r24667 = r24666 / r24628;
        float r24668 = r24665 + r24667;
        float r24669 = 1.5056327351493116e-07;
        float r24670 = 8;
        float r24671 = r24626 + r24670;
        float r24672 = r24669 / r24671;
        float r24673 = r24668 + r24672;
        float r24674 = r24636 * r24673;
        float r24675 = r24620 * r24674;
        return r24675;
}

double f_id(double z) {
        double r24676 = atan2(1.0, 0.0);
        double r24677 = z;
        double r24678 = r24676 * r24677;
        double r24679 = sin(r24678);
        double r24680 = r24676 / r24679;
        double r24681 = 2;
        double r24682 = r24676 * r24681;
        double r24683 = sqrt(r24682);
        double r24684 = 1;
        double r24685 = r24684 - r24677;
        double r24686 = r24685 - r24684;
        double r24687 = 7;
        double r24688 = r24686 + r24687;
        double r24689 = 0.5;
        double r24690 = r24688 + r24689;
        double r24691 = r24686 + r24689;
        double r24692 = pow(r24690, r24691);
        double r24693 = r24683 * r24692;
        double r24694 = -r24690;
        double r24695 = exp(r24694);
        double r24696 = r24693 * r24695;
        double r24697 = 0.9999999999998099;
        double r24698 = 676.5203681218851;
        double r24699 = r24686 + r24684;
        double r24700 = r24698 / r24699;
        double r24701 = r24697 + r24700;
        double r24702 = -1259.1392167224028;
        double r24703 = r24686 + r24681;
        double r24704 = r24702 / r24703;
        double r24705 = r24701 + r24704;
        double r24706 = 771.3234287776531;
        double r24707 = 3;
        double r24708 = r24686 + r24707;
        double r24709 = r24706 / r24708;
        double r24710 = r24705 + r24709;
        double r24711 = -176.6150291621406;
        double r24712 = 4;
        double r24713 = r24686 + r24712;
        double r24714 = r24711 / r24713;
        double r24715 = r24710 + r24714;
        double r24716 = 12.507343278686905;
        double r24717 = 5;
        double r24718 = r24686 + r24717;
        double r24719 = r24716 / r24718;
        double r24720 = r24715 + r24719;
        double r24721 = -0.13857109526572012;
        double r24722 = 6;
        double r24723 = r24686 + r24722;
        double r24724 = r24721 / r24723;
        double r24725 = r24720 + r24724;
        double r24726 = 9.984369578019572e-06;
        double r24727 = r24726 / r24688;
        double r24728 = r24725 + r24727;
        double r24729 = 1.5056327351493116e-07;
        double r24730 = 8;
        double r24731 = r24686 + r24730;
        double r24732 = r24729 / r24731;
        double r24733 = r24728 + r24732;
        double r24734 = r24696 * r24733;
        double r24735 = r24680 * r24734;
        return r24735;
}


double f_of(float z) {
        float r24736 = atan2(1.0, 0.0);
        float r24737 = exp(1.0);
        float r24738 = r24736 / r24737;
        float r24739 = -6;
        float r24740 = exp(r24739);
        float r24741 = r24738 * r24740;
        float r24742 = z;
        float r24743 = 0.5;
        float r24744 = r24742 - r24743;
        float r24745 = exp(r24744);
        float r24746 = r24741 * r24745;
        float r24747 = sqrt(r24746);
        float r24748 = r24747 * r24747;
        float r24749 = 2;
        float r24750 = r24749 * r24736;
        float r24751 = sqrt(r24750);
        float r24752 = 1;
        float r24753 = r24752 - r24742;
        float r24754 = r24739 - r24743;
        float r24755 = r24753 - r24754;
        float r24756 = r24752 - r24743;
        float r24757 = r24753 - r24756;
        float r24758 = pow(r24755, r24757);
        float r24759 = r24751 * r24758;
        float r24760 = r24748 * r24759;
        float r24761 = r24742 * r24736;
        float r24762 = sin(r24761);
        float r24763 = r24760 / r24762;
        float r24764 = 0.9999999999998099;
        float r24765 = 676.5203681218851;
        float r24766 = r24765 / r24753;
        float r24767 = -1259.1392167224028;
        float r24768 = r24749 - r24742;
        float r24769 = r24767 / r24768;
        float r24770 = r24766 + r24769;
        float r24771 = r24764 + r24770;
        float r24772 = 771.3234287776531;
        float r24773 = 3;
        float r24774 = r24773 - r24742;
        float r24775 = r24772 / r24774;
        float r24776 = -176.6150291621406;
        float r24777 = 4;
        float r24778 = r24777 - r24742;
        float r24779 = r24776 / r24778;
        float r24780 = r24775 + r24779;
        float r24781 = 12.507343278686905;
        float r24782 = 5;
        float r24783 = r24782 - r24742;
        float r24784 = r24781 / r24783;
        float r24785 = -0.13857109526572012;
        float r24786 = 6;
        float r24787 = r24786 - r24742;
        float r24788 = r24785 / r24787;
        float r24789 = r24784 + r24788;
        float r24790 = r24780 + r24789;
        float r24791 = 9.984369578019572e-06;
        float r24792 = r24753 - r24739;
        float r24793 = r24791 / r24792;
        float r24794 = 1.5056327351493116e-07;
        float r24795 = 7;
        float r24796 = r24742 - r24795;
        float r24797 = r24752 - r24796;
        float r24798 = r24794 / r24797;
        float r24799 = r24793 + r24798;
        float r24800 = r24790 + r24799;
        float r24801 = r24771 + r24800;
        float r24802 = r24763 * r24801;
        return r24802;
}

double f_od(double z) {
        double r24803 = atan2(1.0, 0.0);
        double r24804 = exp(1.0);
        double r24805 = r24803 / r24804;
        double r24806 = -6;
        double r24807 = exp(r24806);
        double r24808 = r24805 * r24807;
        double r24809 = z;
        double r24810 = 0.5;
        double r24811 = r24809 - r24810;
        double r24812 = exp(r24811);
        double r24813 = r24808 * r24812;
        double r24814 = sqrt(r24813);
        double r24815 = r24814 * r24814;
        double r24816 = 2;
        double r24817 = r24816 * r24803;
        double r24818 = sqrt(r24817);
        double r24819 = 1;
        double r24820 = r24819 - r24809;
        double r24821 = r24806 - r24810;
        double r24822 = r24820 - r24821;
        double r24823 = r24819 - r24810;
        double r24824 = r24820 - r24823;
        double r24825 = pow(r24822, r24824);
        double r24826 = r24818 * r24825;
        double r24827 = r24815 * r24826;
        double r24828 = r24809 * r24803;
        double r24829 = sin(r24828);
        double r24830 = r24827 / r24829;
        double r24831 = 0.9999999999998099;
        double r24832 = 676.5203681218851;
        double r24833 = r24832 / r24820;
        double r24834 = -1259.1392167224028;
        double r24835 = r24816 - r24809;
        double r24836 = r24834 / r24835;
        double r24837 = r24833 + r24836;
        double r24838 = r24831 + r24837;
        double r24839 = 771.3234287776531;
        double r24840 = 3;
        double r24841 = r24840 - r24809;
        double r24842 = r24839 / r24841;
        double r24843 = -176.6150291621406;
        double r24844 = 4;
        double r24845 = r24844 - r24809;
        double r24846 = r24843 / r24845;
        double r24847 = r24842 + r24846;
        double r24848 = 12.507343278686905;
        double r24849 = 5;
        double r24850 = r24849 - r24809;
        double r24851 = r24848 / r24850;
        double r24852 = -0.13857109526572012;
        double r24853 = 6;
        double r24854 = r24853 - r24809;
        double r24855 = r24852 / r24854;
        double r24856 = r24851 + r24855;
        double r24857 = r24847 + r24856;
        double r24858 = 9.984369578019572e-06;
        double r24859 = r24820 - r24806;
        double r24860 = r24858 / r24859;
        double r24861 = 1.5056327351493116e-07;
        double r24862 = 7;
        double r24863 = r24809 - r24862;
        double r24864 = r24819 - r24863;
        double r24865 = r24861 / r24864;
        double r24866 = r24860 + r24865;
        double r24867 = r24857 + r24866;
        double r24868 = r24838 + r24867;
        double r24869 = r24830 * r24868;
        return r24869;
}

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 r24870, r24871, r24872, r24873, r24874, r24875, r24876, r24877, r24878, r24879, r24880, r24881, r24882, r24883, r24884, r24885, r24886, r24887, r24888, r24889, r24890, r24891, r24892, r24893, r24894, r24895, r24896, r24897, r24898, r24899, r24900, r24901, r24902, r24903, r24904, r24905, r24906, r24907, r24908, r24909, r24910, r24911, r24912, r24913, r24914, r24915, r24916, r24917, r24918, r24919, r24920, r24921, r24922, r24923, r24924, r24925, r24926, r24927, r24928, r24929;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r24870);
        mpfr_init(r24871);
        mpfr_init(r24872);
        mpfr_init(r24873);
        mpfr_init(r24874);
        mpfr_init_set_str(r24875, "2", 10, MPFR_RNDN);
        mpfr_init(r24876);
        mpfr_init(r24877);
        mpfr_init_set_str(r24878, "1", 10, MPFR_RNDN);
        mpfr_init(r24879);
        mpfr_init(r24880);
        mpfr_init_set_str(r24881, "7", 10, MPFR_RNDN);
        mpfr_init(r24882);
        mpfr_init_set_str(r24883, "0.5", 10, MPFR_RNDN);
        mpfr_init(r24884);
        mpfr_init(r24885);
        mpfr_init(r24886);
        mpfr_init(r24887);
        mpfr_init(r24888);
        mpfr_init(r24889);
        mpfr_init(r24890);
        mpfr_init_set_str(r24891, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r24892, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r24893);
        mpfr_init(r24894);
        mpfr_init(r24895);
        mpfr_init_set_str(r24896, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r24897);
        mpfr_init(r24898);
        mpfr_init(r24899);
        mpfr_init_set_str(r24900, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r24901, "3", 10, MPFR_RNDN);
        mpfr_init(r24902);
        mpfr_init(r24903);
        mpfr_init(r24904);
        mpfr_init_set_str(r24905, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r24906, "4", 10, MPFR_RNDN);
        mpfr_init(r24907);
        mpfr_init(r24908);
        mpfr_init(r24909);
        mpfr_init_set_str(r24910, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r24911, "5", 10, MPFR_RNDN);
        mpfr_init(r24912);
        mpfr_init(r24913);
        mpfr_init(r24914);
        mpfr_init_set_str(r24915, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r24916, "6", 10, MPFR_RNDN);
        mpfr_init(r24917);
        mpfr_init(r24918);
        mpfr_init(r24919);
        mpfr_init_set_str(r24920, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r24921);
        mpfr_init(r24922);
        mpfr_init_set_str(r24923, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r24924, "8", 10, MPFR_RNDN);
        mpfr_init(r24925);
        mpfr_init(r24926);
        mpfr_init(r24927);
        mpfr_init(r24928);
        mpfr_init(r24929);
}

double f_im(double z) {
        mpfr_const_pi(r24870, MPFR_RNDN);
        mpfr_set_d(r24871, z, MPFR_RNDN);
        mpfr_mul(r24872, r24870, r24871, MPFR_RNDN);
        mpfr_sin(r24873, r24872, MPFR_RNDN);
        mpfr_div(r24874, r24870, r24873, MPFR_RNDN);
        ;
        mpfr_mul(r24876, r24870, r24875, MPFR_RNDN);
        mpfr_sqrt(r24877, r24876, MPFR_RNDN);
        ;
        mpfr_sub(r24879, r24878, r24871, MPFR_RNDN);
        mpfr_sub(r24880, r24879, r24878, MPFR_RNDN);
        ;
        mpfr_add(r24882, r24880, r24881, MPFR_RNDN);
        ;
        mpfr_add(r24884, r24882, r24883, MPFR_RNDN);
        mpfr_add(r24885, r24880, r24883, MPFR_RNDN);
        mpfr_pow(r24886, r24884, r24885, MPFR_RNDN);
        mpfr_mul(r24887, r24877, r24886, MPFR_RNDN);
        mpfr_neg(r24888, r24884, MPFR_RNDN);
        mpfr_exp(r24889, r24888, MPFR_RNDN);
        mpfr_mul(r24890, r24887, r24889, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24893, r24880, r24878, MPFR_RNDN);
        mpfr_div(r24894, r24892, r24893, MPFR_RNDN);
        mpfr_add(r24895, r24891, r24894, MPFR_RNDN);
        ;
        mpfr_add(r24897, r24880, r24875, MPFR_RNDN);
        mpfr_div(r24898, r24896, r24897, MPFR_RNDN);
        mpfr_add(r24899, r24895, r24898, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24902, r24880, r24901, MPFR_RNDN);
        mpfr_div(r24903, r24900, r24902, MPFR_RNDN);
        mpfr_add(r24904, r24899, r24903, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24907, r24880, r24906, MPFR_RNDN);
        mpfr_div(r24908, r24905, r24907, MPFR_RNDN);
        mpfr_add(r24909, r24904, r24908, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24912, r24880, r24911, MPFR_RNDN);
        mpfr_div(r24913, r24910, r24912, MPFR_RNDN);
        mpfr_add(r24914, r24909, r24913, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24917, r24880, r24916, MPFR_RNDN);
        mpfr_div(r24918, r24915, r24917, MPFR_RNDN);
        mpfr_add(r24919, r24914, r24918, MPFR_RNDN);
        ;
        mpfr_div(r24921, r24920, r24882, MPFR_RNDN);
        mpfr_add(r24922, r24919, r24921, MPFR_RNDN);
        ;
        ;
        mpfr_add(r24925, r24880, r24924, MPFR_RNDN);
        mpfr_div(r24926, r24923, r24925, MPFR_RNDN);
        mpfr_add(r24927, r24922, r24926, MPFR_RNDN);
        mpfr_mul(r24928, r24890, r24927, MPFR_RNDN);
        mpfr_mul(r24929, r24874, r24928, MPFR_RNDN);
        return mpfr_get_d(r24929, MPFR_RNDN);
}

static mpfr_t r24930, r24931, r24932, r24933, r24934, r24935, r24936, r24937, r24938, r24939, r24940, r24941, r24942, r24943, r24944, r24945, r24946, r24947, r24948, r24949, r24950, r24951, r24952, r24953, r24954, r24955, r24956, r24957, r24958, r24959, r24960, r24961, r24962, r24963, r24964, r24965, r24966, r24967, r24968, r24969, r24970, r24971, r24972, r24973, r24974, r24975, r24976, r24977, r24978, r24979, r24980, r24981, r24982, r24983, r24984, r24985, r24986, r24987, r24988, r24989, r24990, r24991, r24992, r24993, r24994, r24995, r24996;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r24930);
        mpfr_init(r24931);
        mpfr_init(r24932);
        mpfr_init_set_str(r24933, "-6", 10, MPFR_RNDN);
        mpfr_init(r24934);
        mpfr_init(r24935);
        mpfr_init(r24936);
        mpfr_init_set_str(r24937, "0.5", 10, MPFR_RNDN);
        mpfr_init(r24938);
        mpfr_init(r24939);
        mpfr_init(r24940);
        mpfr_init(r24941);
        mpfr_init(r24942);
        mpfr_init_set_str(r24943, "2", 10, MPFR_RNDN);
        mpfr_init(r24944);
        mpfr_init(r24945);
        mpfr_init_set_str(r24946, "1", 10, MPFR_RNDN);
        mpfr_init(r24947);
        mpfr_init(r24948);
        mpfr_init(r24949);
        mpfr_init(r24950);
        mpfr_init(r24951);
        mpfr_init(r24952);
        mpfr_init(r24953);
        mpfr_init(r24954);
        mpfr_init(r24955);
        mpfr_init(r24956);
        mpfr_init(r24957);
        mpfr_init_set_str(r24958, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r24959, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r24960);
        mpfr_init_set_str(r24961, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r24962);
        mpfr_init(r24963);
        mpfr_init(r24964);
        mpfr_init(r24965);
        mpfr_init_set_str(r24966, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r24967, "3", 10, MPFR_RNDN);
        mpfr_init(r24968);
        mpfr_init(r24969);
        mpfr_init_set_str(r24970, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r24971, "4", 10, MPFR_RNDN);
        mpfr_init(r24972);
        mpfr_init(r24973);
        mpfr_init(r24974);
        mpfr_init_set_str(r24975, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r24976, "5", 10, MPFR_RNDN);
        mpfr_init(r24977);
        mpfr_init(r24978);
        mpfr_init_set_str(r24979, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r24980, "6", 10, MPFR_RNDN);
        mpfr_init(r24981);
        mpfr_init(r24982);
        mpfr_init(r24983);
        mpfr_init(r24984);
        mpfr_init_set_str(r24985, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r24986);
        mpfr_init(r24987);
        mpfr_init_set_str(r24988, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r24989, "7", 10, MPFR_RNDN);
        mpfr_init(r24990);
        mpfr_init(r24991);
        mpfr_init(r24992);
        mpfr_init(r24993);
        mpfr_init(r24994);
        mpfr_init(r24995);
        mpfr_init(r24996);
}

double f_fm(double z) {
        mpfr_const_pi(r24930, MPFR_RNDN);
        mpfr_set_si(r24931, 1, MPFR_RNDN), mpfr_const_exp(r24931, r24931, MPFR_RNDN);
        mpfr_div(r24932, r24930, r24931, MPFR_RNDN);
        ;
        mpfr_exp(r24934, r24933, MPFR_RNDN);
        mpfr_mul(r24935, r24932, r24934, MPFR_RNDN);
        mpfr_set_d(r24936, z, MPFR_RNDN);
        ;
        mpfr_sub(r24938, r24936, r24937, MPFR_RNDN);
        mpfr_exp(r24939, r24938, MPFR_RNDN);
        mpfr_mul(r24940, r24935, r24939, MPFR_RNDN);
        mpfr_sqrt(r24941, r24940, MPFR_RNDN);
        mpfr_mul(r24942, r24941, r24941, MPFR_RNDN);
        ;
        mpfr_mul(r24944, r24943, r24930, MPFR_RNDN);
        mpfr_sqrt(r24945, r24944, MPFR_RNDN);
        ;
        mpfr_sub(r24947, r24946, r24936, MPFR_RNDN);
        mpfr_sub(r24948, r24933, r24937, MPFR_RNDN);
        mpfr_sub(r24949, r24947, r24948, MPFR_RNDN);
        mpfr_sub(r24950, r24946, r24937, MPFR_RNDN);
        mpfr_sub(r24951, r24947, r24950, MPFR_RNDN);
        mpfr_pow(r24952, r24949, r24951, MPFR_RNDN);
        mpfr_mul(r24953, r24945, r24952, MPFR_RNDN);
        mpfr_mul(r24954, r24942, r24953, MPFR_RNDN);
        mpfr_mul(r24955, r24936, r24930, MPFR_RNDN);
        mpfr_sin(r24956, r24955, MPFR_RNDN);
        mpfr_div(r24957, r24954, r24956, MPFR_RNDN);
        ;
        ;
        mpfr_div(r24960, r24959, r24947, MPFR_RNDN);
        ;
        mpfr_sub(r24962, r24943, r24936, MPFR_RNDN);
        mpfr_div(r24963, r24961, r24962, MPFR_RNDN);
        mpfr_add(r24964, r24960, r24963, MPFR_RNDN);
        mpfr_add(r24965, r24958, r24964, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r24968, r24967, r24936, MPFR_RNDN);
        mpfr_div(r24969, r24966, r24968, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r24972, r24971, r24936, MPFR_RNDN);
        mpfr_div(r24973, r24970, r24972, MPFR_RNDN);
        mpfr_add(r24974, r24969, r24973, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r24977, r24976, r24936, MPFR_RNDN);
        mpfr_div(r24978, r24975, r24977, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r24981, r24980, r24936, MPFR_RNDN);
        mpfr_div(r24982, r24979, r24981, MPFR_RNDN);
        mpfr_add(r24983, r24978, r24982, MPFR_RNDN);
        mpfr_add(r24984, r24974, r24983, MPFR_RNDN);
        ;
        mpfr_sub(r24986, r24947, r24933, MPFR_RNDN);
        mpfr_div(r24987, r24985, r24986, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r24990, r24936, r24989, MPFR_RNDN);
        mpfr_sub(r24991, r24946, r24990, MPFR_RNDN);
        mpfr_div(r24992, r24988, r24991, MPFR_RNDN);
        mpfr_add(r24993, r24987, r24992, MPFR_RNDN);
        mpfr_add(r24994, r24984, r24993, MPFR_RNDN);
        mpfr_add(r24995, r24965, r24994, MPFR_RNDN);
        mpfr_mul(r24996, r24957, r24995, MPFR_RNDN);
        return mpfr_get_d(r24996, MPFR_RNDN);
}

static mpfr_t r24997, r24998, r24999, r25000, r25001, r25002, r25003, r25004, r25005, r25006, r25007, r25008, r25009, r25010, r25011, r25012, r25013, r25014, r25015, r25016, r25017, r25018, r25019, r25020, r25021, r25022, r25023, r25024, r25025, r25026, r25027, r25028, r25029, r25030, r25031, r25032, r25033, r25034, r25035, r25036, r25037, r25038, r25039, r25040, r25041, r25042, r25043, r25044, r25045, r25046, r25047, r25048, r25049, r25050, r25051, r25052, r25053, r25054, r25055, r25056, r25057, r25058, r25059, r25060, r25061, r25062, r25063;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r24997);
        mpfr_init(r24998);
        mpfr_init(r24999);
        mpfr_init_set_str(r25000, "-6", 10, MPFR_RNDN);
        mpfr_init(r25001);
        mpfr_init(r25002);
        mpfr_init(r25003);
        mpfr_init_set_str(r25004, "0.5", 10, MPFR_RNDN);
        mpfr_init(r25005);
        mpfr_init(r25006);
        mpfr_init(r25007);
        mpfr_init(r25008);
        mpfr_init(r25009);
        mpfr_init_set_str(r25010, "2", 10, MPFR_RNDN);
        mpfr_init(r25011);
        mpfr_init(r25012);
        mpfr_init_set_str(r25013, "1", 10, MPFR_RNDN);
        mpfr_init(r25014);
        mpfr_init(r25015);
        mpfr_init(r25016);
        mpfr_init(r25017);
        mpfr_init(r25018);
        mpfr_init(r25019);
        mpfr_init(r25020);
        mpfr_init(r25021);
        mpfr_init(r25022);
        mpfr_init(r25023);
        mpfr_init(r25024);
        mpfr_init_set_str(r25025, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r25026, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r25027);
        mpfr_init_set_str(r25028, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r25029);
        mpfr_init(r25030);
        mpfr_init(r25031);
        mpfr_init(r25032);
        mpfr_init_set_str(r25033, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r25034, "3", 10, MPFR_RNDN);
        mpfr_init(r25035);
        mpfr_init(r25036);
        mpfr_init_set_str(r25037, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r25038, "4", 10, MPFR_RNDN);
        mpfr_init(r25039);
        mpfr_init(r25040);
        mpfr_init(r25041);
        mpfr_init_set_str(r25042, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r25043, "5", 10, MPFR_RNDN);
        mpfr_init(r25044);
        mpfr_init(r25045);
        mpfr_init_set_str(r25046, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r25047, "6", 10, MPFR_RNDN);
        mpfr_init(r25048);
        mpfr_init(r25049);
        mpfr_init(r25050);
        mpfr_init(r25051);
        mpfr_init_set_str(r25052, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r25053);
        mpfr_init(r25054);
        mpfr_init_set_str(r25055, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r25056, "7", 10, MPFR_RNDN);
        mpfr_init(r25057);
        mpfr_init(r25058);
        mpfr_init(r25059);
        mpfr_init(r25060);
        mpfr_init(r25061);
        mpfr_init(r25062);
        mpfr_init(r25063);
}

double f_dm(double z) {
        mpfr_const_pi(r24997, MPFR_RNDN);
        mpfr_set_si(r24998, 1, MPFR_RNDN), mpfr_const_exp(r24998, r24998, MPFR_RNDN);
        mpfr_div(r24999, r24997, r24998, MPFR_RNDN);
        ;
        mpfr_exp(r25001, r25000, MPFR_RNDN);
        mpfr_mul(r25002, r24999, r25001, MPFR_RNDN);
        mpfr_set_d(r25003, z, MPFR_RNDN);
        ;
        mpfr_sub(r25005, r25003, r25004, MPFR_RNDN);
        mpfr_exp(r25006, r25005, MPFR_RNDN);
        mpfr_mul(r25007, r25002, r25006, MPFR_RNDN);
        mpfr_sqrt(r25008, r25007, MPFR_RNDN);
        mpfr_mul(r25009, r25008, r25008, MPFR_RNDN);
        ;
        mpfr_mul(r25011, r25010, r24997, MPFR_RNDN);
        mpfr_sqrt(r25012, r25011, MPFR_RNDN);
        ;
        mpfr_sub(r25014, r25013, r25003, MPFR_RNDN);
        mpfr_sub(r25015, r25000, r25004, MPFR_RNDN);
        mpfr_sub(r25016, r25014, r25015, MPFR_RNDN);
        mpfr_sub(r25017, r25013, r25004, MPFR_RNDN);
        mpfr_sub(r25018, r25014, r25017, MPFR_RNDN);
        mpfr_pow(r25019, r25016, r25018, MPFR_RNDN);
        mpfr_mul(r25020, r25012, r25019, MPFR_RNDN);
        mpfr_mul(r25021, r25009, r25020, MPFR_RNDN);
        mpfr_mul(r25022, r25003, r24997, MPFR_RNDN);
        mpfr_sin(r25023, r25022, MPFR_RNDN);
        mpfr_div(r25024, r25021, r25023, MPFR_RNDN);
        ;
        ;
        mpfr_div(r25027, r25026, r25014, MPFR_RNDN);
        ;
        mpfr_sub(r25029, r25010, r25003, MPFR_RNDN);
        mpfr_div(r25030, r25028, r25029, MPFR_RNDN);
        mpfr_add(r25031, r25027, r25030, MPFR_RNDN);
        mpfr_add(r25032, r25025, r25031, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r25035, r25034, r25003, MPFR_RNDN);
        mpfr_div(r25036, r25033, r25035, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r25039, r25038, r25003, MPFR_RNDN);
        mpfr_div(r25040, r25037, r25039, MPFR_RNDN);
        mpfr_add(r25041, r25036, r25040, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r25044, r25043, r25003, MPFR_RNDN);
        mpfr_div(r25045, r25042, r25044, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r25048, r25047, r25003, MPFR_RNDN);
        mpfr_div(r25049, r25046, r25048, MPFR_RNDN);
        mpfr_add(r25050, r25045, r25049, MPFR_RNDN);
        mpfr_add(r25051, r25041, r25050, MPFR_RNDN);
        ;
        mpfr_sub(r25053, r25014, r25000, MPFR_RNDN);
        mpfr_div(r25054, r25052, r25053, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r25057, r25003, r25056, MPFR_RNDN);
        mpfr_sub(r25058, r25013, r25057, MPFR_RNDN);
        mpfr_div(r25059, r25055, r25058, MPFR_RNDN);
        mpfr_add(r25060, r25054, r25059, MPFR_RNDN);
        mpfr_add(r25061, r25051, r25060, MPFR_RNDN);
        mpfr_add(r25062, r25032, r25061, MPFR_RNDN);
        mpfr_mul(r25063, r25024, r25062, MPFR_RNDN);
        return mpfr_get_d(r25063, MPFR_RNDN);
}

