#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 r18746 = 0.5f;
        float r18747 = 2.0f;
        float r18748 = re;
        float r18749 = r18748 * r18748;
        float r18750 = im;
        float r18751 = r18750 * r18750;
        float r18752 = r18749 + r18751;
        float r18753 = sqrt(r18752);
        float r18754 = r18753 + r18748;
        float r18755 = r18747 * r18754;
        float r18756 = sqrt(r18755);
        float r18757 = r18746 * r18756;
        return r18757;
}

double f_id(double re, double im) {
        double r18758 = 0.5;
        double r18759 = 2.0;
        double r18760 = re;
        double r18761 = r18760 * r18760;
        double r18762 = im;
        double r18763 = r18762 * r18762;
        double r18764 = r18761 + r18763;
        double r18765 = sqrt(r18764);
        double r18766 = r18765 + r18760;
        double r18767 = r18759 * r18766;
        double r18768 = sqrt(r18767);
        double r18769 = r18758 * r18768;
        return r18769;
}


double f_of(float re, float im) {
        float r18770 = re;
        float r18771 = -3.4058532270484164e-37f;
        bool r18772 = r18770 <= r18771;
        float r18773 = 0.5f;
        float r18774 = 2.0f;
        float r18775 = im;
        float r18776 = r18774 * r18775;
        float r18777 = r18776 * r18775;
        float r18778 = sqrt(r18777);
        float r18779 = r18770 * r18770;
        float r18780 = r18775 * r18775;
        float r18781 = r18779 + r18780;
        float r18782 = sqrt(r18781);
        float r18783 = r18782 - r18770;
        float r18784 = sqrt(r18783);
        float r18785 = r18778 / r18784;
        float r18786 = r18773 * r18785;
        float r18787 = 90184992.0f;
        bool r18788 = r18770 <= r18787;
        float r18789 = r18770 * r18770;
        float r18790 = r18789 + r18780;
        float r18791 = sqrt(r18790);
        float r18792 = r18791 + r18770;
        float r18793 = r18774 * r18792;
        float r18794 = sqrt(r18793);
        float r18795 = r18773 * r18794;
        float r18796 = r18770 + r18770;
        float r18797 = r18774 * r18796;
        float r18798 = sqrt(r18797);
        float r18799 = r18773 * r18798;
        float r18800 = r18788 ? r18795 : r18799;
        float r18801 = r18772 ? r18786 : r18800;
        return r18801;
}

double f_od(double re, double im) {
        double r18802 = re;
        double r18803 = -3.4058532270484164e-37;
        bool r18804 = r18802 <= r18803;
        double r18805 = 0.5;
        double r18806 = 2.0;
        double r18807 = im;
        double r18808 = r18806 * r18807;
        double r18809 = r18808 * r18807;
        double r18810 = sqrt(r18809);
        double r18811 = r18802 * r18802;
        double r18812 = r18807 * r18807;
        double r18813 = r18811 + r18812;
        double r18814 = sqrt(r18813);
        double r18815 = r18814 - r18802;
        double r18816 = sqrt(r18815);
        double r18817 = r18810 / r18816;
        double r18818 = r18805 * r18817;
        double r18819 = 90184992.0;
        bool r18820 = r18802 <= r18819;
        double r18821 = r18802 * r18802;
        double r18822 = r18821 + r18812;
        double r18823 = sqrt(r18822);
        double r18824 = r18823 + r18802;
        double r18825 = r18806 * r18824;
        double r18826 = sqrt(r18825);
        double r18827 = r18805 * r18826;
        double r18828 = r18802 + r18802;
        double r18829 = r18806 * r18828;
        double r18830 = sqrt(r18829);
        double r18831 = r18805 * r18830;
        double r18832 = r18820 ? r18827 : r18831;
        double r18833 = r18804 ? r18818 : r18832;
        return r18833;
}

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 r18834, r18835, r18836, r18837, r18838, r18839, r18840, r18841, r18842, r18843, r18844, r18845;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r18834, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r18835, "2.0", 10, MPFR_RNDN);
        mpfr_init(r18836);
        mpfr_init(r18837);
        mpfr_init(r18838);
        mpfr_init(r18839);
        mpfr_init(r18840);
        mpfr_init(r18841);
        mpfr_init(r18842);
        mpfr_init(r18843);
        mpfr_init(r18844);
        mpfr_init(r18845);
}

double f_im(double re, double im) {
        ;
        ;
        mpfr_set_d(r18836, re, MPFR_RNDN);
        mpfr_mul(r18837, r18836, r18836, MPFR_RNDN);
        mpfr_set_d(r18838, im, MPFR_RNDN);
        mpfr_mul(r18839, r18838, r18838, MPFR_RNDN);
        mpfr_add(r18840, r18837, r18839, MPFR_RNDN);
        mpfr_sqrt(r18841, r18840, MPFR_RNDN);
        mpfr_add(r18842, r18841, r18836, MPFR_RNDN);
        mpfr_mul(r18843, r18835, r18842, MPFR_RNDN);
        mpfr_sqrt(r18844, r18843, MPFR_RNDN);
        mpfr_mul(r18845, r18834, r18844, MPFR_RNDN);
        return mpfr_get_d(r18845, MPFR_RNDN);
}

static mpfr_t r18846, r18847, r18848, r18849, r18850, r18851, r18852, r18853, r18854, r18855, r18856, r18857, r18858, r18859, r18860, r18861, r18862, r18863, r18864, r18865, r18866, r18867, r18868, r18869, r18870, r18871, r18872, r18873, r18874, r18875, r18876, r18877;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r18846);
        mpfr_init_set_str(r18847, "-3.4058532f-37", 10, MPFR_RNDN);
        mpfr_init(r18848);
        mpfr_init_set_str(r18849, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r18850, "2.0", 10, MPFR_RNDN);
        mpfr_init(r18851);
        mpfr_init(r18852);
        mpfr_init(r18853);
        mpfr_init(r18854);
        mpfr_init(r18855);
        mpfr_init(r18856);
        mpfr_init(r18857);
        mpfr_init(r18858);
        mpfr_init(r18859);
        mpfr_init(r18860);
        mpfr_init(r18861);
        mpfr_init(r18862);
        mpfr_init_set_str(r18863, "9.018499f+07", 10, MPFR_RNDN);
        mpfr_init(r18864);
        mpfr_init(r18865);
        mpfr_init(r18866);
        mpfr_init(r18867);
        mpfr_init(r18868);
        mpfr_init(r18869);
        mpfr_init(r18870);
        mpfr_init(r18871);
        mpfr_init(r18872);
        mpfr_init(r18873);
        mpfr_init(r18874);
        mpfr_init(r18875);
        mpfr_init(r18876);
        mpfr_init(r18877);
}

double f_fm(double re, double im) {
        mpfr_set_d(r18846, re, MPFR_RNDN);
        ;
        mpfr_set_si(r18848, mpfr_cmp(r18846, r18847) <= 0, MPFR_RNDN);
        ;
        ;
        mpfr_set_d(r18851, im, MPFR_RNDN);
        mpfr_mul(r18852, r18850, r18851, MPFR_RNDN);
        mpfr_mul(r18853, r18852, r18851, MPFR_RNDN);
        mpfr_sqrt(r18854, r18853, MPFR_RNDN);
        mpfr_sqr(r18855, r18846, MPFR_RNDN);
        mpfr_mul(r18856, r18851, r18851, MPFR_RNDN);
        mpfr_add(r18857, r18855, r18856, MPFR_RNDN);
        mpfr_sqrt(r18858, r18857, MPFR_RNDN);
        mpfr_sub(r18859, r18858, r18846, MPFR_RNDN);
        mpfr_sqrt(r18860, r18859, MPFR_RNDN);
        mpfr_div(r18861, r18854, r18860, MPFR_RNDN);
        mpfr_mul(r18862, r18849, r18861, MPFR_RNDN);
        ;
        mpfr_set_si(r18864, mpfr_cmp(r18846, r18863) <= 0, MPFR_RNDN);
        mpfr_mul(r18865, r18846, r18846, MPFR_RNDN);
        mpfr_add(r18866, r18865, r18856, MPFR_RNDN);
        mpfr_sqrt(r18867, r18866, MPFR_RNDN);
        mpfr_add(r18868, r18867, r18846, MPFR_RNDN);
        mpfr_mul(r18869, r18850, r18868, MPFR_RNDN);
        mpfr_sqrt(r18870, r18869, MPFR_RNDN);
        mpfr_mul(r18871, r18849, r18870, MPFR_RNDN);
        mpfr_add(r18872, r18846, r18846, MPFR_RNDN);
        mpfr_mul(r18873, r18850, r18872, MPFR_RNDN);
        mpfr_sqrt(r18874, r18873, MPFR_RNDN);
        mpfr_mul(r18875, r18849, r18874, MPFR_RNDN);
        if (mpfr_get_si(r18864, MPFR_RNDN)) { mpfr_set(r18876, r18871, MPFR_RNDN); } else { mpfr_set(r18876, r18875, MPFR_RNDN); };
        if (mpfr_get_si(r18848, MPFR_RNDN)) { mpfr_set(r18877, r18862, MPFR_RNDN); } else { mpfr_set(r18877, r18876, MPFR_RNDN); };
        return mpfr_get_d(r18877, MPFR_RNDN);
}

static mpfr_t r18878, r18879, r18880, r18881, r18882, r18883, r18884, r18885, r18886, r18887, r18888, r18889, r18890, r18891, r18892, r18893, r18894, r18895, r18896, r18897, r18898, r18899, r18900, r18901, r18902, r18903, r18904, r18905, r18906, r18907, r18908, r18909;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r18878);
        mpfr_init_set_str(r18879, "-3.4058532f-37", 10, MPFR_RNDN);
        mpfr_init(r18880);
        mpfr_init_set_str(r18881, "0.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r18882, "2.0", 10, MPFR_RNDN);
        mpfr_init(r18883);
        mpfr_init(r18884);
        mpfr_init(r18885);
        mpfr_init(r18886);
        mpfr_init(r18887);
        mpfr_init(r18888);
        mpfr_init(r18889);
        mpfr_init(r18890);
        mpfr_init(r18891);
        mpfr_init(r18892);
        mpfr_init(r18893);
        mpfr_init(r18894);
        mpfr_init_set_str(r18895, "9.018499f+07", 10, MPFR_RNDN);
        mpfr_init(r18896);
        mpfr_init(r18897);
        mpfr_init(r18898);
        mpfr_init(r18899);
        mpfr_init(r18900);
        mpfr_init(r18901);
        mpfr_init(r18902);
        mpfr_init(r18903);
        mpfr_init(r18904);
        mpfr_init(r18905);
        mpfr_init(r18906);
        mpfr_init(r18907);
        mpfr_init(r18908);
        mpfr_init(r18909);
}

double f_dm(double re, double im) {
        mpfr_set_d(r18878, re, MPFR_RNDN);
        ;
        mpfr_set_si(r18880, mpfr_cmp(r18878, r18879) <= 0, MPFR_RNDN);
        ;
        ;
        mpfr_set_d(r18883, im, MPFR_RNDN);
        mpfr_mul(r18884, r18882, r18883, MPFR_RNDN);
        mpfr_mul(r18885, r18884, r18883, MPFR_RNDN);
        mpfr_sqrt(r18886, r18885, MPFR_RNDN);
        mpfr_sqr(r18887, r18878, MPFR_RNDN);
        mpfr_mul(r18888, r18883, r18883, MPFR_RNDN);
        mpfr_add(r18889, r18887, r18888, MPFR_RNDN);
        mpfr_sqrt(r18890, r18889, MPFR_RNDN);
        mpfr_sub(r18891, r18890, r18878, MPFR_RNDN);
        mpfr_sqrt(r18892, r18891, MPFR_RNDN);
        mpfr_div(r18893, r18886, r18892, MPFR_RNDN);
        mpfr_mul(r18894, r18881, r18893, MPFR_RNDN);
        ;
        mpfr_set_si(r18896, mpfr_cmp(r18878, r18895) <= 0, MPFR_RNDN);
        mpfr_mul(r18897, r18878, r18878, MPFR_RNDN);
        mpfr_add(r18898, r18897, r18888, MPFR_RNDN);
        mpfr_sqrt(r18899, r18898, MPFR_RNDN);
        mpfr_add(r18900, r18899, r18878, MPFR_RNDN);
        mpfr_mul(r18901, r18882, r18900, MPFR_RNDN);
        mpfr_sqrt(r18902, r18901, MPFR_RNDN);
        mpfr_mul(r18903, r18881, r18902, MPFR_RNDN);
        mpfr_add(r18904, r18878, r18878, MPFR_RNDN);
        mpfr_mul(r18905, r18882, r18904, MPFR_RNDN);
        mpfr_sqrt(r18906, r18905, MPFR_RNDN);
        mpfr_mul(r18907, r18881, r18906, MPFR_RNDN);
        if (mpfr_get_si(r18896, MPFR_RNDN)) { mpfr_set(r18908, r18903, MPFR_RNDN); } else { mpfr_set(r18908, r18907, MPFR_RNDN); };
        if (mpfr_get_si(r18880, MPFR_RNDN)) { mpfr_set(r18909, r18894, MPFR_RNDN); } else { mpfr_set(r18909, r18908, MPFR_RNDN); };
        return mpfr_get_d(r18909, MPFR_RNDN);
}

