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

char *name = "math.log/1 on complex, real part";

double f_if(float re, float im) {
        float r25394 = re;
        float r25395 = r25394 * r25394;
        float r25396 = im;
        float r25397 = r25396 * r25396;
        float r25398 = r25395 + r25397;
        float r25399 = sqrt(r25398);
        float r25400 = log(r25399);
        return r25400;
}

double f_id(double re, double im) {
        double r25401 = re;
        double r25402 = r25401 * r25401;
        double r25403 = im;
        double r25404 = r25403 * r25403;
        double r25405 = r25402 + r25404;
        double r25406 = sqrt(r25405);
        double r25407 = log(r25406);
        return r25407;
}


double f_of(float re, float im) {
        float r25408 = re;
        float r25409 = -1.5646458293890962e+101;
        bool r25410 = r25408 <= r25409;
        float r25411 = -r25408;
        float r25412 = log(r25411);
        float r25413 = -1.2737350136312853e-263;
        bool r25414 = r25408 <= r25413;
        float r25415 = r25408 * r25408;
        float r25416 = im;
        float r25417 = r25416 * r25416;
        float r25418 = r25415 + r25417;
        float r25419 = sqrt(r25418);
        float r25420 = log(r25419);
        float r25421 = 8.21968103819049e-300;
        bool r25422 = r25408 <= r25421;
        float r25423 = log(r25416);
        float r25424 = 0.025734278377922217;
        bool r25425 = r25408 <= r25424;
        float r25426 = log(r25408);
        float r25427 = r25425 ? r25420 : r25426;
        float r25428 = r25422 ? r25423 : r25427;
        float r25429 = r25414 ? r25420 : r25428;
        float r25430 = r25410 ? r25412 : r25429;
        return r25430;
}

double f_od(double re, double im) {
        double r25431 = re;
        double r25432 = -1.5646458293890962e+101;
        bool r25433 = r25431 <= r25432;
        double r25434 = -r25431;
        double r25435 = log(r25434);
        double r25436 = -1.2737350136312853e-263;
        bool r25437 = r25431 <= r25436;
        double r25438 = r25431 * r25431;
        double r25439 = im;
        double r25440 = r25439 * r25439;
        double r25441 = r25438 + r25440;
        double r25442 = sqrt(r25441);
        double r25443 = log(r25442);
        double r25444 = 8.21968103819049e-300;
        bool r25445 = r25431 <= r25444;
        double r25446 = log(r25439);
        double r25447 = 0.025734278377922217;
        bool r25448 = r25431 <= r25447;
        double r25449 = log(r25431);
        double r25450 = r25448 ? r25443 : r25449;
        double r25451 = r25445 ? r25446 : r25450;
        double r25452 = r25437 ? r25443 : r25451;
        double r25453 = r25433 ? r25435 : r25452;
        return r25453;
}

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 r25454, r25455, r25456, r25457, r25458, r25459, r25460;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(336);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init(r25456);
        mpfr_init(r25457);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init(r25460);
}

double f_im(double re, double im) {
        mpfr_set_d(r25454, re, MPFR_RNDN);
        mpfr_mul(r25455, r25454, r25454, MPFR_RNDN);
        mpfr_set_d(r25456, im, MPFR_RNDN);
        mpfr_mul(r25457, r25456, r25456, MPFR_RNDN);
        mpfr_add(r25458, r25455, r25457, MPFR_RNDN);
        mpfr_sqrt(r25459, r25458, MPFR_RNDN);
        mpfr_log(r25460, r25459, MPFR_RNDN);
        return mpfr_get_d(r25460, MPFR_RNDN);
}

static mpfr_t r25461, r25462, r25463, r25464, r25465, r25466, r25467, r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481, r25482, r25483;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25461);
        mpfr_init_set_str(r25462, "-1.5646458293890962e+101", 10, MPFR_RNDN);
        mpfr_init(r25463);
        mpfr_init(r25464);
        mpfr_init(r25465);
        mpfr_init_set_str(r25466, "-1.2737350136312853e-263", 10, MPFR_RNDN);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init(r25469);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init_set_str(r25474, "8.21968103819049e-300", 10, MPFR_RNDN);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init_set_str(r25477, "0.025734278377922217", 10, MPFR_RNDN);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init(r25481);
        mpfr_init(r25482);
        mpfr_init(r25483);
}

double f_fm(double re, double im) {
        mpfr_set_d(r25461, re, MPFR_RNDN);
        ;
        mpfr_set_si(r25463, mpfr_cmp(r25461, r25462) <= 0, MPFR_RNDN);
        mpfr_neg(r25464, r25461, MPFR_RNDN);
        mpfr_log(r25465, r25464, MPFR_RNDN);
        ;
        mpfr_set_si(r25467, mpfr_cmp(r25461, r25466) <= 0, MPFR_RNDN);
        mpfr_mul(r25468, r25461, r25461, MPFR_RNDN);
        mpfr_set_d(r25469, im, MPFR_RNDN);
        mpfr_mul(r25470, r25469, r25469, MPFR_RNDN);
        mpfr_add(r25471, r25468, r25470, MPFR_RNDN);
        mpfr_sqrt(r25472, r25471, MPFR_RNDN);
        mpfr_log(r25473, r25472, MPFR_RNDN);
        ;
        mpfr_set_si(r25475, mpfr_cmp(r25461, r25474) <= 0, MPFR_RNDN);
        mpfr_log(r25476, r25469, MPFR_RNDN);
        ;
        mpfr_set_si(r25478, mpfr_cmp(r25461, r25477) <= 0, MPFR_RNDN);
        mpfr_log(r25479, r25461, MPFR_RNDN);
        if (mpfr_get_si(r25478, MPFR_RNDN)) { mpfr_set(r25480, r25473, MPFR_RNDN); } else { mpfr_set(r25480, r25479, MPFR_RNDN); };
        if (mpfr_get_si(r25475, MPFR_RNDN)) { mpfr_set(r25481, r25476, MPFR_RNDN); } else { mpfr_set(r25481, r25480, MPFR_RNDN); };
        if (mpfr_get_si(r25467, MPFR_RNDN)) { mpfr_set(r25482, r25473, MPFR_RNDN); } else { mpfr_set(r25482, r25481, MPFR_RNDN); };
        if (mpfr_get_si(r25463, MPFR_RNDN)) { mpfr_set(r25483, r25465, MPFR_RNDN); } else { mpfr_set(r25483, r25482, MPFR_RNDN); };
        return mpfr_get_d(r25483, MPFR_RNDN);
}

static mpfr_t r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502, r25503, r25504, r25505, r25506;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(336);
        mpfr_init(r25484);
        mpfr_init_set_str(r25485, "-1.5646458293890962e+101", 10, MPFR_RNDN);
        mpfr_init(r25486);
        mpfr_init(r25487);
        mpfr_init(r25488);
        mpfr_init_set_str(r25489, "-1.2737350136312853e-263", 10, MPFR_RNDN);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init_set_str(r25497, "8.21968103819049e-300", 10, MPFR_RNDN);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init_set_str(r25500, "0.025734278377922217", 10, MPFR_RNDN);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
}

double f_dm(double re, double im) {
        mpfr_set_d(r25484, re, MPFR_RNDN);
        ;
        mpfr_set_si(r25486, mpfr_cmp(r25484, r25485) <= 0, MPFR_RNDN);
        mpfr_neg(r25487, r25484, MPFR_RNDN);
        mpfr_log(r25488, r25487, MPFR_RNDN);
        ;
        mpfr_set_si(r25490, mpfr_cmp(r25484, r25489) <= 0, MPFR_RNDN);
        mpfr_mul(r25491, r25484, r25484, MPFR_RNDN);
        mpfr_set_d(r25492, im, MPFR_RNDN);
        mpfr_mul(r25493, r25492, r25492, MPFR_RNDN);
        mpfr_add(r25494, r25491, r25493, MPFR_RNDN);
        mpfr_sqrt(r25495, r25494, MPFR_RNDN);
        mpfr_log(r25496, r25495, MPFR_RNDN);
        ;
        mpfr_set_si(r25498, mpfr_cmp(r25484, r25497) <= 0, MPFR_RNDN);
        mpfr_log(r25499, r25492, MPFR_RNDN);
        ;
        mpfr_set_si(r25501, mpfr_cmp(r25484, r25500) <= 0, MPFR_RNDN);
        mpfr_log(r25502, r25484, MPFR_RNDN);
        if (mpfr_get_si(r25501, MPFR_RNDN)) { mpfr_set(r25503, r25496, MPFR_RNDN); } else { mpfr_set(r25503, r25502, MPFR_RNDN); };
        if (mpfr_get_si(r25498, MPFR_RNDN)) { mpfr_set(r25504, r25499, MPFR_RNDN); } else { mpfr_set(r25504, r25503, MPFR_RNDN); };
        if (mpfr_get_si(r25490, MPFR_RNDN)) { mpfr_set(r25505, r25496, MPFR_RNDN); } else { mpfr_set(r25505, r25504, MPFR_RNDN); };
        if (mpfr_get_si(r25486, MPFR_RNDN)) { mpfr_set(r25506, r25488, MPFR_RNDN); } else { mpfr_set(r25506, r25505, MPFR_RNDN); };
        return mpfr_get_d(r25506, MPFR_RNDN);
}

