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

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

double f_if(float alpha, float beta, float i) {
        float r23298 = i;
        float r23299 = alpha;
        float r23300 = beta;
        float r23301 = r23299 + r23300;
        float r23302 = r23301 + r23298;
        float r23303 = r23298 * r23302;
        float r23304 = r23300 * r23299;
        float r23305 = r23304 + r23303;
        float r23306 = r23303 * r23305;
        float r23307 = 2;
        float r23308 = r23307 * r23298;
        float r23309 = r23301 + r23308;
        float r23310 = r23309 * r23309;
        float r23311 = r23306 / r23310;
        float r23312 = 1.0;
        float r23313 = r23310 - r23312;
        float r23314 = r23311 / r23313;
        return r23314;
}

double f_id(double alpha, double beta, double i) {
        double r23315 = i;
        double r23316 = alpha;
        double r23317 = beta;
        double r23318 = r23316 + r23317;
        double r23319 = r23318 + r23315;
        double r23320 = r23315 * r23319;
        double r23321 = r23317 * r23316;
        double r23322 = r23321 + r23320;
        double r23323 = r23320 * r23322;
        double r23324 = 2;
        double r23325 = r23324 * r23315;
        double r23326 = r23318 + r23325;
        double r23327 = r23326 * r23326;
        double r23328 = r23323 / r23327;
        double r23329 = 1.0;
        double r23330 = r23327 - r23329;
        double r23331 = r23328 / r23330;
        return r23331;
}


double f_of(float alpha, float beta, float i) {
        float r23332 = beta;
        float r23333 = 1.22388054911089e+154;
        bool r23334 = r23332 <= r23333;
        float r23335 = alpha;
        float r23336 = i;
        float r23337 = r23335 + r23336;
        float r23338 = r23337 + r23332;
        float r23339 = r23332 * r23335;
        float r23340 = fma(r23338, r23336, r23339);
        float r23341 = 2;
        float r23342 = fma(r23336, r23341, r23335);
        float r23343 = r23342 + r23332;
        float r23344 = 1.0;
        float r23345 = -r23344;
        float r23346 = fma(r23343, r23343, r23345);
        float r23347 = r23340 / r23346;
        float r23348 = log1p(r23347);
        float r23349 = expm1(r23348);
        float r23350 = r23338 / r23343;
        float r23351 = r23336 / r23343;
        float r23352 = r23350 * r23351;
        float r23353 = r23349 * r23352;
        float r23354 = 0;
        float r23355 = r23334 ? r23353 : r23354;
        return r23355;
}

double f_od(double alpha, double beta, double i) {
        double r23356 = beta;
        double r23357 = 1.22388054911089e+154;
        bool r23358 = r23356 <= r23357;
        double r23359 = alpha;
        double r23360 = i;
        double r23361 = r23359 + r23360;
        double r23362 = r23361 + r23356;
        double r23363 = r23356 * r23359;
        double r23364 = fma(r23362, r23360, r23363);
        double r23365 = 2;
        double r23366 = fma(r23360, r23365, r23359);
        double r23367 = r23366 + r23356;
        double r23368 = 1.0;
        double r23369 = -r23368;
        double r23370 = fma(r23367, r23367, r23369);
        double r23371 = r23364 / r23370;
        double r23372 = log1p(r23371);
        double r23373 = expm1(r23372);
        double r23374 = r23362 / r23367;
        double r23375 = r23360 / r23367;
        double r23376 = r23374 * r23375;
        double r23377 = r23373 * r23376;
        double r23378 = 0;
        double r23379 = r23358 ? r23377 : r23378;
        return r23379;
}

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 r23380, r23381, r23382, r23383, r23384, r23385, r23386, r23387, r23388, r23389, r23390, r23391, r23392, r23393, r23394, r23395, r23396;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r23380);
        mpfr_init(r23381);
        mpfr_init(r23382);
        mpfr_init(r23383);
        mpfr_init(r23384);
        mpfr_init(r23385);
        mpfr_init(r23386);
        mpfr_init(r23387);
        mpfr_init(r23388);
        mpfr_init_set_str(r23389, "2", 10, MPFR_RNDN);
        mpfr_init(r23390);
        mpfr_init(r23391);
        mpfr_init(r23392);
        mpfr_init(r23393);
        mpfr_init_set_str(r23394, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23395);
        mpfr_init(r23396);
}

double f_im(double alpha, double beta, double i) {
        mpfr_set_d(r23380, i, MPFR_RNDN);
        mpfr_set_d(r23381, alpha, MPFR_RNDN);
        mpfr_set_d(r23382, beta, MPFR_RNDN);
        mpfr_add(r23383, r23381, r23382, MPFR_RNDN);
        mpfr_add(r23384, r23383, r23380, MPFR_RNDN);
        mpfr_mul(r23385, r23380, r23384, MPFR_RNDN);
        mpfr_mul(r23386, r23382, r23381, MPFR_RNDN);
        mpfr_add(r23387, r23386, r23385, MPFR_RNDN);
        mpfr_mul(r23388, r23385, r23387, MPFR_RNDN);
        ;
        mpfr_mul(r23390, r23389, r23380, MPFR_RNDN);
        mpfr_add(r23391, r23383, r23390, MPFR_RNDN);
        mpfr_mul(r23392, r23391, r23391, MPFR_RNDN);
        mpfr_div(r23393, r23388, r23392, MPFR_RNDN);
        ;
        mpfr_sub(r23395, r23392, r23394, MPFR_RNDN);
        mpfr_div(r23396, r23393, r23395, MPFR_RNDN);
        return mpfr_get_d(r23396, MPFR_RNDN);
}

static mpfr_t r23397, r23398, r23399, r23400, r23401, r23402, r23403, r23404, r23405, r23406, r23407, r23408, r23409, r23410, r23411, r23412, r23413, r23414, r23415, r23416, r23417, r23418, r23419, r23420;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r23397);
        mpfr_init_set_str(r23398, "1.22388054911089e+154", 10, MPFR_RNDN);
        mpfr_init(r23399);
        mpfr_init(r23400);
        mpfr_init(r23401);
        mpfr_init(r23402);
        mpfr_init(r23403);
        mpfr_init(r23404);
        mpfr_init(r23405);
        mpfr_init_set_str(r23406, "2", 10, MPFR_RNDN);
        mpfr_init(r23407);
        mpfr_init(r23408);
        mpfr_init_set_str(r23409, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23410);
        mpfr_init(r23411);
        mpfr_init(r23412);
        mpfr_init(r23413);
        mpfr_init(r23414);
        mpfr_init(r23415);
        mpfr_init(r23416);
        mpfr_init(r23417);
        mpfr_init(r23418);
        mpfr_init_set_str(r23419, "0", 10, MPFR_RNDN);
        mpfr_init(r23420);
}

double f_fm(double alpha, double beta, double i) {
        mpfr_set_d(r23397, beta, MPFR_RNDN);
        ;
        mpfr_set_si(r23399, mpfr_cmp(r23397, r23398) <= 0, MPFR_RNDN);
        mpfr_set_d(r23400, alpha, MPFR_RNDN);
        mpfr_set_d(r23401, i, MPFR_RNDN);
        mpfr_add(r23402, r23400, r23401, MPFR_RNDN);
        mpfr_add(r23403, r23402, r23397, MPFR_RNDN);
        mpfr_mul(r23404, r23397, r23400, MPFR_RNDN);
        mpfr_fma(r23405, r23403, r23401, r23404, MPFR_RNDN);
        ;
        mpfr_fma(r23407, r23401, r23406, r23400, MPFR_RNDN);
        mpfr_add(r23408, r23407, r23397, MPFR_RNDN);
        ;
        mpfr_neg(r23410, r23409, MPFR_RNDN);
        mpfr_fma(r23411, r23408, r23408, r23410, MPFR_RNDN);
        mpfr_div(r23412, r23405, r23411, MPFR_RNDN);
        mpfr_log1p(r23413, r23412, MPFR_RNDN);
        mpfr_expm1(r23414, r23413, MPFR_RNDN);
        mpfr_div(r23415, r23403, r23408, MPFR_RNDN);
        mpfr_div(r23416, r23401, r23408, MPFR_RNDN);
        mpfr_mul(r23417, r23415, r23416, MPFR_RNDN);
        mpfr_mul(r23418, r23414, r23417, MPFR_RNDN);
        ;
        if (mpfr_get_si(r23399, MPFR_RNDN)) { mpfr_set(r23420, r23418, MPFR_RNDN); } else { mpfr_set(r23420, r23419, MPFR_RNDN); };
        return mpfr_get_d(r23420, MPFR_RNDN);
}

static mpfr_t r23421, r23422, r23423, r23424, r23425, r23426, r23427, r23428, r23429, r23430, r23431, r23432, r23433, r23434, r23435, r23436, r23437, r23438, r23439, r23440, r23441, r23442, r23443, r23444;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r23421);
        mpfr_init_set_str(r23422, "1.22388054911089e+154", 10, MPFR_RNDN);
        mpfr_init(r23423);
        mpfr_init(r23424);
        mpfr_init(r23425);
        mpfr_init(r23426);
        mpfr_init(r23427);
        mpfr_init(r23428);
        mpfr_init(r23429);
        mpfr_init_set_str(r23430, "2", 10, MPFR_RNDN);
        mpfr_init(r23431);
        mpfr_init(r23432);
        mpfr_init_set_str(r23433, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23434);
        mpfr_init(r23435);
        mpfr_init(r23436);
        mpfr_init(r23437);
        mpfr_init(r23438);
        mpfr_init(r23439);
        mpfr_init(r23440);
        mpfr_init(r23441);
        mpfr_init(r23442);
        mpfr_init_set_str(r23443, "0", 10, MPFR_RNDN);
        mpfr_init(r23444);
}

double f_dm(double alpha, double beta, double i) {
        mpfr_set_d(r23421, beta, MPFR_RNDN);
        ;
        mpfr_set_si(r23423, mpfr_cmp(r23421, r23422) <= 0, MPFR_RNDN);
        mpfr_set_d(r23424, alpha, MPFR_RNDN);
        mpfr_set_d(r23425, i, MPFR_RNDN);
        mpfr_add(r23426, r23424, r23425, MPFR_RNDN);
        mpfr_add(r23427, r23426, r23421, MPFR_RNDN);
        mpfr_mul(r23428, r23421, r23424, MPFR_RNDN);
        mpfr_fma(r23429, r23427, r23425, r23428, MPFR_RNDN);
        ;
        mpfr_fma(r23431, r23425, r23430, r23424, MPFR_RNDN);
        mpfr_add(r23432, r23431, r23421, MPFR_RNDN);
        ;
        mpfr_neg(r23434, r23433, MPFR_RNDN);
        mpfr_fma(r23435, r23432, r23432, r23434, MPFR_RNDN);
        mpfr_div(r23436, r23429, r23435, MPFR_RNDN);
        mpfr_log1p(r23437, r23436, MPFR_RNDN);
        mpfr_expm1(r23438, r23437, MPFR_RNDN);
        mpfr_div(r23439, r23427, r23432, MPFR_RNDN);
        mpfr_div(r23440, r23425, r23432, MPFR_RNDN);
        mpfr_mul(r23441, r23439, r23440, MPFR_RNDN);
        mpfr_mul(r23442, r23438, r23441, MPFR_RNDN);
        ;
        if (mpfr_get_si(r23423, MPFR_RNDN)) { mpfr_set(r23444, r23442, MPFR_RNDN); } else { mpfr_set(r23444, r23443, MPFR_RNDN); };
        return mpfr_get_d(r23444, MPFR_RNDN);
}

