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

char *name = "quadp (p42, positive)";

double f_if(float a, float b, float c) {
        float r26010 = b;
        float r26011 = -r26010;
        float r26012 = r26010 * r26010;
        float r26013 = 4;
        float r26014 = a;
        float r26015 = c;
        float r26016 = r26014 * r26015;
        float r26017 = r26013 * r26016;
        float r26018 = r26012 - r26017;
        float r26019 = sqrt(r26018);
        float r26020 = r26011 + r26019;
        float r26021 = 2;
        float r26022 = r26021 * r26014;
        float r26023 = r26020 / r26022;
        return r26023;
}

double f_id(double a, double b, double c) {
        double r26024 = b;
        double r26025 = -r26024;
        double r26026 = r26024 * r26024;
        double r26027 = 4;
        double r26028 = a;
        double r26029 = c;
        double r26030 = r26028 * r26029;
        double r26031 = r26027 * r26030;
        double r26032 = r26026 - r26031;
        double r26033 = sqrt(r26032);
        double r26034 = r26025 + r26033;
        double r26035 = 2;
        double r26036 = r26035 * r26028;
        double r26037 = r26034 / r26036;
        return r26037;
}


double f_of(float a, float b, float c) {
        float r26038 = b;
        float r26039 = -1.3026234282048264e+154;
        bool r26040 = r26038 <= r26039;
        float r26041 = c;
        float r26042 = r26041 / r26038;
        float r26043 = a;
        float r26044 = r26038 / r26043;
        float r26045 = r26042 - r26044;
        float r26046 = 2.9009672808283745e-123;
        bool r26047 = r26038 <= r26046;
        float r26048 = -r26038;
        float r26049 = r26038 * r26038;
        float r26050 = 4;
        float r26051 = r26041 * r26043;
        float r26052 = r26050 * r26051;
        float r26053 = r26049 - r26052;
        float r26054 = sqrt(r26053);
        float r26055 = r26048 + r26054;
        float r26056 = 2;
        float r26057 = r26056 * r26043;
        float r26058 = r26055 / r26057;
        float r26059 = 7.182266640601894e+134;
        bool r26060 = r26038 <= r26059;
        float r26061 = -r26041;
        float r26062 = r26054 + r26038;
        float r26063 = cbrt(r26062);
        float r26064 = r26061 / r26063;
        float r26065 = r26041 * r26050;
        float r26066 = r26043 * r26065;
        float r26067 = r26049 - r26066;
        float r26068 = sqrt(r26067);
        float r26069 = r26068 + r26038;
        float r26070 = cbrt(r26069);
        float r26071 = r26070 * r26070;
        float r26072 = r26050 / r26071;
        float r26073 = r26072 / r26056;
        float r26074 = r26064 * r26073;
        float r26075 = r26061 / r26038;
        float r26076 = r26060 ? r26074 : r26075;
        float r26077 = r26047 ? r26058 : r26076;
        float r26078 = r26040 ? r26045 : r26077;
        return r26078;
}

double f_od(double a, double b, double c) {
        double r26079 = b;
        double r26080 = -1.3026234282048264e+154;
        bool r26081 = r26079 <= r26080;
        double r26082 = c;
        double r26083 = r26082 / r26079;
        double r26084 = a;
        double r26085 = r26079 / r26084;
        double r26086 = r26083 - r26085;
        double r26087 = 2.9009672808283745e-123;
        bool r26088 = r26079 <= r26087;
        double r26089 = -r26079;
        double r26090 = r26079 * r26079;
        double r26091 = 4;
        double r26092 = r26082 * r26084;
        double r26093 = r26091 * r26092;
        double r26094 = r26090 - r26093;
        double r26095 = sqrt(r26094);
        double r26096 = r26089 + r26095;
        double r26097 = 2;
        double r26098 = r26097 * r26084;
        double r26099 = r26096 / r26098;
        double r26100 = 7.182266640601894e+134;
        bool r26101 = r26079 <= r26100;
        double r26102 = -r26082;
        double r26103 = r26095 + r26079;
        double r26104 = cbrt(r26103);
        double r26105 = r26102 / r26104;
        double r26106 = r26082 * r26091;
        double r26107 = r26084 * r26106;
        double r26108 = r26090 - r26107;
        double r26109 = sqrt(r26108);
        double r26110 = r26109 + r26079;
        double r26111 = cbrt(r26110);
        double r26112 = r26111 * r26111;
        double r26113 = r26091 / r26112;
        double r26114 = r26113 / r26097;
        double r26115 = r26105 * r26114;
        double r26116 = r26102 / r26079;
        double r26117 = r26101 ? r26115 : r26116;
        double r26118 = r26088 ? r26099 : r26117;
        double r26119 = r26081 ? r26086 : r26118;
        return r26119;
}

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 r26120, r26121, r26122, r26123, r26124, r26125, r26126, r26127, r26128, r26129, r26130, r26131, r26132, r26133;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3408);
        mpfr_init(r26120);
        mpfr_init(r26121);
        mpfr_init(r26122);
        mpfr_init_set_str(r26123, "4", 10, MPFR_RNDN);
        mpfr_init(r26124);
        mpfr_init(r26125);
        mpfr_init(r26126);
        mpfr_init(r26127);
        mpfr_init(r26128);
        mpfr_init(r26129);
        mpfr_init(r26130);
        mpfr_init_set_str(r26131, "2", 10, MPFR_RNDN);
        mpfr_init(r26132);
        mpfr_init(r26133);
}

double f_im(double a, double b, double c) {
        mpfr_set_d(r26120, b, MPFR_RNDN);
        mpfr_neg(r26121, r26120, MPFR_RNDN);
        mpfr_mul(r26122, r26120, r26120, MPFR_RNDN);
        ;
        mpfr_set_d(r26124, a, MPFR_RNDN);
        mpfr_set_d(r26125, c, MPFR_RNDN);
        mpfr_mul(r26126, r26124, r26125, MPFR_RNDN);
        mpfr_mul(r26127, r26123, r26126, MPFR_RNDN);
        mpfr_sub(r26128, r26122, r26127, MPFR_RNDN);
        mpfr_sqrt(r26129, r26128, MPFR_RNDN);
        mpfr_add(r26130, r26121, r26129, MPFR_RNDN);
        ;
        mpfr_mul(r26132, r26131, r26124, MPFR_RNDN);
        mpfr_div(r26133, r26130, r26132, MPFR_RNDN);
        return mpfr_get_d(r26133, MPFR_RNDN);
}

static mpfr_t r26134, r26135, r26136, r26137, r26138, r26139, r26140, r26141, r26142, r26143, r26144, r26145, r26146, r26147, r26148, r26149, r26150, r26151, r26152, r26153, r26154, r26155, r26156, r26157, r26158, r26159, r26160, r26161, r26162, r26163, r26164, r26165, r26166, r26167, r26168, r26169, r26170, r26171, r26172, r26173, r26174;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3408);
        mpfr_init(r26134);
        mpfr_init_set_str(r26135, "-1.3026234282048264e+154", 10, MPFR_RNDN);
        mpfr_init(r26136);
        mpfr_init(r26137);
        mpfr_init(r26138);
        mpfr_init(r26139);
        mpfr_init(r26140);
        mpfr_init(r26141);
        mpfr_init_set_str(r26142, "2.9009672808283745e-123", 10, MPFR_RNDN);
        mpfr_init(r26143);
        mpfr_init(r26144);
        mpfr_init(r26145);
        mpfr_init_set_str(r26146, "4", 10, MPFR_RNDN);
        mpfr_init(r26147);
        mpfr_init(r26148);
        mpfr_init(r26149);
        mpfr_init(r26150);
        mpfr_init(r26151);
        mpfr_init_set_str(r26152, "2", 10, MPFR_RNDN);
        mpfr_init(r26153);
        mpfr_init(r26154);
        mpfr_init_set_str(r26155, "7.182266640601894e+134", 10, MPFR_RNDN);
        mpfr_init(r26156);
        mpfr_init(r26157);
        mpfr_init(r26158);
        mpfr_init(r26159);
        mpfr_init(r26160);
        mpfr_init(r26161);
        mpfr_init(r26162);
        mpfr_init(r26163);
        mpfr_init(r26164);
        mpfr_init(r26165);
        mpfr_init(r26166);
        mpfr_init(r26167);
        mpfr_init(r26168);
        mpfr_init(r26169);
        mpfr_init(r26170);
        mpfr_init(r26171);
        mpfr_init(r26172);
        mpfr_init(r26173);
        mpfr_init(r26174);
}

double f_fm(double a, double b, double c) {
        mpfr_set_d(r26134, b, MPFR_RNDN);
        ;
        mpfr_set_si(r26136, mpfr_cmp(r26134, r26135) <= 0, MPFR_RNDN);
        mpfr_set_d(r26137, c, MPFR_RNDN);
        mpfr_div(r26138, r26137, r26134, MPFR_RNDN);
        mpfr_set_d(r26139, a, MPFR_RNDN);
        mpfr_div(r26140, r26134, r26139, MPFR_RNDN);
        mpfr_sub(r26141, r26138, r26140, MPFR_RNDN);
        ;
        mpfr_set_si(r26143, mpfr_cmp(r26134, r26142) <= 0, MPFR_RNDN);
        mpfr_neg(r26144, r26134, MPFR_RNDN);
        mpfr_mul(r26145, r26134, r26134, MPFR_RNDN);
        ;
        mpfr_mul(r26147, r26137, r26139, MPFR_RNDN);
        mpfr_mul(r26148, r26146, r26147, MPFR_RNDN);
        mpfr_sub(r26149, r26145, r26148, MPFR_RNDN);
        mpfr_sqrt(r26150, r26149, MPFR_RNDN);
        mpfr_add(r26151, r26144, r26150, MPFR_RNDN);
        ;
        mpfr_mul(r26153, r26152, r26139, MPFR_RNDN);
        mpfr_div(r26154, r26151, r26153, MPFR_RNDN);
        ;
        mpfr_set_si(r26156, mpfr_cmp(r26134, r26155) <= 0, MPFR_RNDN);
        mpfr_neg(r26157, r26137, MPFR_RNDN);
        mpfr_add(r26158, r26150, r26134, MPFR_RNDN);
        mpfr_cbrt(r26159, r26158, MPFR_RNDN);
        mpfr_div(r26160, r26157, r26159, MPFR_RNDN);
        mpfr_mul(r26161, r26137, r26146, MPFR_RNDN);
        mpfr_mul(r26162, r26139, r26161, MPFR_RNDN);
        mpfr_sub(r26163, r26145, r26162, MPFR_RNDN);
        mpfr_sqrt(r26164, r26163, MPFR_RNDN);
        mpfr_add(r26165, r26164, r26134, MPFR_RNDN);
        mpfr_cbrt(r26166, r26165, MPFR_RNDN);
        mpfr_mul(r26167, r26166, r26166, MPFR_RNDN);
        mpfr_div(r26168, r26146, r26167, MPFR_RNDN);
        mpfr_div(r26169, r26168, r26152, MPFR_RNDN);
        mpfr_mul(r26170, r26160, r26169, MPFR_RNDN);
        mpfr_div(r26171, r26157, r26134, MPFR_RNDN);
        if (mpfr_get_si(r26156, MPFR_RNDN)) { mpfr_set(r26172, r26170, MPFR_RNDN); } else { mpfr_set(r26172, r26171, MPFR_RNDN); };
        if (mpfr_get_si(r26143, MPFR_RNDN)) { mpfr_set(r26173, r26154, MPFR_RNDN); } else { mpfr_set(r26173, r26172, MPFR_RNDN); };
        if (mpfr_get_si(r26136, MPFR_RNDN)) { mpfr_set(r26174, r26141, MPFR_RNDN); } else { mpfr_set(r26174, r26173, MPFR_RNDN); };
        return mpfr_get_d(r26174, MPFR_RNDN);
}

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

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3408);
        mpfr_init(r26175);
        mpfr_init_set_str(r26176, "-1.3026234282048264e+154", 10, MPFR_RNDN);
        mpfr_init(r26177);
        mpfr_init(r26178);
        mpfr_init(r26179);
        mpfr_init(r26180);
        mpfr_init(r26181);
        mpfr_init(r26182);
        mpfr_init_set_str(r26183, "2.9009672808283745e-123", 10, MPFR_RNDN);
        mpfr_init(r26184);
        mpfr_init(r26185);
        mpfr_init(r26186);
        mpfr_init_set_str(r26187, "4", 10, MPFR_RNDN);
        mpfr_init(r26188);
        mpfr_init(r26189);
        mpfr_init(r26190);
        mpfr_init(r26191);
        mpfr_init(r26192);
        mpfr_init_set_str(r26193, "2", 10, MPFR_RNDN);
        mpfr_init(r26194);
        mpfr_init(r26195);
        mpfr_init_set_str(r26196, "7.182266640601894e+134", 10, MPFR_RNDN);
        mpfr_init(r26197);
        mpfr_init(r26198);
        mpfr_init(r26199);
        mpfr_init(r26200);
        mpfr_init(r26201);
        mpfr_init(r26202);
        mpfr_init(r26203);
        mpfr_init(r26204);
        mpfr_init(r26205);
        mpfr_init(r26206);
        mpfr_init(r26207);
        mpfr_init(r26208);
        mpfr_init(r26209);
        mpfr_init(r26210);
        mpfr_init(r26211);
        mpfr_init(r26212);
        mpfr_init(r26213);
        mpfr_init(r26214);
        mpfr_init(r26215);
}

double f_dm(double a, double b, double c) {
        mpfr_set_d(r26175, b, MPFR_RNDN);
        ;
        mpfr_set_si(r26177, mpfr_cmp(r26175, r26176) <= 0, MPFR_RNDN);
        mpfr_set_d(r26178, c, MPFR_RNDN);
        mpfr_div(r26179, r26178, r26175, MPFR_RNDN);
        mpfr_set_d(r26180, a, MPFR_RNDN);
        mpfr_div(r26181, r26175, r26180, MPFR_RNDN);
        mpfr_sub(r26182, r26179, r26181, MPFR_RNDN);
        ;
        mpfr_set_si(r26184, mpfr_cmp(r26175, r26183) <= 0, MPFR_RNDN);
        mpfr_neg(r26185, r26175, MPFR_RNDN);
        mpfr_mul(r26186, r26175, r26175, MPFR_RNDN);
        ;
        mpfr_mul(r26188, r26178, r26180, MPFR_RNDN);
        mpfr_mul(r26189, r26187, r26188, MPFR_RNDN);
        mpfr_sub(r26190, r26186, r26189, MPFR_RNDN);
        mpfr_sqrt(r26191, r26190, MPFR_RNDN);
        mpfr_add(r26192, r26185, r26191, MPFR_RNDN);
        ;
        mpfr_mul(r26194, r26193, r26180, MPFR_RNDN);
        mpfr_div(r26195, r26192, r26194, MPFR_RNDN);
        ;
        mpfr_set_si(r26197, mpfr_cmp(r26175, r26196) <= 0, MPFR_RNDN);
        mpfr_neg(r26198, r26178, MPFR_RNDN);
        mpfr_add(r26199, r26191, r26175, MPFR_RNDN);
        mpfr_cbrt(r26200, r26199, MPFR_RNDN);
        mpfr_div(r26201, r26198, r26200, MPFR_RNDN);
        mpfr_mul(r26202, r26178, r26187, MPFR_RNDN);
        mpfr_mul(r26203, r26180, r26202, MPFR_RNDN);
        mpfr_sub(r26204, r26186, r26203, MPFR_RNDN);
        mpfr_sqrt(r26205, r26204, MPFR_RNDN);
        mpfr_add(r26206, r26205, r26175, MPFR_RNDN);
        mpfr_cbrt(r26207, r26206, MPFR_RNDN);
        mpfr_mul(r26208, r26207, r26207, MPFR_RNDN);
        mpfr_div(r26209, r26187, r26208, MPFR_RNDN);
        mpfr_div(r26210, r26209, r26193, MPFR_RNDN);
        mpfr_mul(r26211, r26201, r26210, MPFR_RNDN);
        mpfr_div(r26212, r26198, r26175, MPFR_RNDN);
        if (mpfr_get_si(r26197, MPFR_RNDN)) { mpfr_set(r26213, r26211, MPFR_RNDN); } else { mpfr_set(r26213, r26212, MPFR_RNDN); };
        if (mpfr_get_si(r26184, MPFR_RNDN)) { mpfr_set(r26214, r26195, MPFR_RNDN); } else { mpfr_set(r26214, r26213, MPFR_RNDN); };
        if (mpfr_get_si(r26177, MPFR_RNDN)) { mpfr_set(r26215, r26182, MPFR_RNDN); } else { mpfr_set(r26215, r26214, MPFR_RNDN); };
        return mpfr_get_d(r26215, MPFR_RNDN);
}

