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

char *name = "math.sqrt on complex, real part";

double f_if(float re, float im) {
        float r25332 = 0.5;
        float r25333 = 2.0;
        float r25334 = re;
        float r25335 = r25334 * r25334;
        float r25336 = im;
        float r25337 = r25336 * r25336;
        float r25338 = r25335 + r25337;
        float r25339 = sqrt(r25338);
        float r25340 = r25339 + r25334;
        float r25341 = r25333 * r25340;
        float r25342 = sqrt(r25341);
        float r25343 = r25332 * r25342;
        return r25343;
}

double f_id(double re, double im) {
        double r25344 = 0.5;
        double r25345 = 2.0;
        double r25346 = re;
        double r25347 = r25346 * r25346;
        double r25348 = im;
        double r25349 = r25348 * r25348;
        double r25350 = r25347 + r25349;
        double r25351 = sqrt(r25350);
        double r25352 = r25351 + r25346;
        double r25353 = r25345 * r25352;
        double r25354 = sqrt(r25353);
        double r25355 = r25344 * r25354;
        return r25355;
}


double f_of(float re, float im) {
        float r25356 = 2.0;
        float r25357 = im;
        float r25358 = re;
        float r25359 = r25357 + r25358;
        float r25360 = r25356 * r25359;
        float r25361 = -7.842605776201258e+158;
        bool r25362 = r25360 <= r25361;
        float r25363 = sqrt(r25356);
        float r25364 = fabs(r25357);
        float r25365 = r25363 * r25364;
        float r25366 = 0.5;
        float r25367 = r25365 * r25366;
        float r25368 = -r25358;
        float r25369 = r25368 - r25358;
        float r25370 = sqrt(r25369);
        float r25371 = r25367 / r25370;
        float r25372 = 5.255538043449715e-251;
        bool r25373 = r25360 <= r25372;
        float r25374 = r25358 * r25358;
        float r25375 = r25357 * r25357;
        float r25376 = r25374 + r25375;
        float r25377 = sqrt(r25376);
        float r25378 = r25377 - r25358;
        float r25379 = sqrt(r25378);
        float r25380 = r25365 / r25379;
        float r25381 = sqrt(r25380);
        float r25382 = r25381 * r25381;
        float r25383 = r25366 * r25382;
        float r25384 = 5.653739089360909e-149;
        bool r25385 = r25360 <= r25384;
        float r25386 = sqrt(r25360);
        float r25387 = r25366 * r25386;
        float r25388 = 1.6383255164296062e+148;
        bool r25389 = r25360 <= r25388;
        float r25390 = sqrt(r25377);
        float r25391 = r25390 * r25390;
        float r25392 = r25391 + r25358;
        float r25393 = r25356 * r25392;
        float r25394 = sqrt(r25393);
        float r25395 = r25366 * r25394;
        float r25396 = 9.558010746694755e+219;
        bool r25397 = r25360 <= r25396;
        float r25398 = 3.38018246578394e+290;
        bool r25399 = r25360 <= r25398;
        float r25400 = r25358 + r25358;
        float r25401 = r25356 * r25400;
        float r25402 = sqrt(r25401);
        float r25403 = r25366 * r25402;
        float r25404 = r25399 ? r25403 : r25387;
        float r25405 = r25397 ? r25387 : r25404;
        float r25406 = r25389 ? r25395 : r25405;
        float r25407 = r25385 ? r25387 : r25406;
        float r25408 = r25373 ? r25383 : r25407;
        float r25409 = r25362 ? r25371 : r25408;
        return r25409;
}

double f_od(double re, double im) {
        double r25410 = 2.0;
        double r25411 = im;
        double r25412 = re;
        double r25413 = r25411 + r25412;
        double r25414 = r25410 * r25413;
        double r25415 = -7.842605776201258e+158;
        bool r25416 = r25414 <= r25415;
        double r25417 = sqrt(r25410);
        double r25418 = fabs(r25411);
        double r25419 = r25417 * r25418;
        double r25420 = 0.5;
        double r25421 = r25419 * r25420;
        double r25422 = -r25412;
        double r25423 = r25422 - r25412;
        double r25424 = sqrt(r25423);
        double r25425 = r25421 / r25424;
        double r25426 = 5.255538043449715e-251;
        bool r25427 = r25414 <= r25426;
        double r25428 = r25412 * r25412;
        double r25429 = r25411 * r25411;
        double r25430 = r25428 + r25429;
        double r25431 = sqrt(r25430);
        double r25432 = r25431 - r25412;
        double r25433 = sqrt(r25432);
        double r25434 = r25419 / r25433;
        double r25435 = sqrt(r25434);
        double r25436 = r25435 * r25435;
        double r25437 = r25420 * r25436;
        double r25438 = 5.653739089360909e-149;
        bool r25439 = r25414 <= r25438;
        double r25440 = sqrt(r25414);
        double r25441 = r25420 * r25440;
        double r25442 = 1.6383255164296062e+148;
        bool r25443 = r25414 <= r25442;
        double r25444 = sqrt(r25431);
        double r25445 = r25444 * r25444;
        double r25446 = r25445 + r25412;
        double r25447 = r25410 * r25446;
        double r25448 = sqrt(r25447);
        double r25449 = r25420 * r25448;
        double r25450 = 9.558010746694755e+219;
        bool r25451 = r25414 <= r25450;
        double r25452 = 3.38018246578394e+290;
        bool r25453 = r25414 <= r25452;
        double r25454 = r25412 + r25412;
        double r25455 = r25410 * r25454;
        double r25456 = sqrt(r25455);
        double r25457 = r25420 * r25456;
        double r25458 = r25453 ? r25457 : r25441;
        double r25459 = r25451 ? r25441 : r25458;
        double r25460 = r25443 ? r25449 : r25459;
        double r25461 = r25439 ? r25441 : r25460;
        double r25462 = r25427 ? r25437 : r25461;
        double r25463 = r25416 ? r25425 : r25462;
        return r25463;
}

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 r25464, r25465, r25466, r25467, r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(3664);
        mpfr_init_set_str(r25464, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r25465, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init(r25469);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init(r25475);
}

double f_im(double re, double im) {
        ;
        ;
        mpfr_set_d(r25466, re, MPFR_RNDN);
        mpfr_mul(r25467, r25466, r25466, MPFR_RNDN);
        mpfr_set_d(r25468, im, MPFR_RNDN);
        mpfr_mul(r25469, r25468, r25468, MPFR_RNDN);
        mpfr_add(r25470, r25467, r25469, MPFR_RNDN);
        mpfr_sqrt(r25471, r25470, MPFR_RNDN);
        mpfr_add(r25472, r25471, r25466, MPFR_RNDN);
        mpfr_mul(r25473, r25465, r25472, MPFR_RNDN);
        mpfr_sqrt(r25474, r25473, MPFR_RNDN);
        mpfr_mul(r25475, r25464, r25474, MPFR_RNDN);
        return mpfr_get_d(r25475, MPFR_RNDN);
}

static mpfr_t r25476, r25477, r25478, r25479, r25480, r25481, r25482, r25483, r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502, r25503, r25504, r25505, r25506, r25507, r25508, r25509, r25510, r25511, r25512, r25513, r25514, r25515, r25516, r25517, r25518, r25519, r25520, r25521, r25522, r25523, r25524, r25525, r25526, r25527, r25528, r25529;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(3664);
        mpfr_init_set_str(r25476, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25477);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init_set_str(r25481, "-7.842605776201258e+158", 10, MPFR_RNDN);
        mpfr_init(r25482);
        mpfr_init(r25483);
        mpfr_init(r25484);
        mpfr_init(r25485);
        mpfr_init_set_str(r25486, "0.5", 10, MPFR_RNDN);
        mpfr_init(r25487);
        mpfr_init(r25488);
        mpfr_init(r25489);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init_set_str(r25492, "5.255538043449715e-251", 10, MPFR_RNDN);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init_set_str(r25504, "5.653739089360909e-149", 10, MPFR_RNDN);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init_set_str(r25508, "1.6383255164296062e+148", 10, MPFR_RNDN);
        mpfr_init(r25509);
        mpfr_init(r25510);
        mpfr_init(r25511);
        mpfr_init(r25512);
        mpfr_init(r25513);
        mpfr_init(r25514);
        mpfr_init(r25515);
        mpfr_init_set_str(r25516, "9.558010746694755e+219", 10, MPFR_RNDN);
        mpfr_init(r25517);
        mpfr_init_set_str(r25518, "3.38018246578394e+290", 10, MPFR_RNDN);
        mpfr_init(r25519);
        mpfr_init(r25520);
        mpfr_init(r25521);
        mpfr_init(r25522);
        mpfr_init(r25523);
        mpfr_init(r25524);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init(r25529);
}

double f_fm(double re, double im) {
        ;
        mpfr_set_d(r25477, im, MPFR_RNDN);
        mpfr_set_d(r25478, re, MPFR_RNDN);
        mpfr_add(r25479, r25477, r25478, MPFR_RNDN);
        mpfr_mul(r25480, r25476, r25479, MPFR_RNDN);
        ;
        mpfr_set_si(r25482, mpfr_cmp(r25480, r25481) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25483, r25476, MPFR_RNDN);
        mpfr_abs(r25484, r25477, MPFR_RNDN);
        mpfr_mul(r25485, r25483, r25484, MPFR_RNDN);
        ;
        mpfr_mul(r25487, r25485, r25486, MPFR_RNDN);
        mpfr_neg(r25488, r25478, MPFR_RNDN);
        mpfr_sub(r25489, r25488, r25478, MPFR_RNDN);
        mpfr_sqrt(r25490, r25489, MPFR_RNDN);
        mpfr_div(r25491, r25487, r25490, MPFR_RNDN);
        ;
        mpfr_set_si(r25493, mpfr_cmp(r25480, r25492) <= 0, MPFR_RNDN);
        mpfr_mul(r25494, r25478, r25478, MPFR_RNDN);
        mpfr_mul(r25495, r25477, r25477, MPFR_RNDN);
        mpfr_add(r25496, r25494, r25495, MPFR_RNDN);
        mpfr_sqrt(r25497, r25496, MPFR_RNDN);
        mpfr_sub(r25498, r25497, r25478, MPFR_RNDN);
        mpfr_sqrt(r25499, r25498, MPFR_RNDN);
        mpfr_div(r25500, r25485, r25499, MPFR_RNDN);
        mpfr_sqrt(r25501, r25500, MPFR_RNDN);
        mpfr_mul(r25502, r25501, r25501, MPFR_RNDN);
        mpfr_mul(r25503, r25486, r25502, MPFR_RNDN);
        ;
        mpfr_set_si(r25505, mpfr_cmp(r25480, r25504) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25506, r25480, MPFR_RNDN);
        mpfr_mul(r25507, r25486, r25506, MPFR_RNDN);
        ;
        mpfr_set_si(r25509, mpfr_cmp(r25480, r25508) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25510, r25497, MPFR_RNDN);
        mpfr_mul(r25511, r25510, r25510, MPFR_RNDN);
        mpfr_add(r25512, r25511, r25478, MPFR_RNDN);
        mpfr_mul(r25513, r25476, r25512, MPFR_RNDN);
        mpfr_sqrt(r25514, r25513, MPFR_RNDN);
        mpfr_mul(r25515, r25486, r25514, MPFR_RNDN);
        ;
        mpfr_set_si(r25517, mpfr_cmp(r25480, r25516) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25519, mpfr_cmp(r25480, r25518) <= 0, MPFR_RNDN);
        mpfr_add(r25520, r25478, r25478, MPFR_RNDN);
        mpfr_mul(r25521, r25476, r25520, MPFR_RNDN);
        mpfr_sqrt(r25522, r25521, MPFR_RNDN);
        mpfr_mul(r25523, r25486, r25522, MPFR_RNDN);
        if (mpfr_get_si(r25519, MPFR_RNDN)) { mpfr_set(r25524, r25523, MPFR_RNDN); } else { mpfr_set(r25524, r25507, MPFR_RNDN); };
        if (mpfr_get_si(r25517, MPFR_RNDN)) { mpfr_set(r25525, r25507, MPFR_RNDN); } else { mpfr_set(r25525, r25524, MPFR_RNDN); };
        if (mpfr_get_si(r25509, MPFR_RNDN)) { mpfr_set(r25526, r25515, MPFR_RNDN); } else { mpfr_set(r25526, r25525, MPFR_RNDN); };
        if (mpfr_get_si(r25505, MPFR_RNDN)) { mpfr_set(r25527, r25507, MPFR_RNDN); } else { mpfr_set(r25527, r25526, MPFR_RNDN); };
        if (mpfr_get_si(r25493, MPFR_RNDN)) { mpfr_set(r25528, r25503, MPFR_RNDN); } else { mpfr_set(r25528, r25527, MPFR_RNDN); };
        if (mpfr_get_si(r25482, MPFR_RNDN)) { mpfr_set(r25529, r25491, MPFR_RNDN); } else { mpfr_set(r25529, r25528, MPFR_RNDN); };
        return mpfr_get_d(r25529, MPFR_RNDN);
}

static mpfr_t 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, r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568, r25569, r25570, r25571, r25572, r25573, r25574, r25575, r25576, r25577, r25578, r25579, r25580, r25581, r25582, r25583;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(3664);
        mpfr_init_set_str(r25530, "2.0", 10, MPFR_RNDN);
        mpfr_init(r25531);
        mpfr_init(r25532);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init_set_str(r25535, "-7.842605776201258e+158", 10, MPFR_RNDN);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init_set_str(r25540, "0.5", 10, MPFR_RNDN);
        mpfr_init(r25541);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init(r25545);
        mpfr_init_set_str(r25546, "5.255538043449715e-251", 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_set_str(r25558, "5.653739089360909e-149", 10, MPFR_RNDN);
        mpfr_init(r25559);
        mpfr_init(r25560);
        mpfr_init(r25561);
        mpfr_init_set_str(r25562, "1.6383255164296062e+148", 10, MPFR_RNDN);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init(r25567);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init_set_str(r25570, "9.558010746694755e+219", 10, MPFR_RNDN);
        mpfr_init(r25571);
        mpfr_init_set_str(r25572, "3.38018246578394e+290", 10, MPFR_RNDN);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init(r25576);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init(r25579);
        mpfr_init(r25580);
        mpfr_init(r25581);
        mpfr_init(r25582);
        mpfr_init(r25583);
}

double f_dm(double re, double im) {
        ;
        mpfr_set_d(r25531, im, MPFR_RNDN);
        mpfr_set_d(r25532, re, MPFR_RNDN);
        mpfr_add(r25533, r25531, r25532, MPFR_RNDN);
        mpfr_mul(r25534, r25530, r25533, MPFR_RNDN);
        ;
        mpfr_set_si(r25536, mpfr_cmp(r25534, r25535) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25537, r25530, MPFR_RNDN);
        mpfr_abs(r25538, r25531, MPFR_RNDN);
        mpfr_mul(r25539, r25537, r25538, MPFR_RNDN);
        ;
        mpfr_mul(r25541, r25539, r25540, MPFR_RNDN);
        mpfr_neg(r25542, r25532, MPFR_RNDN);
        mpfr_sub(r25543, r25542, r25532, MPFR_RNDN);
        mpfr_sqrt(r25544, r25543, MPFR_RNDN);
        mpfr_div(r25545, r25541, r25544, MPFR_RNDN);
        ;
        mpfr_set_si(r25547, mpfr_cmp(r25534, r25546) <= 0, MPFR_RNDN);
        mpfr_mul(r25548, r25532, r25532, MPFR_RNDN);
        mpfr_mul(r25549, r25531, r25531, MPFR_RNDN);
        mpfr_add(r25550, r25548, r25549, MPFR_RNDN);
        mpfr_sqrt(r25551, r25550, MPFR_RNDN);
        mpfr_sub(r25552, r25551, r25532, MPFR_RNDN);
        mpfr_sqrt(r25553, r25552, MPFR_RNDN);
        mpfr_div(r25554, r25539, r25553, MPFR_RNDN);
        mpfr_sqrt(r25555, r25554, MPFR_RNDN);
        mpfr_mul(r25556, r25555, r25555, MPFR_RNDN);
        mpfr_mul(r25557, r25540, r25556, MPFR_RNDN);
        ;
        mpfr_set_si(r25559, mpfr_cmp(r25534, r25558) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25560, r25534, MPFR_RNDN);
        mpfr_mul(r25561, r25540, r25560, MPFR_RNDN);
        ;
        mpfr_set_si(r25563, mpfr_cmp(r25534, r25562) <= 0, MPFR_RNDN);
        mpfr_sqrt(r25564, r25551, MPFR_RNDN);
        mpfr_mul(r25565, r25564, r25564, MPFR_RNDN);
        mpfr_add(r25566, r25565, r25532, MPFR_RNDN);
        mpfr_mul(r25567, r25530, r25566, MPFR_RNDN);
        mpfr_sqrt(r25568, r25567, MPFR_RNDN);
        mpfr_mul(r25569, r25540, r25568, MPFR_RNDN);
        ;
        mpfr_set_si(r25571, mpfr_cmp(r25534, r25570) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r25573, mpfr_cmp(r25534, r25572) <= 0, MPFR_RNDN);
        mpfr_add(r25574, r25532, r25532, MPFR_RNDN);
        mpfr_mul(r25575, r25530, r25574, MPFR_RNDN);
        mpfr_sqrt(r25576, r25575, MPFR_RNDN);
        mpfr_mul(r25577, r25540, r25576, MPFR_RNDN);
        if (mpfr_get_si(r25573, MPFR_RNDN)) { mpfr_set(r25578, r25577, MPFR_RNDN); } else { mpfr_set(r25578, r25561, MPFR_RNDN); };
        if (mpfr_get_si(r25571, MPFR_RNDN)) { mpfr_set(r25579, r25561, MPFR_RNDN); } else { mpfr_set(r25579, r25578, MPFR_RNDN); };
        if (mpfr_get_si(r25563, MPFR_RNDN)) { mpfr_set(r25580, r25569, MPFR_RNDN); } else { mpfr_set(r25580, r25579, MPFR_RNDN); };
        if (mpfr_get_si(r25559, MPFR_RNDN)) { mpfr_set(r25581, r25561, MPFR_RNDN); } else { mpfr_set(r25581, r25580, MPFR_RNDN); };
        if (mpfr_get_si(r25547, MPFR_RNDN)) { mpfr_set(r25582, r25557, MPFR_RNDN); } else { mpfr_set(r25582, r25581, MPFR_RNDN); };
        if (mpfr_get_si(r25536, MPFR_RNDN)) { mpfr_set(r25583, r25545, MPFR_RNDN); } else { mpfr_set(r25583, r25582, MPFR_RNDN); };
        return mpfr_get_d(r25583, MPFR_RNDN);
}

