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

char *name = "2nthrt (problem 3.4.6)";

double f_if(float x, float n) {
        float r25428 = x;
        float r25429 = 1;
        float r25430 = r25428 + r25429;
        float r25431 = n;
        float r25432 = r25429 / r25431;
        float r25433 = pow(r25430, r25432);
        float r25434 = pow(r25428, r25432);
        float r25435 = r25433 - r25434;
        return r25435;
}

double f_id(double x, double n) {
        double r25436 = x;
        double r25437 = 1;
        double r25438 = r25436 + r25437;
        double r25439 = n;
        double r25440 = r25437 / r25439;
        double r25441 = pow(r25438, r25440);
        double r25442 = pow(r25436, r25440);
        double r25443 = r25441 - r25442;
        return r25443;
}


double f_of(float x, float n) {
        float r25444 = x;
        float r25445 = log1p(r25444);
        float r25446 = n;
        float r25447 = r25445 / r25446;
        float r25448 = expm1(r25447);
        float r25449 = 1/2;
        float r25450 = r25449 / r25446;
        float r25451 = r25450 / r25446;
        float r25452 = log(r25444);
        float r25453 = r25452 * r25452;
        float r25454 = r25452 / r25446;
        float r25455 = fma(r25451, r25453, r25454);
        float r25456 = r25448 - r25455;
        float r25457 = -1.4467849716005934e-14;
        bool r25458 = r25456 <= r25457;
        float r25459 = exp(r25447);
        float r25460 = 1;
        float r25461 = r25460 / r25446;
        float r25462 = pow(r25444, r25461);
        float r25463 = r25459 - r25462;
        float r25464 = -3.438816823903856e-301;
        bool r25465 = r25456 <= r25464;
        float r25466 = 2.9491436330909624e-306;
        bool r25467 = r25456 <= r25466;
        float r25468 = r25446 * r25446;
        float r25469 = r25452 / r25468;
        float r25470 = r25469 / r25444;
        float r25471 = r25444 * r25444;
        float r25472 = r25450 / r25471;
        float r25473 = r25444 * r25446;
        float r25474 = r25460 / r25473;
        float r25475 = r25472 - r25474;
        float r25476 = r25470 - r25475;
        float r25477 = r25467 ? r25476 : r25456;
        float r25478 = r25465 ? r25456 : r25477;
        float r25479 = r25458 ? r25463 : r25478;
        return r25479;
}

double f_od(double x, double n) {
        double r25480 = x;
        double r25481 = log1p(r25480);
        double r25482 = n;
        double r25483 = r25481 / r25482;
        double r25484 = expm1(r25483);
        double r25485 = 1/2;
        double r25486 = r25485 / r25482;
        double r25487 = r25486 / r25482;
        double r25488 = log(r25480);
        double r25489 = r25488 * r25488;
        double r25490 = r25488 / r25482;
        double r25491 = fma(r25487, r25489, r25490);
        double r25492 = r25484 - r25491;
        double r25493 = -1.4467849716005934e-14;
        bool r25494 = r25492 <= r25493;
        double r25495 = exp(r25483);
        double r25496 = 1;
        double r25497 = r25496 / r25482;
        double r25498 = pow(r25480, r25497);
        double r25499 = r25495 - r25498;
        double r25500 = -3.438816823903856e-301;
        bool r25501 = r25492 <= r25500;
        double r25502 = 2.9491436330909624e-306;
        bool r25503 = r25492 <= r25502;
        double r25504 = r25482 * r25482;
        double r25505 = r25488 / r25504;
        double r25506 = r25505 / r25480;
        double r25507 = r25480 * r25480;
        double r25508 = r25486 / r25507;
        double r25509 = r25480 * r25482;
        double r25510 = r25496 / r25509;
        double r25511 = r25508 - r25510;
        double r25512 = r25506 - r25511;
        double r25513 = r25503 ? r25512 : r25492;
        double r25514 = r25501 ? r25492 : r25513;
        double r25515 = r25494 ? r25499 : r25514;
        return r25515;
}

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 r25516, r25517, r25518, r25519, r25520, r25521, r25522, r25523;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25516);
        mpfr_init_set_str(r25517, "1", 10, MPFR_RNDN);
        mpfr_init(r25518);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
}

double f_im(double x, double n) {
        mpfr_set_d(r25516, x, MPFR_RNDN);
        ;
        mpfr_add(r25518, r25516, r25517, MPFR_RNDN);
        mpfr_set_d(r25519, n, MPFR_RNDN);
        mpfr_div(r25520, r25517, r25519, MPFR_RNDN);
        mpfr_pow(r25521, r25518, r25520, MPFR_RNDN);
        mpfr_pow(r25522, r25516, r25520, MPFR_RNDN);
        mpfr_sub(r25523, r25521, r25522, MPFR_RNDN);
        return mpfr_get_d(r25523, MPFR_RNDN);
}

static mpfr_t r25524, r25525, r25526, r25527, r25528, r25529, r25530, r25531, r25532, r25533, r25534, r25535, r25536, r25537, r25538, r25539, r25540, r25541, r25542, r25543, r25544, r25545, r25546, r25547, r25548, r25549, r25550, r25551, r25552, r25553, r25554, r25555, r25556, r25557, r25558, r25559;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init_set_str(r25529, "1/2", 10, MPFR_RNDN);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init(r25535);
        mpfr_init(r25536);
        mpfr_init_set_str(r25537, "-1.4467849716005934e-14", 10, MPFR_RNDN);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init_set_str(r25540, "1", 10, MPFR_RNDN);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init_set_str(r25544, "-3.438816823903856e-301", 10, MPFR_RNDN);
        mpfr_init(r25545);
        mpfr_init_set_str(r25546, "2.9491436330909624e-306", 10, MPFR_RNDN);
        mpfr_init(r25547);
        mpfr_init(r25548);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
        mpfr_init(r25552);
        mpfr_init(r25553);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init(r25556);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
}

double f_fm(double x, double n) {
        mpfr_set_d(r25524, x, MPFR_RNDN);
        mpfr_log1p(r25525, r25524, MPFR_RNDN);
        mpfr_set_d(r25526, n, MPFR_RNDN);
        mpfr_div(r25527, r25525, r25526, MPFR_RNDN);
        mpfr_expm1(r25528, r25527, MPFR_RNDN);
        ;
        mpfr_div(r25530, r25529, r25526, MPFR_RNDN);
        mpfr_div(r25531, r25530, r25526, MPFR_RNDN);
        mpfr_log(r25532, r25524, MPFR_RNDN);
        mpfr_mul(r25533, r25532, r25532, MPFR_RNDN);
        mpfr_div(r25534, r25532, r25526, MPFR_RNDN);
        mpfr_fma(r25535, r25531, r25533, r25534, MPFR_RNDN);
        mpfr_sub(r25536, r25528, r25535, MPFR_RNDN);
        ;
        mpfr_set_si(r25538, mpfr_cmp(r25536, r25537) <= 0, MPFR_RNDN);
        mpfr_exp(r25539, r25527, MPFR_RNDN);
        ;
        mpfr_div(r25541, r25540, r25526, MPFR_RNDN);
        mpfr_pow(r25542, r25524, r25541, MPFR_RNDN);
        mpfr_sub(r25543, r25539, r25542, MPFR_RNDN);
        ;
        mpfr_set_si(r25545, mpfr_cmp(r25536, r25544) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25547, mpfr_cmp(r25536, r25546) <= 0, MPFR_RNDN);
        mpfr_mul(r25548, r25526, r25526, MPFR_RNDN);
        mpfr_div(r25549, r25532, r25548, MPFR_RNDN);
        mpfr_div(r25550, r25549, r25524, MPFR_RNDN);
        mpfr_mul(r25551, r25524, r25524, MPFR_RNDN);
        mpfr_div(r25552, r25530, r25551, MPFR_RNDN);
        mpfr_mul(r25553, r25524, r25526, MPFR_RNDN);
        mpfr_div(r25554, r25540, r25553, MPFR_RNDN);
        mpfr_sub(r25555, r25552, r25554, MPFR_RNDN);
        mpfr_sub(r25556, r25550, r25555, MPFR_RNDN);
        if (mpfr_get_si(r25547, MPFR_RNDN)) { mpfr_set(r25557, r25556, MPFR_RNDN); } else { mpfr_set(r25557, r25536, MPFR_RNDN); };
        if (mpfr_get_si(r25545, MPFR_RNDN)) { mpfr_set(r25558, r25536, MPFR_RNDN); } else { mpfr_set(r25558, r25557, MPFR_RNDN); };
        if (mpfr_get_si(r25538, MPFR_RNDN)) { mpfr_set(r25559, r25543, MPFR_RNDN); } else { mpfr_set(r25559, r25558, MPFR_RNDN); };
        return mpfr_get_d(r25559, MPFR_RNDN);
}

static mpfr_t r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568, r25569, r25570, r25571, r25572, r25573, r25574, r25575, r25576, r25577, r25578, r25579, r25580, r25581, r25582, r25583, r25584, r25585, r25586, r25587, r25588, r25589, r25590, r25591, r25592, r25593, r25594, r25595;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25560);
        mpfr_init(r25561);
        mpfr_init(r25562);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init_set_str(r25565, "1/2", 10, MPFR_RNDN);
        mpfr_init(r25566);
        mpfr_init(r25567);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init(r25571);
        mpfr_init(r25572);
        mpfr_init_set_str(r25573, "-1.4467849716005934e-14", 10, MPFR_RNDN);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init_set_str(r25576, "1", 10, MPFR_RNDN);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init(r25579);
        mpfr_init_set_str(r25580, "-3.438816823903856e-301", 10, MPFR_RNDN);
        mpfr_init(r25581);
        mpfr_init_set_str(r25582, "2.9491436330909624e-306", 10, MPFR_RNDN);
        mpfr_init(r25583);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init(r25586);
        mpfr_init(r25587);
        mpfr_init(r25588);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init(r25591);
        mpfr_init(r25592);
        mpfr_init(r25593);
        mpfr_init(r25594);
        mpfr_init(r25595);
}

double f_dm(double x, double n) {
        mpfr_set_d(r25560, x, MPFR_RNDN);
        mpfr_log1p(r25561, r25560, MPFR_RNDN);
        mpfr_set_d(r25562, n, MPFR_RNDN);
        mpfr_div(r25563, r25561, r25562, MPFR_RNDN);
        mpfr_expm1(r25564, r25563, MPFR_RNDN);
        ;
        mpfr_div(r25566, r25565, r25562, MPFR_RNDN);
        mpfr_div(r25567, r25566, r25562, MPFR_RNDN);
        mpfr_log(r25568, r25560, MPFR_RNDN);
        mpfr_mul(r25569, r25568, r25568, MPFR_RNDN);
        mpfr_div(r25570, r25568, r25562, MPFR_RNDN);
        mpfr_fma(r25571, r25567, r25569, r25570, MPFR_RNDN);
        mpfr_sub(r25572, r25564, r25571, MPFR_RNDN);
        ;
        mpfr_set_si(r25574, mpfr_cmp(r25572, r25573) <= 0, MPFR_RNDN);
        mpfr_exp(r25575, r25563, MPFR_RNDN);
        ;
        mpfr_div(r25577, r25576, r25562, MPFR_RNDN);
        mpfr_pow(r25578, r25560, r25577, MPFR_RNDN);
        mpfr_sub(r25579, r25575, r25578, MPFR_RNDN);
        ;
        mpfr_set_si(r25581, mpfr_cmp(r25572, r25580) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25583, mpfr_cmp(r25572, r25582) <= 0, MPFR_RNDN);
        mpfr_mul(r25584, r25562, r25562, MPFR_RNDN);
        mpfr_div(r25585, r25568, r25584, MPFR_RNDN);
        mpfr_div(r25586, r25585, r25560, MPFR_RNDN);
        mpfr_mul(r25587, r25560, r25560, MPFR_RNDN);
        mpfr_div(r25588, r25566, r25587, MPFR_RNDN);
        mpfr_mul(r25589, r25560, r25562, MPFR_RNDN);
        mpfr_div(r25590, r25576, r25589, MPFR_RNDN);
        mpfr_sub(r25591, r25588, r25590, MPFR_RNDN);
        mpfr_sub(r25592, r25586, r25591, MPFR_RNDN);
        if (mpfr_get_si(r25583, MPFR_RNDN)) { mpfr_set(r25593, r25592, MPFR_RNDN); } else { mpfr_set(r25593, r25572, MPFR_RNDN); };
        if (mpfr_get_si(r25581, MPFR_RNDN)) { mpfr_set(r25594, r25572, MPFR_RNDN); } else { mpfr_set(r25594, r25593, MPFR_RNDN); };
        if (mpfr_get_si(r25574, MPFR_RNDN)) { mpfr_set(r25595, r25579, MPFR_RNDN); } else { mpfr_set(r25595, r25594, MPFR_RNDN); };
        return mpfr_get_d(r25595, MPFR_RNDN);
}

