#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 r26687 = atan2(1.0, 0.0);
        float r26688 = z;
        float r26689 = r26687 * r26688;
        float r26690 = sin(r26689);
        float r26691 = r26687 / r26690;
        float r26692 = 2;
        float r26693 = r26687 * r26692;
        float r26694 = sqrt(r26693);
        float r26695 = 1;
        float r26696 = r26695 - r26688;
        float r26697 = r26696 - r26695;
        float r26698 = 7;
        float r26699 = r26697 + r26698;
        float r26700 = 0.5;
        float r26701 = r26699 + r26700;
        float r26702 = r26697 + r26700;
        float r26703 = pow(r26701, r26702);
        float r26704 = r26694 * r26703;
        float r26705 = -r26701;
        float r26706 = exp(r26705);
        float r26707 = r26704 * r26706;
        float r26708 = 0.9999999999998099;
        float r26709 = 676.5203681218851;
        float r26710 = r26697 + r26695;
        float r26711 = r26709 / r26710;
        float r26712 = r26708 + r26711;
        float r26713 = -1259.1392167224028;
        float r26714 = r26697 + r26692;
        float r26715 = r26713 / r26714;
        float r26716 = r26712 + r26715;
        float r26717 = 771.3234287776531;
        float r26718 = 3;
        float r26719 = r26697 + r26718;
        float r26720 = r26717 / r26719;
        float r26721 = r26716 + r26720;
        float r26722 = -176.6150291621406;
        float r26723 = 4;
        float r26724 = r26697 + r26723;
        float r26725 = r26722 / r26724;
        float r26726 = r26721 + r26725;
        float r26727 = 12.507343278686905;
        float r26728 = 5;
        float r26729 = r26697 + r26728;
        float r26730 = r26727 / r26729;
        float r26731 = r26726 + r26730;
        float r26732 = -0.13857109526572012;
        float r26733 = 6;
        float r26734 = r26697 + r26733;
        float r26735 = r26732 / r26734;
        float r26736 = r26731 + r26735;
        float r26737 = 9.984369578019572e-06;
        float r26738 = r26737 / r26699;
        float r26739 = r26736 + r26738;
        float r26740 = 1.5056327351493116e-07;
        float r26741 = 8;
        float r26742 = r26697 + r26741;
        float r26743 = r26740 / r26742;
        float r26744 = r26739 + r26743;
        float r26745 = r26707 * r26744;
        float r26746 = r26691 * r26745;
        return r26746;
}

double f_id(double z) {
        double r26747 = atan2(1.0, 0.0);
        double r26748 = z;
        double r26749 = r26747 * r26748;
        double r26750 = sin(r26749);
        double r26751 = r26747 / r26750;
        double r26752 = 2;
        double r26753 = r26747 * r26752;
        double r26754 = sqrt(r26753);
        double r26755 = 1;
        double r26756 = r26755 - r26748;
        double r26757 = r26756 - r26755;
        double r26758 = 7;
        double r26759 = r26757 + r26758;
        double r26760 = 0.5;
        double r26761 = r26759 + r26760;
        double r26762 = r26757 + r26760;
        double r26763 = pow(r26761, r26762);
        double r26764 = r26754 * r26763;
        double r26765 = -r26761;
        double r26766 = exp(r26765);
        double r26767 = r26764 * r26766;
        double r26768 = 0.9999999999998099;
        double r26769 = 676.5203681218851;
        double r26770 = r26757 + r26755;
        double r26771 = r26769 / r26770;
        double r26772 = r26768 + r26771;
        double r26773 = -1259.1392167224028;
        double r26774 = r26757 + r26752;
        double r26775 = r26773 / r26774;
        double r26776 = r26772 + r26775;
        double r26777 = 771.3234287776531;
        double r26778 = 3;
        double r26779 = r26757 + r26778;
        double r26780 = r26777 / r26779;
        double r26781 = r26776 + r26780;
        double r26782 = -176.6150291621406;
        double r26783 = 4;
        double r26784 = r26757 + r26783;
        double r26785 = r26782 / r26784;
        double r26786 = r26781 + r26785;
        double r26787 = 12.507343278686905;
        double r26788 = 5;
        double r26789 = r26757 + r26788;
        double r26790 = r26787 / r26789;
        double r26791 = r26786 + r26790;
        double r26792 = -0.13857109526572012;
        double r26793 = 6;
        double r26794 = r26757 + r26793;
        double r26795 = r26792 / r26794;
        double r26796 = r26791 + r26795;
        double r26797 = 9.984369578019572e-06;
        double r26798 = r26797 / r26759;
        double r26799 = r26796 + r26798;
        double r26800 = 1.5056327351493116e-07;
        double r26801 = 8;
        double r26802 = r26757 + r26801;
        double r26803 = r26800 / r26802;
        double r26804 = r26799 + r26803;
        double r26805 = r26767 * r26804;
        double r26806 = r26751 * r26805;
        return r26806;
}


double f_of(float z) {
        float r26807 = atan2(1.0, 0.0);
        float r26808 = z;
        float r26809 = r26808 * r26807;
        float r26810 = sin(r26809);
        float r26811 = r26807 / r26810;
        float r26812 = 2;
        float r26813 = r26807 * r26812;
        float r26814 = sqrt(r26813);
        float r26815 = 0.5;
        float r26816 = 7;
        float r26817 = r26816 - r26808;
        float r26818 = r26815 + r26817;
        float r26819 = exp(r26818);
        float r26820 = r26814 / r26819;
        float r26821 = r26815 - r26808;
        float r26822 = pow(r26818, r26821);
        float r26823 = r26820 * r26822;
        float r26824 = sqrt(r26823);
        float r26825 = r26824 * r26824;
        float r26826 = r26811 * r26825;
        float r26827 = 771.3234287776531;
        float r26828 = 1;
        float r26829 = r26828 - r26808;
        float r26830 = 3;
        float r26831 = r26828 - r26830;
        float r26832 = r26829 - r26831;
        float r26833 = r26827 / r26832;
        float r26834 = 0.9999999999998099;
        float r26835 = r26833 + r26834;
        float r26836 = 676.5203681218851;
        float r26837 = 0;
        float r26838 = r26829 - r26837;
        float r26839 = r26836 / r26838;
        float r26840 = -1259.1392167224028;
        float r26841 = r26812 + r26828;
        float r26842 = r26828 + r26808;
        float r26843 = r26841 - r26842;
        float r26844 = r26840 / r26843;
        float r26845 = r26839 + r26844;
        float r26846 = r26835 + r26845;
        float r26847 = 12.507343278686905;
        float r26848 = 5;
        float r26849 = r26828 - r26848;
        float r26850 = r26829 - r26849;
        float r26851 = r26847 / r26850;
        float r26852 = -176.6150291621406;
        float r26853 = 4;
        float r26854 = r26828 - r26853;
        float r26855 = r26829 - r26854;
        float r26856 = r26852 / r26855;
        float r26857 = r26851 + r26856;
        float r26858 = -0.13857109526572012;
        float r26859 = 6;
        float r26860 = r26859 + r26828;
        float r26861 = r26860 - r26842;
        float r26862 = r26858 / r26861;
        float r26863 = 9.984369578019572e-06;
        float r26864 = r26816 + r26828;
        float r26865 = r26864 - r26842;
        float r26866 = r26863 / r26865;
        float r26867 = r26862 + r26866;
        float r26868 = r26857 + r26867;
        float r26869 = r26846 + r26868;
        float r26870 = 1.5056327351493116e-07;
        float r26871 = 8;
        float r26872 = r26871 + r26828;
        float r26873 = r26872 - r26842;
        float r26874 = r26870 / r26873;
        float r26875 = r26869 + r26874;
        float r26876 = r26826 * r26875;
        return r26876;
}

double f_od(double z) {
        double r26877 = atan2(1.0, 0.0);
        double r26878 = z;
        double r26879 = r26878 * r26877;
        double r26880 = sin(r26879);
        double r26881 = r26877 / r26880;
        double r26882 = 2;
        double r26883 = r26877 * r26882;
        double r26884 = sqrt(r26883);
        double r26885 = 0.5;
        double r26886 = 7;
        double r26887 = r26886 - r26878;
        double r26888 = r26885 + r26887;
        double r26889 = exp(r26888);
        double r26890 = r26884 / r26889;
        double r26891 = r26885 - r26878;
        double r26892 = pow(r26888, r26891);
        double r26893 = r26890 * r26892;
        double r26894 = sqrt(r26893);
        double r26895 = r26894 * r26894;
        double r26896 = r26881 * r26895;
        double r26897 = 771.3234287776531;
        double r26898 = 1;
        double r26899 = r26898 - r26878;
        double r26900 = 3;
        double r26901 = r26898 - r26900;
        double r26902 = r26899 - r26901;
        double r26903 = r26897 / r26902;
        double r26904 = 0.9999999999998099;
        double r26905 = r26903 + r26904;
        double r26906 = 676.5203681218851;
        double r26907 = 0;
        double r26908 = r26899 - r26907;
        double r26909 = r26906 / r26908;
        double r26910 = -1259.1392167224028;
        double r26911 = r26882 + r26898;
        double r26912 = r26898 + r26878;
        double r26913 = r26911 - r26912;
        double r26914 = r26910 / r26913;
        double r26915 = r26909 + r26914;
        double r26916 = r26905 + r26915;
        double r26917 = 12.507343278686905;
        double r26918 = 5;
        double r26919 = r26898 - r26918;
        double r26920 = r26899 - r26919;
        double r26921 = r26917 / r26920;
        double r26922 = -176.6150291621406;
        double r26923 = 4;
        double r26924 = r26898 - r26923;
        double r26925 = r26899 - r26924;
        double r26926 = r26922 / r26925;
        double r26927 = r26921 + r26926;
        double r26928 = -0.13857109526572012;
        double r26929 = 6;
        double r26930 = r26929 + r26898;
        double r26931 = r26930 - r26912;
        double r26932 = r26928 / r26931;
        double r26933 = 9.984369578019572e-06;
        double r26934 = r26886 + r26898;
        double r26935 = r26934 - r26912;
        double r26936 = r26933 / r26935;
        double r26937 = r26932 + r26936;
        double r26938 = r26927 + r26937;
        double r26939 = r26916 + r26938;
        double r26940 = 1.5056327351493116e-07;
        double r26941 = 8;
        double r26942 = r26941 + r26898;
        double r26943 = r26942 - r26912;
        double r26944 = r26940 / r26943;
        double r26945 = r26939 + r26944;
        double r26946 = r26896 * r26945;
        return r26946;
}

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 r26947, r26948, r26949, r26950, r26951, r26952, r26953, r26954, r26955, r26956, r26957, r26958, r26959, r26960, r26961, r26962, r26963, r26964, r26965, r26966, r26967, r26968, r26969, r26970, r26971, r26972, r26973, r26974, r26975, r26976, r26977, r26978, r26979, r26980, r26981, r26982, r26983, r26984, r26985, r26986, r26987, r26988, r26989, r26990, r26991, r26992, r26993, r26994, r26995, r26996, r26997, r26998, r26999, r27000, r27001, r27002, r27003, r27004, r27005, r27006;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r26947);
        mpfr_init(r26948);
        mpfr_init(r26949);
        mpfr_init(r26950);
        mpfr_init(r26951);
        mpfr_init_set_str(r26952, "2", 10, MPFR_RNDN);
        mpfr_init(r26953);
        mpfr_init(r26954);
        mpfr_init_set_str(r26955, "1", 10, MPFR_RNDN);
        mpfr_init(r26956);
        mpfr_init(r26957);
        mpfr_init_set_str(r26958, "7", 10, MPFR_RNDN);
        mpfr_init(r26959);
        mpfr_init_set_str(r26960, "0.5", 10, MPFR_RNDN);
        mpfr_init(r26961);
        mpfr_init(r26962);
        mpfr_init(r26963);
        mpfr_init(r26964);
        mpfr_init(r26965);
        mpfr_init(r26966);
        mpfr_init(r26967);
        mpfr_init_set_str(r26968, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init_set_str(r26969, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init(r26970);
        mpfr_init(r26971);
        mpfr_init(r26972);
        mpfr_init_set_str(r26973, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r26974);
        mpfr_init(r26975);
        mpfr_init(r26976);
        mpfr_init_set_str(r26977, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r26978, "3", 10, MPFR_RNDN);
        mpfr_init(r26979);
        mpfr_init(r26980);
        mpfr_init(r26981);
        mpfr_init_set_str(r26982, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r26983, "4", 10, MPFR_RNDN);
        mpfr_init(r26984);
        mpfr_init(r26985);
        mpfr_init(r26986);
        mpfr_init_set_str(r26987, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r26988, "5", 10, MPFR_RNDN);
        mpfr_init(r26989);
        mpfr_init(r26990);
        mpfr_init(r26991);
        mpfr_init_set_str(r26992, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r26993, "6", 10, MPFR_RNDN);
        mpfr_init(r26994);
        mpfr_init(r26995);
        mpfr_init(r26996);
        mpfr_init_set_str(r26997, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r26998);
        mpfr_init(r26999);
        mpfr_init_set_str(r27000, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r27001, "8", 10, MPFR_RNDN);
        mpfr_init(r27002);
        mpfr_init(r27003);
        mpfr_init(r27004);
        mpfr_init(r27005);
        mpfr_init(r27006);
}

double f_im(double z) {
        mpfr_const_pi(r26947, MPFR_RNDN);
        mpfr_set_d(r26948, z, MPFR_RNDN);
        mpfr_mul(r26949, r26947, r26948, MPFR_RNDN);
        mpfr_sin(r26950, r26949, MPFR_RNDN);
        mpfr_div(r26951, r26947, r26950, MPFR_RNDN);
        ;
        mpfr_mul(r26953, r26947, r26952, MPFR_RNDN);
        mpfr_sqrt(r26954, r26953, MPFR_RNDN);
        ;
        mpfr_sub(r26956, r26955, r26948, MPFR_RNDN);
        mpfr_sub(r26957, r26956, r26955, MPFR_RNDN);
        ;
        mpfr_add(r26959, r26957, r26958, MPFR_RNDN);
        ;
        mpfr_add(r26961, r26959, r26960, MPFR_RNDN);
        mpfr_add(r26962, r26957, r26960, MPFR_RNDN);
        mpfr_pow(r26963, r26961, r26962, MPFR_RNDN);
        mpfr_mul(r26964, r26954, r26963, MPFR_RNDN);
        mpfr_neg(r26965, r26961, MPFR_RNDN);
        mpfr_exp(r26966, r26965, MPFR_RNDN);
        mpfr_mul(r26967, r26964, r26966, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26970, r26957, r26955, MPFR_RNDN);
        mpfr_div(r26971, r26969, r26970, MPFR_RNDN);
        mpfr_add(r26972, r26968, r26971, MPFR_RNDN);
        ;
        mpfr_add(r26974, r26957, r26952, MPFR_RNDN);
        mpfr_div(r26975, r26973, r26974, MPFR_RNDN);
        mpfr_add(r26976, r26972, r26975, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26979, r26957, r26978, MPFR_RNDN);
        mpfr_div(r26980, r26977, r26979, MPFR_RNDN);
        mpfr_add(r26981, r26976, r26980, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26984, r26957, r26983, MPFR_RNDN);
        mpfr_div(r26985, r26982, r26984, MPFR_RNDN);
        mpfr_add(r26986, r26981, r26985, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26989, r26957, r26988, MPFR_RNDN);
        mpfr_div(r26990, r26987, r26989, MPFR_RNDN);
        mpfr_add(r26991, r26986, r26990, MPFR_RNDN);
        ;
        ;
        mpfr_add(r26994, r26957, r26993, MPFR_RNDN);
        mpfr_div(r26995, r26992, r26994, MPFR_RNDN);
        mpfr_add(r26996, r26991, r26995, MPFR_RNDN);
        ;
        mpfr_div(r26998, r26997, r26959, MPFR_RNDN);
        mpfr_add(r26999, r26996, r26998, MPFR_RNDN);
        ;
        ;
        mpfr_add(r27002, r26957, r27001, MPFR_RNDN);
        mpfr_div(r27003, r27000, r27002, MPFR_RNDN);
        mpfr_add(r27004, r26999, r27003, MPFR_RNDN);
        mpfr_mul(r27005, r26967, r27004, MPFR_RNDN);
        mpfr_mul(r27006, r26951, r27005, MPFR_RNDN);
        return mpfr_get_d(r27006, MPFR_RNDN);
}

static mpfr_t r27007, r27008, r27009, r27010, r27011, r27012, r27013, r27014, r27015, r27016, r27017, r27018, r27019, r27020, r27021, r27022, r27023, r27024, r27025, r27026, r27027, r27028, r27029, r27030, r27031, r27032, r27033, r27034, r27035, r27036, r27037, r27038, r27039, r27040, r27041, r27042, r27043, r27044, r27045, r27046, r27047, r27048, r27049, r27050, r27051, r27052, r27053, r27054, r27055, r27056, r27057, r27058, r27059, r27060, r27061, r27062, r27063, r27064, r27065, r27066, r27067, r27068, r27069, r27070, r27071, r27072, r27073, r27074, r27075, r27076;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r27007);
        mpfr_init(r27008);
        mpfr_init(r27009);
        mpfr_init(r27010);
        mpfr_init(r27011);
        mpfr_init_set_str(r27012, "2", 10, MPFR_RNDN);
        mpfr_init(r27013);
        mpfr_init(r27014);
        mpfr_init_set_str(r27015, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r27016, "7", 10, MPFR_RNDN);
        mpfr_init(r27017);
        mpfr_init(r27018);
        mpfr_init(r27019);
        mpfr_init(r27020);
        mpfr_init(r27021);
        mpfr_init(r27022);
        mpfr_init(r27023);
        mpfr_init(r27024);
        mpfr_init(r27025);
        mpfr_init(r27026);
        mpfr_init_set_str(r27027, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r27028, "1", 10, MPFR_RNDN);
        mpfr_init(r27029);
        mpfr_init_set_str(r27030, "3", 10, MPFR_RNDN);
        mpfr_init(r27031);
        mpfr_init(r27032);
        mpfr_init(r27033);
        mpfr_init_set_str(r27034, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init(r27035);
        mpfr_init_set_str(r27036, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r27037, "0", 10, MPFR_RNDN);
        mpfr_init(r27038);
        mpfr_init(r27039);
        mpfr_init_set_str(r27040, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r27041);
        mpfr_init(r27042);
        mpfr_init(r27043);
        mpfr_init(r27044);
        mpfr_init(r27045);
        mpfr_init(r27046);
        mpfr_init_set_str(r27047, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r27048, "5", 10, MPFR_RNDN);
        mpfr_init(r27049);
        mpfr_init(r27050);
        mpfr_init(r27051);
        mpfr_init_set_str(r27052, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r27053, "4", 10, MPFR_RNDN);
        mpfr_init(r27054);
        mpfr_init(r27055);
        mpfr_init(r27056);
        mpfr_init(r27057);
        mpfr_init_set_str(r27058, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r27059, "6", 10, MPFR_RNDN);
        mpfr_init(r27060);
        mpfr_init(r27061);
        mpfr_init(r27062);
        mpfr_init_set_str(r27063, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r27064);
        mpfr_init(r27065);
        mpfr_init(r27066);
        mpfr_init(r27067);
        mpfr_init(r27068);
        mpfr_init(r27069);
        mpfr_init_set_str(r27070, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r27071, "8", 10, MPFR_RNDN);
        mpfr_init(r27072);
        mpfr_init(r27073);
        mpfr_init(r27074);
        mpfr_init(r27075);
        mpfr_init(r27076);
}

double f_fm(double z) {
        mpfr_const_pi(r27007, MPFR_RNDN);
        mpfr_set_d(r27008, z, MPFR_RNDN);
        mpfr_mul(r27009, r27008, r27007, MPFR_RNDN);
        mpfr_sin(r27010, r27009, MPFR_RNDN);
        mpfr_div(r27011, r27007, r27010, MPFR_RNDN);
        ;
        mpfr_mul(r27013, r27007, r27012, MPFR_RNDN);
        mpfr_sqrt(r27014, r27013, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27017, r27016, r27008, MPFR_RNDN);
        mpfr_add(r27018, r27015, r27017, MPFR_RNDN);
        mpfr_exp(r27019, r27018, MPFR_RNDN);
        mpfr_div(r27020, r27014, r27019, MPFR_RNDN);
        mpfr_sub(r27021, r27015, r27008, MPFR_RNDN);
        mpfr_pow(r27022, r27018, r27021, MPFR_RNDN);
        mpfr_mul(r27023, r27020, r27022, MPFR_RNDN);
        mpfr_sqrt(r27024, r27023, MPFR_RNDN);
        mpfr_mul(r27025, r27024, r27024, MPFR_RNDN);
        mpfr_mul(r27026, r27011, r27025, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27029, r27028, r27008, MPFR_RNDN);
        ;
        mpfr_sub(r27031, r27028, r27030, MPFR_RNDN);
        mpfr_sub(r27032, r27029, r27031, MPFR_RNDN);
        mpfr_div(r27033, r27027, r27032, MPFR_RNDN);
        ;
        mpfr_add(r27035, r27033, r27034, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27038, r27029, r27037, MPFR_RNDN);
        mpfr_div(r27039, r27036, r27038, MPFR_RNDN);
        ;
        mpfr_add(r27041, r27012, r27028, MPFR_RNDN);
        mpfr_add(r27042, r27028, r27008, MPFR_RNDN);
        mpfr_sub(r27043, r27041, r27042, MPFR_RNDN);
        mpfr_div(r27044, r27040, r27043, MPFR_RNDN);
        mpfr_add(r27045, r27039, r27044, MPFR_RNDN);
        mpfr_add(r27046, r27035, r27045, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27049, r27028, r27048, MPFR_RNDN);
        mpfr_sub(r27050, r27029, r27049, MPFR_RNDN);
        mpfr_div(r27051, r27047, r27050, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27054, r27028, r27053, MPFR_RNDN);
        mpfr_sub(r27055, r27029, r27054, MPFR_RNDN);
        mpfr_div(r27056, r27052, r27055, MPFR_RNDN);
        mpfr_add(r27057, r27051, r27056, MPFR_RNDN);
        ;
        ;
        mpfr_add(r27060, r27059, r27028, MPFR_RNDN);
        mpfr_sub(r27061, r27060, r27042, MPFR_RNDN);
        mpfr_div(r27062, r27058, r27061, MPFR_RNDN);
        ;
        mpfr_add(r27064, r27016, r27028, MPFR_RNDN);
        mpfr_sub(r27065, r27064, r27042, MPFR_RNDN);
        mpfr_div(r27066, r27063, r27065, MPFR_RNDN);
        mpfr_add(r27067, r27062, r27066, MPFR_RNDN);
        mpfr_add(r27068, r27057, r27067, MPFR_RNDN);
        mpfr_add(r27069, r27046, r27068, MPFR_RNDN);
        ;
        ;
        mpfr_add(r27072, r27071, r27028, MPFR_RNDN);
        mpfr_sub(r27073, r27072, r27042, MPFR_RNDN);
        mpfr_div(r27074, r27070, r27073, MPFR_RNDN);
        mpfr_add(r27075, r27069, r27074, MPFR_RNDN);
        mpfr_mul(r27076, r27026, r27075, MPFR_RNDN);
        return mpfr_get_d(r27076, MPFR_RNDN);
}

static mpfr_t r27077, r27078, r27079, r27080, r27081, r27082, r27083, r27084, r27085, r27086, r27087, r27088, r27089, r27090, r27091, r27092, r27093, r27094, r27095, r27096, r27097, r27098, r27099, r27100, r27101, r27102, r27103, r27104, r27105, r27106, r27107, r27108, r27109, r27110, r27111, r27112, r27113, r27114, r27115, r27116, r27117, r27118, r27119, r27120, r27121, r27122, r27123, r27124, r27125, r27126, r27127, r27128, r27129, r27130, r27131, r27132, r27133, r27134, r27135, r27136, r27137, r27138, r27139, r27140, r27141, r27142, r27143, r27144, r27145, r27146;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r27077);
        mpfr_init(r27078);
        mpfr_init(r27079);
        mpfr_init(r27080);
        mpfr_init(r27081);
        mpfr_init_set_str(r27082, "2", 10, MPFR_RNDN);
        mpfr_init(r27083);
        mpfr_init(r27084);
        mpfr_init_set_str(r27085, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r27086, "7", 10, MPFR_RNDN);
        mpfr_init(r27087);
        mpfr_init(r27088);
        mpfr_init(r27089);
        mpfr_init(r27090);
        mpfr_init(r27091);
        mpfr_init(r27092);
        mpfr_init(r27093);
        mpfr_init(r27094);
        mpfr_init(r27095);
        mpfr_init(r27096);
        mpfr_init_set_str(r27097, "771.3234287776531", 10, MPFR_RNDN);
        mpfr_init_set_str(r27098, "1", 10, MPFR_RNDN);
        mpfr_init(r27099);
        mpfr_init_set_str(r27100, "3", 10, MPFR_RNDN);
        mpfr_init(r27101);
        mpfr_init(r27102);
        mpfr_init(r27103);
        mpfr_init_set_str(r27104, "0.9999999999998099", 10, MPFR_RNDN);
        mpfr_init(r27105);
        mpfr_init_set_str(r27106, "676.5203681218851", 10, MPFR_RNDN);
        mpfr_init_set_str(r27107, "0", 10, MPFR_RNDN);
        mpfr_init(r27108);
        mpfr_init(r27109);
        mpfr_init_set_str(r27110, "-1259.1392167224028", 10, MPFR_RNDN);
        mpfr_init(r27111);
        mpfr_init(r27112);
        mpfr_init(r27113);
        mpfr_init(r27114);
        mpfr_init(r27115);
        mpfr_init(r27116);
        mpfr_init_set_str(r27117, "12.507343278686905", 10, MPFR_RNDN);
        mpfr_init_set_str(r27118, "5", 10, MPFR_RNDN);
        mpfr_init(r27119);
        mpfr_init(r27120);
        mpfr_init(r27121);
        mpfr_init_set_str(r27122, "-176.6150291621406", 10, MPFR_RNDN);
        mpfr_init_set_str(r27123, "4", 10, MPFR_RNDN);
        mpfr_init(r27124);
        mpfr_init(r27125);
        mpfr_init(r27126);
        mpfr_init(r27127);
        mpfr_init_set_str(r27128, "-0.13857109526572012", 10, MPFR_RNDN);
        mpfr_init_set_str(r27129, "6", 10, MPFR_RNDN);
        mpfr_init(r27130);
        mpfr_init(r27131);
        mpfr_init(r27132);
        mpfr_init_set_str(r27133, "9.984369578019572e-06", 10, MPFR_RNDN);
        mpfr_init(r27134);
        mpfr_init(r27135);
        mpfr_init(r27136);
        mpfr_init(r27137);
        mpfr_init(r27138);
        mpfr_init(r27139);
        mpfr_init_set_str(r27140, "1.5056327351493116e-07", 10, MPFR_RNDN);
        mpfr_init_set_str(r27141, "8", 10, MPFR_RNDN);
        mpfr_init(r27142);
        mpfr_init(r27143);
        mpfr_init(r27144);
        mpfr_init(r27145);
        mpfr_init(r27146);
}

double f_dm(double z) {
        mpfr_const_pi(r27077, MPFR_RNDN);
        mpfr_set_d(r27078, z, MPFR_RNDN);
        mpfr_mul(r27079, r27078, r27077, MPFR_RNDN);
        mpfr_sin(r27080, r27079, MPFR_RNDN);
        mpfr_div(r27081, r27077, r27080, MPFR_RNDN);
        ;
        mpfr_mul(r27083, r27077, r27082, MPFR_RNDN);
        mpfr_sqrt(r27084, r27083, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27087, r27086, r27078, MPFR_RNDN);
        mpfr_add(r27088, r27085, r27087, MPFR_RNDN);
        mpfr_exp(r27089, r27088, MPFR_RNDN);
        mpfr_div(r27090, r27084, r27089, MPFR_RNDN);
        mpfr_sub(r27091, r27085, r27078, MPFR_RNDN);
        mpfr_pow(r27092, r27088, r27091, MPFR_RNDN);
        mpfr_mul(r27093, r27090, r27092, MPFR_RNDN);
        mpfr_sqrt(r27094, r27093, MPFR_RNDN);
        mpfr_mul(r27095, r27094, r27094, MPFR_RNDN);
        mpfr_mul(r27096, r27081, r27095, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27099, r27098, r27078, MPFR_RNDN);
        ;
        mpfr_sub(r27101, r27098, r27100, MPFR_RNDN);
        mpfr_sub(r27102, r27099, r27101, MPFR_RNDN);
        mpfr_div(r27103, r27097, r27102, MPFR_RNDN);
        ;
        mpfr_add(r27105, r27103, r27104, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27108, r27099, r27107, MPFR_RNDN);
        mpfr_div(r27109, r27106, r27108, MPFR_RNDN);
        ;
        mpfr_add(r27111, r27082, r27098, MPFR_RNDN);
        mpfr_add(r27112, r27098, r27078, MPFR_RNDN);
        mpfr_sub(r27113, r27111, r27112, MPFR_RNDN);
        mpfr_div(r27114, r27110, r27113, MPFR_RNDN);
        mpfr_add(r27115, r27109, r27114, MPFR_RNDN);
        mpfr_add(r27116, r27105, r27115, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27119, r27098, r27118, MPFR_RNDN);
        mpfr_sub(r27120, r27099, r27119, MPFR_RNDN);
        mpfr_div(r27121, r27117, r27120, MPFR_RNDN);
        ;
        ;
        mpfr_sub(r27124, r27098, r27123, MPFR_RNDN);
        mpfr_sub(r27125, r27099, r27124, MPFR_RNDN);
        mpfr_div(r27126, r27122, r27125, MPFR_RNDN);
        mpfr_add(r27127, r27121, r27126, MPFR_RNDN);
        ;
        ;
        mpfr_add(r27130, r27129, r27098, MPFR_RNDN);
        mpfr_sub(r27131, r27130, r27112, MPFR_RNDN);
        mpfr_div(r27132, r27128, r27131, MPFR_RNDN);
        ;
        mpfr_add(r27134, r27086, r27098, MPFR_RNDN);
        mpfr_sub(r27135, r27134, r27112, MPFR_RNDN);
        mpfr_div(r27136, r27133, r27135, MPFR_RNDN);
        mpfr_add(r27137, r27132, r27136, MPFR_RNDN);
        mpfr_add(r27138, r27127, r27137, MPFR_RNDN);
        mpfr_add(r27139, r27116, r27138, MPFR_RNDN);
        ;
        ;
        mpfr_add(r27142, r27141, r27098, MPFR_RNDN);
        mpfr_sub(r27143, r27142, r27112, MPFR_RNDN);
        mpfr_div(r27144, r27140, r27143, MPFR_RNDN);
        mpfr_add(r27145, r27139, r27144, MPFR_RNDN);
        mpfr_mul(r27146, r27096, r27145, MPFR_RNDN);
        return mpfr_get_d(r27146, MPFR_RNDN);
}

