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

char *name = "Octave 3.8, jcobi/2";

double f_if(float alpha, float beta, float i) {
        float r26064 = alpha;
        float r26065 = beta;
        float r26066 = r26064 + r26065;
        float r26067 = r26065 - r26064;
        float r26068 = r26066 * r26067;
        float r26069 = 2;
        float r26070 = i;
        float r26071 = r26069 * r26070;
        float r26072 = r26066 + r26071;
        float r26073 = r26068 / r26072;
        float r26074 = 2.0;
        float r26075 = r26072 + r26074;
        float r26076 = r26073 / r26075;
        float r26077 = 1.0;
        float r26078 = r26076 + r26077;
        float r26079 = r26078 / r26074;
        return r26079;
}

double f_id(double alpha, double beta, double i) {
        double r26080 = alpha;
        double r26081 = beta;
        double r26082 = r26080 + r26081;
        double r26083 = r26081 - r26080;
        double r26084 = r26082 * r26083;
        double r26085 = 2;
        double r26086 = i;
        double r26087 = r26085 * r26086;
        double r26088 = r26082 + r26087;
        double r26089 = r26084 / r26088;
        double r26090 = 2.0;
        double r26091 = r26088 + r26090;
        double r26092 = r26089 / r26091;
        double r26093 = 1.0;
        double r26094 = r26092 + r26093;
        double r26095 = r26094 / r26090;
        return r26095;
}


double f_of(float alpha, float beta, float i) {
        float r26096 = beta;
        float r26097 = alpha;
        float r26098 = r26096 + r26097;
        float r26099 = i;
        float r26100 = 2;
        float r26101 = fma(r26099, r26100, r26096);
        float r26102 = 2.0;
        float r26103 = r26102 + r26097;
        float r26104 = r26101 + r26103;
        float r26105 = r26098 / r26104;
        float r26106 = r26096 - r26097;
        float r26107 = 1;
        float r26108 = fma(r26100, r26099, r26098);
        float r26109 = r26107 / r26108;
        float r26110 = sqrt(r26109);
        float r26111 = r26110 * r26110;
        float r26112 = r26106 * r26111;
        float r26113 = 1.0;
        float r26114 = fma(r26105, r26112, r26113);
        float r26115 = r26114 / r26102;
        float r26116 = 6.603606550470431e-13;
        bool r26117 = r26115 <= r26116;
        float r26118 = 8.0;
        float r26119 = r26118 / r26097;
        float r26120 = 4.0;
        float r26121 = r26119 - r26120;
        float r26122 = r26097 * r26097;
        float r26123 = r26107 / r26122;
        float r26124 = r26102 / r26097;
        float r26125 = fma(r26121, r26123, r26124);
        float r26126 = r26125 / r26102;
        float r26127 = cbrt(r26108);
        float r26128 = r26127 * r26127;
        float r26129 = r26107 / r26128;
        float r26130 = r26106 / r26127;
        float r26131 = r26129 * r26130;
        float r26132 = fma(r26105, r26131, r26113);
        float r26133 = r26132 / r26102;
        float r26134 = r26117 ? r26126 : r26133;
        return r26134;
}

double f_od(double alpha, double beta, double i) {
        double r26135 = beta;
        double r26136 = alpha;
        double r26137 = r26135 + r26136;
        double r26138 = i;
        double r26139 = 2;
        double r26140 = fma(r26138, r26139, r26135);
        double r26141 = 2.0;
        double r26142 = r26141 + r26136;
        double r26143 = r26140 + r26142;
        double r26144 = r26137 / r26143;
        double r26145 = r26135 - r26136;
        double r26146 = 1;
        double r26147 = fma(r26139, r26138, r26137);
        double r26148 = r26146 / r26147;
        double r26149 = sqrt(r26148);
        double r26150 = r26149 * r26149;
        double r26151 = r26145 * r26150;
        double r26152 = 1.0;
        double r26153 = fma(r26144, r26151, r26152);
        double r26154 = r26153 / r26141;
        double r26155 = 6.603606550470431e-13;
        bool r26156 = r26154 <= r26155;
        double r26157 = 8.0;
        double r26158 = r26157 / r26136;
        double r26159 = 4.0;
        double r26160 = r26158 - r26159;
        double r26161 = r26136 * r26136;
        double r26162 = r26146 / r26161;
        double r26163 = r26141 / r26136;
        double r26164 = fma(r26160, r26162, r26163);
        double r26165 = r26164 / r26141;
        double r26166 = cbrt(r26147);
        double r26167 = r26166 * r26166;
        double r26168 = r26146 / r26167;
        double r26169 = r26145 / r26166;
        double r26170 = r26168 * r26169;
        double r26171 = fma(r26144, r26170, r26152);
        double r26172 = r26171 / r26141;
        double r26173 = r26156 ? r26165 : r26172;
        return r26173;
}

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 r26174, r26175, r26176, r26177, r26178, r26179, r26180, r26181, r26182, r26183, r26184, r26185, r26186, r26187, r26188, r26189;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26174);
        mpfr_init(r26175);
        mpfr_init(r26176);
        mpfr_init(r26177);
        mpfr_init(r26178);
        mpfr_init_set_str(r26179, "2", 10, MPFR_RNDN);
        mpfr_init(r26180);
        mpfr_init(r26181);
        mpfr_init(r26182);
        mpfr_init(r26183);
        mpfr_init_set_str(r26184, "2.0", 10, MPFR_RNDN);
        mpfr_init(r26185);
        mpfr_init(r26186);
        mpfr_init_set_str(r26187, "1.0", 10, MPFR_RNDN);
        mpfr_init(r26188);
        mpfr_init(r26189);
}

double f_im(double alpha, double beta, double i) {
        mpfr_set_d(r26174, alpha, MPFR_RNDN);
        mpfr_set_d(r26175, beta, MPFR_RNDN);
        mpfr_add(r26176, r26174, r26175, MPFR_RNDN);
        mpfr_sub(r26177, r26175, r26174, MPFR_RNDN);
        mpfr_mul(r26178, r26176, r26177, MPFR_RNDN);
        ;
        mpfr_set_d(r26180, i, MPFR_RNDN);
        mpfr_mul(r26181, r26179, r26180, MPFR_RNDN);
        mpfr_add(r26182, r26176, r26181, MPFR_RNDN);
        mpfr_div(r26183, r26178, r26182, MPFR_RNDN);
        ;
        mpfr_add(r26185, r26182, r26184, MPFR_RNDN);
        mpfr_div(r26186, r26183, r26185, MPFR_RNDN);
        ;
        mpfr_add(r26188, r26186, r26187, MPFR_RNDN);
        mpfr_div(r26189, r26188, r26184, MPFR_RNDN);
        return mpfr_get_d(r26189, MPFR_RNDN);
}

static mpfr_t r26190, r26191, r26192, r26193, r26194, r26195, r26196, r26197, r26198, r26199, r26200, r26201, r26202, r26203, r26204, r26205, r26206, r26207, r26208, r26209, r26210, r26211, r26212, r26213, r26214, r26215, r26216, r26217, r26218, r26219, r26220, r26221, r26222, r26223, r26224, r26225, r26226, r26227, r26228;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26190);
        mpfr_init(r26191);
        mpfr_init(r26192);
        mpfr_init(r26193);
        mpfr_init_set_str(r26194, "2", 10, MPFR_RNDN);
        mpfr_init(r26195);
        mpfr_init_set_str(r26196, "2.0", 10, MPFR_RNDN);
        mpfr_init(r26197);
        mpfr_init(r26198);
        mpfr_init(r26199);
        mpfr_init(r26200);
        mpfr_init_set_str(r26201, "1", 10, MPFR_RNDN);
        mpfr_init(r26202);
        mpfr_init(r26203);
        mpfr_init(r26204);
        mpfr_init(r26205);
        mpfr_init(r26206);
        mpfr_init_set_str(r26207, "1.0", 10, MPFR_RNDN);
        mpfr_init(r26208);
        mpfr_init(r26209);
        mpfr_init_set_str(r26210, "6.603606550470431e-13", 10, MPFR_RNDN);
        mpfr_init(r26211);
        mpfr_init_set_str(r26212, "8.0", 10, MPFR_RNDN);
        mpfr_init(r26213);
        mpfr_init_set_str(r26214, "4.0", 10, MPFR_RNDN);
        mpfr_init(r26215);
        mpfr_init(r26216);
        mpfr_init(r26217);
        mpfr_init(r26218);
        mpfr_init(r26219);
        mpfr_init(r26220);
        mpfr_init(r26221);
        mpfr_init(r26222);
        mpfr_init(r26223);
        mpfr_init(r26224);
        mpfr_init(r26225);
        mpfr_init(r26226);
        mpfr_init(r26227);
        mpfr_init(r26228);
}

double f_fm(double alpha, double beta, double i) {
        mpfr_set_d(r26190, beta, MPFR_RNDN);
        mpfr_set_d(r26191, alpha, MPFR_RNDN);
        mpfr_add(r26192, r26190, r26191, MPFR_RNDN);
        mpfr_set_d(r26193, i, MPFR_RNDN);
        ;
        mpfr_fma(r26195, r26193, r26194, r26190, MPFR_RNDN);
        ;
        mpfr_add(r26197, r26196, r26191, MPFR_RNDN);
        mpfr_add(r26198, r26195, r26197, MPFR_RNDN);
        mpfr_div(r26199, r26192, r26198, MPFR_RNDN);
        mpfr_sub(r26200, r26190, r26191, MPFR_RNDN);
        ;
        mpfr_fma(r26202, r26194, r26193, r26192, MPFR_RNDN);
        mpfr_div(r26203, r26201, r26202, MPFR_RNDN);
        mpfr_sqrt(r26204, r26203, MPFR_RNDN);
        mpfr_mul(r26205, r26204, r26204, MPFR_RNDN);
        mpfr_mul(r26206, r26200, r26205, MPFR_RNDN);
        ;
        mpfr_fma(r26208, r26199, r26206, r26207, MPFR_RNDN);
        mpfr_div(r26209, r26208, r26196, MPFR_RNDN);
        ;
        mpfr_set_si(r26211, mpfr_cmp(r26209, r26210) <= 0, MPFR_RNDN);
        ;
        mpfr_div(r26213, r26212, r26191, MPFR_RNDN);
        ;
        mpfr_sub(r26215, r26213, r26214, MPFR_RNDN);
        mpfr_mul(r26216, r26191, r26191, MPFR_RNDN);
        mpfr_div(r26217, r26201, r26216, MPFR_RNDN);
        mpfr_div(r26218, r26196, r26191, MPFR_RNDN);
        mpfr_fma(r26219, r26215, r26217, r26218, MPFR_RNDN);
        mpfr_div(r26220, r26219, r26196, MPFR_RNDN);
        mpfr_cbrt(r26221, r26202, MPFR_RNDN);
        mpfr_mul(r26222, r26221, r26221, MPFR_RNDN);
        mpfr_div(r26223, r26201, r26222, MPFR_RNDN);
        mpfr_div(r26224, r26200, r26221, MPFR_RNDN);
        mpfr_mul(r26225, r26223, r26224, MPFR_RNDN);
        mpfr_fma(r26226, r26199, r26225, r26207, MPFR_RNDN);
        mpfr_div(r26227, r26226, r26196, MPFR_RNDN);
        if (mpfr_get_si(r26211, MPFR_RNDN)) { mpfr_set(r26228, r26220, MPFR_RNDN); } else { mpfr_set(r26228, r26227, MPFR_RNDN); };
        return mpfr_get_d(r26228, MPFR_RNDN);
}

static mpfr_t r26229, r26230, r26231, r26232, r26233, r26234, r26235, r26236, r26237, r26238, r26239, r26240, r26241, r26242, r26243, r26244, r26245, r26246, r26247, r26248, r26249, r26250, r26251, r26252, r26253, r26254, r26255, r26256, r26257, r26258, r26259, r26260, r26261, r26262, r26263, r26264, r26265, r26266, r26267;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26229);
        mpfr_init(r26230);
        mpfr_init(r26231);
        mpfr_init(r26232);
        mpfr_init_set_str(r26233, "2", 10, MPFR_RNDN);
        mpfr_init(r26234);
        mpfr_init_set_str(r26235, "2.0", 10, MPFR_RNDN);
        mpfr_init(r26236);
        mpfr_init(r26237);
        mpfr_init(r26238);
        mpfr_init(r26239);
        mpfr_init_set_str(r26240, "1", 10, MPFR_RNDN);
        mpfr_init(r26241);
        mpfr_init(r26242);
        mpfr_init(r26243);
        mpfr_init(r26244);
        mpfr_init(r26245);
        mpfr_init_set_str(r26246, "1.0", 10, MPFR_RNDN);
        mpfr_init(r26247);
        mpfr_init(r26248);
        mpfr_init_set_str(r26249, "6.603606550470431e-13", 10, MPFR_RNDN);
        mpfr_init(r26250);
        mpfr_init_set_str(r26251, "8.0", 10, MPFR_RNDN);
        mpfr_init(r26252);
        mpfr_init_set_str(r26253, "4.0", 10, MPFR_RNDN);
        mpfr_init(r26254);
        mpfr_init(r26255);
        mpfr_init(r26256);
        mpfr_init(r26257);
        mpfr_init(r26258);
        mpfr_init(r26259);
        mpfr_init(r26260);
        mpfr_init(r26261);
        mpfr_init(r26262);
        mpfr_init(r26263);
        mpfr_init(r26264);
        mpfr_init(r26265);
        mpfr_init(r26266);
        mpfr_init(r26267);
}

double f_dm(double alpha, double beta, double i) {
        mpfr_set_d(r26229, beta, MPFR_RNDN);
        mpfr_set_d(r26230, alpha, MPFR_RNDN);
        mpfr_add(r26231, r26229, r26230, MPFR_RNDN);
        mpfr_set_d(r26232, i, MPFR_RNDN);
        ;
        mpfr_fma(r26234, r26232, r26233, r26229, MPFR_RNDN);
        ;
        mpfr_add(r26236, r26235, r26230, MPFR_RNDN);
        mpfr_add(r26237, r26234, r26236, MPFR_RNDN);
        mpfr_div(r26238, r26231, r26237, MPFR_RNDN);
        mpfr_sub(r26239, r26229, r26230, MPFR_RNDN);
        ;
        mpfr_fma(r26241, r26233, r26232, r26231, MPFR_RNDN);
        mpfr_div(r26242, r26240, r26241, MPFR_RNDN);
        mpfr_sqrt(r26243, r26242, MPFR_RNDN);
        mpfr_mul(r26244, r26243, r26243, MPFR_RNDN);
        mpfr_mul(r26245, r26239, r26244, MPFR_RNDN);
        ;
        mpfr_fma(r26247, r26238, r26245, r26246, MPFR_RNDN);
        mpfr_div(r26248, r26247, r26235, MPFR_RNDN);
        ;
        mpfr_set_si(r26250, mpfr_cmp(r26248, r26249) <= 0, MPFR_RNDN);
        ;
        mpfr_div(r26252, r26251, r26230, MPFR_RNDN);
        ;
        mpfr_sub(r26254, r26252, r26253, MPFR_RNDN);
        mpfr_mul(r26255, r26230, r26230, MPFR_RNDN);
        mpfr_div(r26256, r26240, r26255, MPFR_RNDN);
        mpfr_div(r26257, r26235, r26230, MPFR_RNDN);
        mpfr_fma(r26258, r26254, r26256, r26257, MPFR_RNDN);
        mpfr_div(r26259, r26258, r26235, MPFR_RNDN);
        mpfr_cbrt(r26260, r26241, MPFR_RNDN);
        mpfr_mul(r26261, r26260, r26260, MPFR_RNDN);
        mpfr_div(r26262, r26240, r26261, MPFR_RNDN);
        mpfr_div(r26263, r26239, r26260, MPFR_RNDN);
        mpfr_mul(r26264, r26262, r26263, MPFR_RNDN);
        mpfr_fma(r26265, r26238, r26264, r26246, MPFR_RNDN);
        mpfr_div(r26266, r26265, r26235, MPFR_RNDN);
        if (mpfr_get_si(r26250, MPFR_RNDN)) { mpfr_set(r26267, r26259, MPFR_RNDN); } else { mpfr_set(r26267, r26266, MPFR_RNDN); };
        return mpfr_get_d(r26267, MPFR_RNDN);
}

