#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 r23530 = i;
        float r23531 = alpha;
        float r23532 = beta;
        float r23533 = r23531 + r23532;
        float r23534 = r23533 + r23530;
        float r23535 = r23530 * r23534;
        float r23536 = r23532 * r23531;
        float r23537 = r23536 + r23535;
        float r23538 = r23535 * r23537;
        float r23539 = 2;
        float r23540 = r23539 * r23530;
        float r23541 = r23533 + r23540;
        float r23542 = r23541 * r23541;
        float r23543 = r23538 / r23542;
        float r23544 = 1.0;
        float r23545 = r23542 - r23544;
        float r23546 = r23543 / r23545;
        return r23546;
}

double f_id(double alpha, double beta, double i) {
        double r23547 = i;
        double r23548 = alpha;
        double r23549 = beta;
        double r23550 = r23548 + r23549;
        double r23551 = r23550 + r23547;
        double r23552 = r23547 * r23551;
        double r23553 = r23549 * r23548;
        double r23554 = r23553 + r23552;
        double r23555 = r23552 * r23554;
        double r23556 = 2;
        double r23557 = r23556 * r23547;
        double r23558 = r23550 + r23557;
        double r23559 = r23558 * r23558;
        double r23560 = r23555 / r23559;
        double r23561 = 1.0;
        double r23562 = r23559 - r23561;
        double r23563 = r23560 / r23562;
        return r23563;
}


double f_of(float alpha, float beta, float i) {
        float r23564 = alpha;
        float r23565 = beta;
        float r23566 = r23564 + r23565;
        float r23567 = 2.367490657871795e+153;
        bool r23568 = r23566 <= r23567;
        float r23569 = i;
        float r23570 = r23569 + r23565;
        float r23571 = r23564 + r23570;
        float r23572 = 2;
        float r23573 = r23569 * r23572;
        float r23574 = r23566 + r23573;
        float r23575 = r23574 / r23569;
        float r23576 = r23571 / r23575;
        float r23577 = r23565 * r23564;
        float r23578 = r23566 + r23569;
        float r23579 = r23569 * r23578;
        float r23580 = r23577 + r23579;
        float r23581 = r23572 * r23569;
        float r23582 = r23566 + r23581;
        float r23583 = r23580 / r23582;
        float r23584 = r23582 * r23582;
        float r23585 = 1.0;
        float r23586 = r23584 - r23585;
        float r23587 = r23583 / r23586;
        float r23588 = r23576 * r23587;
        float r23589 = 0;
        float r23590 = r23568 ? r23588 : r23589;
        return r23590;
}

double f_od(double alpha, double beta, double i) {
        double r23591 = alpha;
        double r23592 = beta;
        double r23593 = r23591 + r23592;
        double r23594 = 2.367490657871795e+153;
        bool r23595 = r23593 <= r23594;
        double r23596 = i;
        double r23597 = r23596 + r23592;
        double r23598 = r23591 + r23597;
        double r23599 = 2;
        double r23600 = r23596 * r23599;
        double r23601 = r23593 + r23600;
        double r23602 = r23601 / r23596;
        double r23603 = r23598 / r23602;
        double r23604 = r23592 * r23591;
        double r23605 = r23593 + r23596;
        double r23606 = r23596 * r23605;
        double r23607 = r23604 + r23606;
        double r23608 = r23599 * r23596;
        double r23609 = r23593 + r23608;
        double r23610 = r23607 / r23609;
        double r23611 = r23609 * r23609;
        double r23612 = 1.0;
        double r23613 = r23611 - r23612;
        double r23614 = r23610 / r23613;
        double r23615 = r23603 * r23614;
        double r23616 = 0;
        double r23617 = r23595 ? r23615 : r23616;
        return r23617;
}

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 r23618, r23619, r23620, r23621, r23622, r23623, r23624, r23625, r23626, r23627, r23628, r23629, r23630, r23631, r23632, r23633, r23634;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r23618);
        mpfr_init(r23619);
        mpfr_init(r23620);
        mpfr_init(r23621);
        mpfr_init(r23622);
        mpfr_init(r23623);
        mpfr_init(r23624);
        mpfr_init(r23625);
        mpfr_init(r23626);
        mpfr_init_set_str(r23627, "2", 10, MPFR_RNDN);
        mpfr_init(r23628);
        mpfr_init(r23629);
        mpfr_init(r23630);
        mpfr_init(r23631);
        mpfr_init_set_str(r23632, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23633);
        mpfr_init(r23634);
}

double f_im(double alpha, double beta, double i) {
        mpfr_set_d(r23618, i, MPFR_RNDN);
        mpfr_set_d(r23619, alpha, MPFR_RNDN);
        mpfr_set_d(r23620, beta, MPFR_RNDN);
        mpfr_add(r23621, r23619, r23620, MPFR_RNDN);
        mpfr_add(r23622, r23621, r23618, MPFR_RNDN);
        mpfr_mul(r23623, r23618, r23622, MPFR_RNDN);
        mpfr_mul(r23624, r23620, r23619, MPFR_RNDN);
        mpfr_add(r23625, r23624, r23623, MPFR_RNDN);
        mpfr_mul(r23626, r23623, r23625, MPFR_RNDN);
        ;
        mpfr_mul(r23628, r23627, r23618, MPFR_RNDN);
        mpfr_add(r23629, r23621, r23628, MPFR_RNDN);
        mpfr_mul(r23630, r23629, r23629, MPFR_RNDN);
        mpfr_div(r23631, r23626, r23630, MPFR_RNDN);
        ;
        mpfr_sub(r23633, r23630, r23632, MPFR_RNDN);
        mpfr_div(r23634, r23631, r23633, MPFR_RNDN);
        return mpfr_get_d(r23634, MPFR_RNDN);
}

static mpfr_t r23635, r23636, r23637, r23638, r23639, r23640, r23641, r23642, r23643, r23644, r23645, r23646, r23647, r23648, r23649, r23650, r23651, r23652, r23653, r23654, r23655, r23656, r23657, r23658, r23659, r23660, r23661;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r23635);
        mpfr_init(r23636);
        mpfr_init(r23637);
        mpfr_init_set_str(r23638, "2.367490657871795e+153", 10, MPFR_RNDN);
        mpfr_init(r23639);
        mpfr_init(r23640);
        mpfr_init(r23641);
        mpfr_init(r23642);
        mpfr_init_set_str(r23643, "2", 10, MPFR_RNDN);
        mpfr_init(r23644);
        mpfr_init(r23645);
        mpfr_init(r23646);
        mpfr_init(r23647);
        mpfr_init(r23648);
        mpfr_init(r23649);
        mpfr_init(r23650);
        mpfr_init(r23651);
        mpfr_init(r23652);
        mpfr_init(r23653);
        mpfr_init(r23654);
        mpfr_init(r23655);
        mpfr_init_set_str(r23656, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23657);
        mpfr_init(r23658);
        mpfr_init(r23659);
        mpfr_init_set_str(r23660, "0", 10, MPFR_RNDN);
        mpfr_init(r23661);
}

double f_fm(double alpha, double beta, double i) {
        mpfr_set_d(r23635, alpha, MPFR_RNDN);
        mpfr_set_d(r23636, beta, MPFR_RNDN);
        mpfr_add(r23637, r23635, r23636, MPFR_RNDN);
        ;
        mpfr_set_si(r23639, mpfr_cmp(r23637, r23638) <= 0, MPFR_RNDN);
        mpfr_set_d(r23640, i, MPFR_RNDN);
        mpfr_add(r23641, r23640, r23636, MPFR_RNDN);
        mpfr_add(r23642, r23635, r23641, MPFR_RNDN);
        ;
        mpfr_mul(r23644, r23640, r23643, MPFR_RNDN);
        mpfr_add(r23645, r23637, r23644, MPFR_RNDN);
        mpfr_div(r23646, r23645, r23640, MPFR_RNDN);
        mpfr_div(r23647, r23642, r23646, MPFR_RNDN);
        mpfr_mul(r23648, r23636, r23635, MPFR_RNDN);
        mpfr_add(r23649, r23637, r23640, MPFR_RNDN);
        mpfr_mul(r23650, r23640, r23649, MPFR_RNDN);
        mpfr_add(r23651, r23648, r23650, MPFR_RNDN);
        mpfr_mul(r23652, r23643, r23640, MPFR_RNDN);
        mpfr_add(r23653, r23637, r23652, MPFR_RNDN);
        mpfr_div(r23654, r23651, r23653, MPFR_RNDN);
        mpfr_mul(r23655, r23653, r23653, MPFR_RNDN);
        ;
        mpfr_sub(r23657, r23655, r23656, MPFR_RNDN);
        mpfr_div(r23658, r23654, r23657, MPFR_RNDN);
        mpfr_mul(r23659, r23647, r23658, MPFR_RNDN);
        ;
        if (mpfr_get_si(r23639, MPFR_RNDN)) { mpfr_set(r23661, r23659, MPFR_RNDN); } else { mpfr_set(r23661, r23660, MPFR_RNDN); };
        return mpfr_get_d(r23661, MPFR_RNDN);
}

static mpfr_t r23662, r23663, r23664, r23665, r23666, r23667, r23668, r23669, r23670, r23671, r23672, r23673, r23674, r23675, r23676, r23677, r23678, r23679, r23680, r23681, r23682, r23683, r23684, r23685, r23686, r23687, r23688;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r23662);
        mpfr_init(r23663);
        mpfr_init(r23664);
        mpfr_init_set_str(r23665, "2.367490657871795e+153", 10, MPFR_RNDN);
        mpfr_init(r23666);
        mpfr_init(r23667);
        mpfr_init(r23668);
        mpfr_init(r23669);
        mpfr_init_set_str(r23670, "2", 10, MPFR_RNDN);
        mpfr_init(r23671);
        mpfr_init(r23672);
        mpfr_init(r23673);
        mpfr_init(r23674);
        mpfr_init(r23675);
        mpfr_init(r23676);
        mpfr_init(r23677);
        mpfr_init(r23678);
        mpfr_init(r23679);
        mpfr_init(r23680);
        mpfr_init(r23681);
        mpfr_init(r23682);
        mpfr_init_set_str(r23683, "1.0", 10, MPFR_RNDN);
        mpfr_init(r23684);
        mpfr_init(r23685);
        mpfr_init(r23686);
        mpfr_init_set_str(r23687, "0", 10, MPFR_RNDN);
        mpfr_init(r23688);
}

double f_dm(double alpha, double beta, double i) {
        mpfr_set_d(r23662, alpha, MPFR_RNDN);
        mpfr_set_d(r23663, beta, MPFR_RNDN);
        mpfr_add(r23664, r23662, r23663, MPFR_RNDN);
        ;
        mpfr_set_si(r23666, mpfr_cmp(r23664, r23665) <= 0, MPFR_RNDN);
        mpfr_set_d(r23667, i, MPFR_RNDN);
        mpfr_add(r23668, r23667, r23663, MPFR_RNDN);
        mpfr_add(r23669, r23662, r23668, MPFR_RNDN);
        ;
        mpfr_mul(r23671, r23667, r23670, MPFR_RNDN);
        mpfr_add(r23672, r23664, r23671, MPFR_RNDN);
        mpfr_div(r23673, r23672, r23667, MPFR_RNDN);
        mpfr_div(r23674, r23669, r23673, MPFR_RNDN);
        mpfr_mul(r23675, r23663, r23662, MPFR_RNDN);
        mpfr_add(r23676, r23664, r23667, MPFR_RNDN);
        mpfr_mul(r23677, r23667, r23676, MPFR_RNDN);
        mpfr_add(r23678, r23675, r23677, MPFR_RNDN);
        mpfr_mul(r23679, r23670, r23667, MPFR_RNDN);
        mpfr_add(r23680, r23664, r23679, MPFR_RNDN);
        mpfr_div(r23681, r23678, r23680, MPFR_RNDN);
        mpfr_mul(r23682, r23680, r23680, MPFR_RNDN);
        ;
        mpfr_sub(r23684, r23682, r23683, MPFR_RNDN);
        mpfr_div(r23685, r23681, r23684, MPFR_RNDN);
        mpfr_mul(r23686, r23674, r23685, MPFR_RNDN);
        ;
        if (mpfr_get_si(r23666, MPFR_RNDN)) { mpfr_set(r23688, r23686, MPFR_RNDN); } else { mpfr_set(r23688, r23687, MPFR_RNDN); };
        return mpfr_get_d(r23688, MPFR_RNDN);
}

