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

char *name = "powComplex, imaginary part";

double f_if(float x_re, float x_im, float y_re, float y_im) {
        float r24067 = x_re;
        float r24068 = r24067 * r24067;
        float r24069 = x_im;
        float r24070 = r24069 * r24069;
        float r24071 = r24068 + r24070;
        float r24072 = sqrt(r24071);
        float r24073 = log(r24072);
        float r24074 = y_re;
        float r24075 = r24073 * r24074;
        float r24076 = atan2(r24069, r24067);
        float r24077 = y_im;
        float r24078 = r24076 * r24077;
        float r24079 = r24075 - r24078;
        float r24080 = exp(r24079);
        float r24081 = r24073 * r24077;
        float r24082 = r24076 * r24074;
        float r24083 = r24081 + r24082;
        float r24084 = sin(r24083);
        float r24085 = r24080 * r24084;
        return r24085;
}

double f_id(double x_re, double x_im, double y_re, double y_im) {
        double r24086 = x_re;
        double r24087 = r24086 * r24086;
        double r24088 = x_im;
        double r24089 = r24088 * r24088;
        double r24090 = r24087 + r24089;
        double r24091 = sqrt(r24090);
        double r24092 = log(r24091);
        double r24093 = y_re;
        double r24094 = r24092 * r24093;
        double r24095 = atan2(r24088, r24086);
        double r24096 = y_im;
        double r24097 = r24095 * r24096;
        double r24098 = r24094 - r24097;
        double r24099 = exp(r24098);
        double r24100 = r24092 * r24096;
        double r24101 = r24095 * r24093;
        double r24102 = r24100 + r24101;
        double r24103 = sin(r24102);
        double r24104 = r24099 * r24103;
        return r24104;
}


double f_of(float x_re, float x_im, float y_re, float y_im) {
        float r24105 = x_im;
        float r24106 = x_re;
        float r24107 = hypot(r24105, r24106);
        float r24108 = log(r24107);
        float r24109 = y_im;
        float r24110 = atan2(r24105, r24106);
        float r24111 = y_re;
        float r24112 = r24110 * r24111;
        float r24113 = fma(r24108, r24109, r24112);
        float r24114 = sin(r24113);
        float r24115 = r24110 * r24109;
        float r24116 = 1;
        float r24117 = 1/2;
        float r24118 = 2;
        float r24119 = pow(r24110, r24118);
        float r24120 = pow(r24109, r24118);
        float r24121 = r24119 * r24120;
        float r24122 = r24117 * r24121;
        float r24123 = r24116 + r24122;
        float r24124 = r24115 + r24123;
        float r24125 = pow(r24107, r24111);
        float r24126 = r24124 / r24125;
        float r24127 = r24114 / r24126;
        float r24128 = -1.6713205803800765e-300;
        bool r24129 = r24127 <= r24128;
        float r24130 = cbrt(r24113);
        float r24131 = r24130 * r24130;
        float r24132 = cbrt(r24110);
        float r24133 = r24132 * r24132;
        float r24134 = r24132 * r24111;
        float r24135 = r24133 * r24134;
        float r24136 = fma(r24108, r24109, r24135);
        float r24137 = cbrt(r24136);
        float r24138 = r24131 * r24137;
        float r24139 = sin(r24138);
        float r24140 = r24109 * r24110;
        float r24141 = exp(r24140);
        float r24142 = r24141 / r24125;
        float r24143 = r24139 / r24142;
        float r24144 = 3.251676678165954e-290;
        bool r24145 = r24127 <= r24144;
        float r24146 = r24145 ? r24127 : r24143;
        float r24147 = r24129 ? r24143 : r24146;
        return r24147;
}

double f_od(double x_re, double x_im, double y_re, double y_im) {
        double r24148 = x_im;
        double r24149 = x_re;
        double r24150 = hypot(r24148, r24149);
        double r24151 = log(r24150);
        double r24152 = y_im;
        double r24153 = atan2(r24148, r24149);
        double r24154 = y_re;
        double r24155 = r24153 * r24154;
        double r24156 = fma(r24151, r24152, r24155);
        double r24157 = sin(r24156);
        double r24158 = r24153 * r24152;
        double r24159 = 1;
        double r24160 = 1/2;
        double r24161 = 2;
        double r24162 = pow(r24153, r24161);
        double r24163 = pow(r24152, r24161);
        double r24164 = r24162 * r24163;
        double r24165 = r24160 * r24164;
        double r24166 = r24159 + r24165;
        double r24167 = r24158 + r24166;
        double r24168 = pow(r24150, r24154);
        double r24169 = r24167 / r24168;
        double r24170 = r24157 / r24169;
        double r24171 = -1.6713205803800765e-300;
        bool r24172 = r24170 <= r24171;
        double r24173 = cbrt(r24156);
        double r24174 = r24173 * r24173;
        double r24175 = cbrt(r24153);
        double r24176 = r24175 * r24175;
        double r24177 = r24175 * r24154;
        double r24178 = r24176 * r24177;
        double r24179 = fma(r24151, r24152, r24178);
        double r24180 = cbrt(r24179);
        double r24181 = r24174 * r24180;
        double r24182 = sin(r24181);
        double r24183 = r24152 * r24153;
        double r24184 = exp(r24183);
        double r24185 = r24184 / r24168;
        double r24186 = r24182 / r24185;
        double r24187 = 3.251676678165954e-290;
        bool r24188 = r24170 <= r24187;
        double r24189 = r24188 ? r24170 : r24186;
        double r24190 = r24172 ? r24186 : r24189;
        return r24190;
}

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 r24191, r24192, r24193, r24194, r24195, r24196, r24197, r24198, r24199, r24200, r24201, r24202, r24203, r24204, r24205, r24206, r24207, r24208, r24209;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(2128);
        mpfr_init(r24191);
        mpfr_init(r24192);
        mpfr_init(r24193);
        mpfr_init(r24194);
        mpfr_init(r24195);
        mpfr_init(r24196);
        mpfr_init(r24197);
        mpfr_init(r24198);
        mpfr_init(r24199);
        mpfr_init(r24200);
        mpfr_init(r24201);
        mpfr_init(r24202);
        mpfr_init(r24203);
        mpfr_init(r24204);
        mpfr_init(r24205);
        mpfr_init(r24206);
        mpfr_init(r24207);
        mpfr_init(r24208);
        mpfr_init(r24209);
}

double f_im(double x_re, double x_im, double y_re, double y_im) {
        mpfr_set_d(r24191, x_re, MPFR_RNDN);
        mpfr_mul(r24192, r24191, r24191, MPFR_RNDN);
        mpfr_set_d(r24193, x_im, MPFR_RNDN);
        mpfr_mul(r24194, r24193, r24193, MPFR_RNDN);
        mpfr_add(r24195, r24192, r24194, MPFR_RNDN);
        mpfr_sqrt(r24196, r24195, MPFR_RNDN);
        mpfr_log(r24197, r24196, MPFR_RNDN);
        mpfr_set_d(r24198, y_re, MPFR_RNDN);
        mpfr_mul(r24199, r24197, r24198, MPFR_RNDN);
        mpfr_atan2(r24200, r24193, r24191, MPFR_RNDN);
        mpfr_set_d(r24201, y_im, MPFR_RNDN);
        mpfr_mul(r24202, r24200, r24201, MPFR_RNDN);
        mpfr_sub(r24203, r24199, r24202, MPFR_RNDN);
        mpfr_exp(r24204, r24203, MPFR_RNDN);
        mpfr_mul(r24205, r24197, r24201, MPFR_RNDN);
        mpfr_mul(r24206, r24200, r24198, MPFR_RNDN);
        mpfr_add(r24207, r24205, r24206, MPFR_RNDN);
        mpfr_sin(r24208, r24207, MPFR_RNDN);
        mpfr_mul(r24209, r24204, r24208, MPFR_RNDN);
        return mpfr_get_d(r24209, MPFR_RNDN);
}

static mpfr_t r24210, r24211, r24212, r24213, r24214, r24215, r24216, r24217, r24218, r24219, r24220, r24221, r24222, r24223, r24224, r24225, r24226, r24227, r24228, r24229, r24230, r24231, r24232, r24233, r24234, r24235, r24236, r24237, r24238, r24239, r24240, r24241, r24242, r24243, r24244, r24245, r24246, r24247, r24248, r24249, r24250, r24251, r24252;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(2128);
        mpfr_init(r24210);
        mpfr_init(r24211);
        mpfr_init(r24212);
        mpfr_init(r24213);
        mpfr_init(r24214);
        mpfr_init(r24215);
        mpfr_init(r24216);
        mpfr_init(r24217);
        mpfr_init(r24218);
        mpfr_init(r24219);
        mpfr_init(r24220);
        mpfr_init_set_str(r24221, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r24222, "1/2", 10, MPFR_RNDN);
        mpfr_init_set_str(r24223, "2", 10, MPFR_RNDN);
        mpfr_init(r24224);
        mpfr_init(r24225);
        mpfr_init(r24226);
        mpfr_init(r24227);
        mpfr_init(r24228);
        mpfr_init(r24229);
        mpfr_init(r24230);
        mpfr_init(r24231);
        mpfr_init(r24232);
        mpfr_init_set_str(r24233, "-1.6713205803800765e-300", 10, MPFR_RNDN);
        mpfr_init(r24234);
        mpfr_init(r24235);
        mpfr_init(r24236);
        mpfr_init(r24237);
        mpfr_init(r24238);
        mpfr_init(r24239);
        mpfr_init(r24240);
        mpfr_init(r24241);
        mpfr_init(r24242);
        mpfr_init(r24243);
        mpfr_init(r24244);
        mpfr_init(r24245);
        mpfr_init(r24246);
        mpfr_init(r24247);
        mpfr_init(r24248);
        mpfr_init_set_str(r24249, "3.251676678165954e-290", 10, MPFR_RNDN);
        mpfr_init(r24250);
        mpfr_init(r24251);
        mpfr_init(r24252);
}

double f_fm(double x_re, double x_im, double y_re, double y_im) {
        mpfr_set_d(r24210, x_im, MPFR_RNDN);
        mpfr_set_d(r24211, x_re, MPFR_RNDN);
        mpfr_hypot(r24212, r24210, r24211, MPFR_RNDN);
        mpfr_log(r24213, r24212, MPFR_RNDN);
        mpfr_set_d(r24214, y_im, MPFR_RNDN);
        mpfr_atan2(r24215, r24210, r24211, MPFR_RNDN);
        mpfr_set_d(r24216, y_re, MPFR_RNDN);
        mpfr_mul(r24217, r24215, r24216, MPFR_RNDN);
        mpfr_fma(r24218, r24213, r24214, r24217, MPFR_RNDN);
        mpfr_sin(r24219, r24218, MPFR_RNDN);
        mpfr_mul(r24220, r24215, r24214, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_pow(r24224, r24215, r24223, MPFR_RNDN);
        mpfr_pow(r24225, r24214, r24223, MPFR_RNDN);
        mpfr_mul(r24226, r24224, r24225, MPFR_RNDN);
        mpfr_mul(r24227, r24222, r24226, MPFR_RNDN);
        mpfr_add(r24228, r24221, r24227, MPFR_RNDN);
        mpfr_add(r24229, r24220, r24228, MPFR_RNDN);
        mpfr_pow(r24230, r24212, r24216, MPFR_RNDN);
        mpfr_div(r24231, r24229, r24230, MPFR_RNDN);
        mpfr_div(r24232, r24219, r24231, MPFR_RNDN);
        ;
        mpfr_set_si(r24234, mpfr_cmp(r24232, r24233) <= 0, MPFR_RNDN);
        mpfr_cbrt(r24235, r24218, MPFR_RNDN);
        mpfr_mul(r24236, r24235, r24235, MPFR_RNDN);
        mpfr_cbrt(r24237, r24215, MPFR_RNDN);
        mpfr_mul(r24238, r24237, r24237, MPFR_RNDN);
        mpfr_mul(r24239, r24237, r24216, MPFR_RNDN);
        mpfr_mul(r24240, r24238, r24239, MPFR_RNDN);
        mpfr_fma(r24241, r24213, r24214, r24240, MPFR_RNDN);
        mpfr_cbrt(r24242, r24241, MPFR_RNDN);
        mpfr_mul(r24243, r24236, r24242, MPFR_RNDN);
        mpfr_sin(r24244, r24243, MPFR_RNDN);
        mpfr_mul(r24245, r24214, r24215, MPFR_RNDN);
        mpfr_exp(r24246, r24245, MPFR_RNDN);
        mpfr_div(r24247, r24246, r24230, MPFR_RNDN);
        mpfr_div(r24248, r24244, r24247, MPFR_RNDN);
        ;
        mpfr_set_si(r24250, mpfr_cmp(r24232, r24249) <= 0, MPFR_RNDN);
        if (mpfr_get_si(r24250, MPFR_RNDN)) { mpfr_set(r24251, r24232, MPFR_RNDN); } else { mpfr_set(r24251, r24248, MPFR_RNDN); };
        if (mpfr_get_si(r24234, MPFR_RNDN)) { mpfr_set(r24252, r24248, MPFR_RNDN); } else { mpfr_set(r24252, r24251, MPFR_RNDN); };
        return mpfr_get_d(r24252, MPFR_RNDN);
}

static mpfr_t r24253, r24254, r24255, r24256, r24257, r24258, r24259, r24260, r24261, r24262, r24263, r24264, r24265, r24266, r24267, r24268, r24269, r24270, r24271, r24272, r24273, r24274, r24275, r24276, r24277, r24278, r24279, r24280, r24281, r24282, r24283, r24284, r24285, r24286, r24287, r24288, r24289, r24290, r24291, r24292, r24293, r24294, r24295;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(2128);
        mpfr_init(r24253);
        mpfr_init(r24254);
        mpfr_init(r24255);
        mpfr_init(r24256);
        mpfr_init(r24257);
        mpfr_init(r24258);
        mpfr_init(r24259);
        mpfr_init(r24260);
        mpfr_init(r24261);
        mpfr_init(r24262);
        mpfr_init(r24263);
        mpfr_init_set_str(r24264, "1", 10, MPFR_RNDN);
        mpfr_init_set_str(r24265, "1/2", 10, MPFR_RNDN);
        mpfr_init_set_str(r24266, "2", 10, MPFR_RNDN);
        mpfr_init(r24267);
        mpfr_init(r24268);
        mpfr_init(r24269);
        mpfr_init(r24270);
        mpfr_init(r24271);
        mpfr_init(r24272);
        mpfr_init(r24273);
        mpfr_init(r24274);
        mpfr_init(r24275);
        mpfr_init_set_str(r24276, "-1.6713205803800765e-300", 10, MPFR_RNDN);
        mpfr_init(r24277);
        mpfr_init(r24278);
        mpfr_init(r24279);
        mpfr_init(r24280);
        mpfr_init(r24281);
        mpfr_init(r24282);
        mpfr_init(r24283);
        mpfr_init(r24284);
        mpfr_init(r24285);
        mpfr_init(r24286);
        mpfr_init(r24287);
        mpfr_init(r24288);
        mpfr_init(r24289);
        mpfr_init(r24290);
        mpfr_init(r24291);
        mpfr_init_set_str(r24292, "3.251676678165954e-290", 10, MPFR_RNDN);
        mpfr_init(r24293);
        mpfr_init(r24294);
        mpfr_init(r24295);
}

double f_dm(double x_re, double x_im, double y_re, double y_im) {
        mpfr_set_d(r24253, x_im, MPFR_RNDN);
        mpfr_set_d(r24254, x_re, MPFR_RNDN);
        mpfr_hypot(r24255, r24253, r24254, MPFR_RNDN);
        mpfr_log(r24256, r24255, MPFR_RNDN);
        mpfr_set_d(r24257, y_im, MPFR_RNDN);
        mpfr_atan2(r24258, r24253, r24254, MPFR_RNDN);
        mpfr_set_d(r24259, y_re, MPFR_RNDN);
        mpfr_mul(r24260, r24258, r24259, MPFR_RNDN);
        mpfr_fma(r24261, r24256, r24257, r24260, MPFR_RNDN);
        mpfr_sin(r24262, r24261, MPFR_RNDN);
        mpfr_mul(r24263, r24258, r24257, MPFR_RNDN);
        ;
        ;
        ;
        mpfr_pow(r24267, r24258, r24266, MPFR_RNDN);
        mpfr_pow(r24268, r24257, r24266, MPFR_RNDN);
        mpfr_mul(r24269, r24267, r24268, MPFR_RNDN);
        mpfr_mul(r24270, r24265, r24269, MPFR_RNDN);
        mpfr_add(r24271, r24264, r24270, MPFR_RNDN);
        mpfr_add(r24272, r24263, r24271, MPFR_RNDN);
        mpfr_pow(r24273, r24255, r24259, MPFR_RNDN);
        mpfr_div(r24274, r24272, r24273, MPFR_RNDN);
        mpfr_div(r24275, r24262, r24274, MPFR_RNDN);
        ;
        mpfr_set_si(r24277, mpfr_cmp(r24275, r24276) <= 0, MPFR_RNDN);
        mpfr_cbrt(r24278, r24261, MPFR_RNDN);
        mpfr_mul(r24279, r24278, r24278, MPFR_RNDN);
        mpfr_cbrt(r24280, r24258, MPFR_RNDN);
        mpfr_mul(r24281, r24280, r24280, MPFR_RNDN);
        mpfr_mul(r24282, r24280, r24259, MPFR_RNDN);
        mpfr_mul(r24283, r24281, r24282, MPFR_RNDN);
        mpfr_fma(r24284, r24256, r24257, r24283, MPFR_RNDN);
        mpfr_cbrt(r24285, r24284, MPFR_RNDN);
        mpfr_mul(r24286, r24279, r24285, MPFR_RNDN);
        mpfr_sin(r24287, r24286, MPFR_RNDN);
        mpfr_mul(r24288, r24257, r24258, MPFR_RNDN);
        mpfr_exp(r24289, r24288, MPFR_RNDN);
        mpfr_div(r24290, r24289, r24273, MPFR_RNDN);
        mpfr_div(r24291, r24287, r24290, MPFR_RNDN);
        ;
        mpfr_set_si(r24293, mpfr_cmp(r24275, r24292) <= 0, MPFR_RNDN);
        if (mpfr_get_si(r24293, MPFR_RNDN)) { mpfr_set(r24294, r24275, MPFR_RNDN); } else { mpfr_set(r24294, r24291, MPFR_RNDN); };
        if (mpfr_get_si(r24277, MPFR_RNDN)) { mpfr_set(r24295, r24291, MPFR_RNDN); } else { mpfr_set(r24295, r24294, MPFR_RNDN); };
        return mpfr_get_d(r24295, MPFR_RNDN);
}

