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

char *name = "Hyperbolic arcsine";

double f_if(float x) {
        float r24832 = x;
        float r24833 = r24832 * r24832;
        float r24834 = 1;
        float r24835 = r24833 + r24834;
        float r24836 = sqrt(r24835);
        float r24837 = r24832 + r24836;
        float r24838 = log(r24837);
        return r24838;
}

double f_id(double x) {
        double r24839 = x;
        double r24840 = r24839 * r24839;
        double r24841 = 1;
        double r24842 = r24840 + r24841;
        double r24843 = sqrt(r24842);
        double r24844 = r24839 + r24843;
        double r24845 = log(r24844);
        return r24845;
}


double f_of(float x) {
        float r24846 = x;
        float r24847 = -1.0700427558809735;
        bool r24848 = r24846 <= r24847;
        float r24849 = 1;
        float r24850 = r24849 / r24846;
        float r24851 = 1/8;
        float r24852 = r24851 / r24846;
        float r24853 = 1/2;
        float r24854 = -r24853;
        float r24855 = fma(r24850, r24852, r24854);
        float r24856 = 1/16;
        float r24857 = -r24856;
        float r24858 = 5;
        float r24859 = pow(r24846, r24858);
        float r24860 = r24857 / r24859;
        float r24861 = fma(r24850, r24855, r24860);
        float r24862 = log(r24861);
        float r24863 = 0.009031036370286613;
        bool r24864 = r24846 <= r24863;
        float r24865 = 3/40;
        float r24866 = r24865 * r24859;
        float r24867 = r24866 + r24846;
        float r24868 = 1/6;
        float r24869 = 3;
        float r24870 = pow(r24846, r24869);
        float r24871 = r24868 * r24870;
        float r24872 = r24867 - r24871;
        float r24873 = hypot(r24849, r24846);
        float r24874 = r24873 + r24846;
        float r24875 = sqrt(r24874);
        float r24876 = log(r24875);
        float r24877 = r24876 + r24876;
        float r24878 = r24864 ? r24872 : r24877;
        float r24879 = r24848 ? r24862 : r24878;
        return r24879;
}

double f_od(double x) {
        double r24880 = x;
        double r24881 = -1.0700427558809735;
        bool r24882 = r24880 <= r24881;
        double r24883 = 1;
        double r24884 = r24883 / r24880;
        double r24885 = 1/8;
        double r24886 = r24885 / r24880;
        double r24887 = 1/2;
        double r24888 = -r24887;
        double r24889 = fma(r24884, r24886, r24888);
        double r24890 = 1/16;
        double r24891 = -r24890;
        double r24892 = 5;
        double r24893 = pow(r24880, r24892);
        double r24894 = r24891 / r24893;
        double r24895 = fma(r24884, r24889, r24894);
        double r24896 = log(r24895);
        double r24897 = 0.009031036370286613;
        bool r24898 = r24880 <= r24897;
        double r24899 = 3/40;
        double r24900 = r24899 * r24893;
        double r24901 = r24900 + r24880;
        double r24902 = 1/6;
        double r24903 = 3;
        double r24904 = pow(r24880, r24903);
        double r24905 = r24902 * r24904;
        double r24906 = r24901 - r24905;
        double r24907 = hypot(r24883, r24880);
        double r24908 = r24907 + r24880;
        double r24909 = sqrt(r24908);
        double r24910 = log(r24909);
        double r24911 = r24910 + r24910;
        double r24912 = r24898 ? r24906 : r24911;
        double r24913 = r24882 ? r24896 : r24912;
        return r24913;
}

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 r24914, r24915, r24916, r24917, r24918, r24919, r24920;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(8208);
        mpfr_init(r24914);
        mpfr_init(r24915);
        mpfr_init_set_str(r24916, "1", 10, MPFR_RNDN);
        mpfr_init(r24917);
        mpfr_init(r24918);
        mpfr_init(r24919);
        mpfr_init(r24920);
}

double f_im(double x) {
        mpfr_set_d(r24914, x, MPFR_RNDN);
        mpfr_mul(r24915, r24914, r24914, MPFR_RNDN);
        ;
        mpfr_add(r24917, r24915, r24916, MPFR_RNDN);
        mpfr_sqrt(r24918, r24917, MPFR_RNDN);
        mpfr_add(r24919, r24914, r24918, MPFR_RNDN);
        mpfr_log(r24920, r24919, MPFR_RNDN);
        return mpfr_get_d(r24920, MPFR_RNDN);
}

static mpfr_t r24921, r24922, r24923, r24924, r24925, r24926, r24927, r24928, r24929, r24930, r24931, r24932, r24933, r24934, r24935, r24936, r24937, r24938, r24939, r24940, r24941, r24942, r24943, r24944, r24945, r24946, r24947, r24948, r24949, r24950, r24951, r24952, r24953, r24954;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(8208);
        mpfr_init(r24921);
        mpfr_init_set_str(r24922, "-1.0700427558809735", 10, MPFR_RNDN);
        mpfr_init(r24923);
        mpfr_init_set_str(r24924, "1", 10, MPFR_RNDN);
        mpfr_init(r24925);
        mpfr_init_set_str(r24926, "1/8", 10, MPFR_RNDN);
        mpfr_init(r24927);
        mpfr_init_set_str(r24928, "1/2", 10, MPFR_RNDN);
        mpfr_init(r24929);
        mpfr_init(r24930);
        mpfr_init_set_str(r24931, "1/16", 10, MPFR_RNDN);
        mpfr_init(r24932);
        mpfr_init_set_str(r24933, "5", 10, MPFR_RNDN);
        mpfr_init(r24934);
        mpfr_init(r24935);
        mpfr_init(r24936);
        mpfr_init(r24937);
        mpfr_init_set_str(r24938, "0.009031036370286613", 10, MPFR_RNDN);
        mpfr_init(r24939);
        mpfr_init_set_str(r24940, "3/40", 10, MPFR_RNDN);
        mpfr_init(r24941);
        mpfr_init(r24942);
        mpfr_init_set_str(r24943, "1/6", 10, MPFR_RNDN);
        mpfr_init_set_str(r24944, "3", 10, MPFR_RNDN);
        mpfr_init(r24945);
        mpfr_init(r24946);
        mpfr_init(r24947);
        mpfr_init(r24948);
        mpfr_init(r24949);
        mpfr_init(r24950);
        mpfr_init(r24951);
        mpfr_init(r24952);
        mpfr_init(r24953);
        mpfr_init(r24954);
}

double f_fm(double x) {
        mpfr_set_d(r24921, x, MPFR_RNDN);
        ;
        mpfr_set_si(r24923, mpfr_cmp(r24921, r24922) <= 0, MPFR_RNDN);
        ;
        mpfr_div(r24925, r24924, r24921, MPFR_RNDN);
        ;
        mpfr_div(r24927, r24926, r24921, MPFR_RNDN);
        ;
        mpfr_neg(r24929, r24928, MPFR_RNDN);
        mpfr_fma(r24930, r24925, r24927, r24929, MPFR_RNDN);
        ;
        mpfr_neg(r24932, r24931, MPFR_RNDN);
        ;
        mpfr_pow(r24934, r24921, r24933, MPFR_RNDN);
        mpfr_div(r24935, r24932, r24934, MPFR_RNDN);
        mpfr_fma(r24936, r24925, r24930, r24935, MPFR_RNDN);
        mpfr_log(r24937, r24936, MPFR_RNDN);
        ;
        mpfr_set_si(r24939, mpfr_cmp(r24921, r24938) <= 0, MPFR_RNDN);
        ;
        mpfr_mul(r24941, r24940, r24934, MPFR_RNDN);
        mpfr_add(r24942, r24941, r24921, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r24945, r24921, r24944, MPFR_RNDN);
        mpfr_mul(r24946, r24943, r24945, MPFR_RNDN);
        mpfr_sub(r24947, r24942, r24946, MPFR_RNDN);
        mpfr_hypot(r24948, r24924, r24921, MPFR_RNDN);
        mpfr_add(r24949, r24948, r24921, MPFR_RNDN);
        mpfr_sqrt(r24950, r24949, MPFR_RNDN);
        mpfr_log(r24951, r24950, MPFR_RNDN);
        mpfr_add(r24952, r24951, r24951, MPFR_RNDN);
        if (mpfr_get_si(r24939, MPFR_RNDN)) { mpfr_set(r24953, r24947, MPFR_RNDN); } else { mpfr_set(r24953, r24952, MPFR_RNDN); };
        if (mpfr_get_si(r24923, MPFR_RNDN)) { mpfr_set(r24954, r24937, MPFR_RNDN); } else { mpfr_set(r24954, r24953, MPFR_RNDN); };
        return mpfr_get_d(r24954, MPFR_RNDN);
}

static mpfr_t r24955, r24956, r24957, r24958, r24959, r24960, r24961, r24962, r24963, r24964, r24965, r24966, r24967, r24968, r24969, r24970, r24971, r24972, r24973, r24974, r24975, r24976, r24977, r24978, r24979, r24980, r24981, r24982, r24983, r24984, r24985, r24986, r24987, r24988;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(8208);
        mpfr_init(r24955);
        mpfr_init_set_str(r24956, "-1.0700427558809735", 10, MPFR_RNDN);
        mpfr_init(r24957);
        mpfr_init_set_str(r24958, "1", 10, MPFR_RNDN);
        mpfr_init(r24959);
        mpfr_init_set_str(r24960, "1/8", 10, MPFR_RNDN);
        mpfr_init(r24961);
        mpfr_init_set_str(r24962, "1/2", 10, MPFR_RNDN);
        mpfr_init(r24963);
        mpfr_init(r24964);
        mpfr_init_set_str(r24965, "1/16", 10, MPFR_RNDN);
        mpfr_init(r24966);
        mpfr_init_set_str(r24967, "5", 10, MPFR_RNDN);
        mpfr_init(r24968);
        mpfr_init(r24969);
        mpfr_init(r24970);
        mpfr_init(r24971);
        mpfr_init_set_str(r24972, "0.009031036370286613", 10, MPFR_RNDN);
        mpfr_init(r24973);
        mpfr_init_set_str(r24974, "3/40", 10, MPFR_RNDN);
        mpfr_init(r24975);
        mpfr_init(r24976);
        mpfr_init_set_str(r24977, "1/6", 10, MPFR_RNDN);
        mpfr_init_set_str(r24978, "3", 10, MPFR_RNDN);
        mpfr_init(r24979);
        mpfr_init(r24980);
        mpfr_init(r24981);
        mpfr_init(r24982);
        mpfr_init(r24983);
        mpfr_init(r24984);
        mpfr_init(r24985);
        mpfr_init(r24986);
        mpfr_init(r24987);
        mpfr_init(r24988);
}

double f_dm(double x) {
        mpfr_set_d(r24955, x, MPFR_RNDN);
        ;
        mpfr_set_si(r24957, mpfr_cmp(r24955, r24956) <= 0, MPFR_RNDN);
        ;
        mpfr_div(r24959, r24958, r24955, MPFR_RNDN);
        ;
        mpfr_div(r24961, r24960, r24955, MPFR_RNDN);
        ;
        mpfr_neg(r24963, r24962, MPFR_RNDN);
        mpfr_fma(r24964, r24959, r24961, r24963, MPFR_RNDN);
        ;
        mpfr_neg(r24966, r24965, MPFR_RNDN);
        ;
        mpfr_pow(r24968, r24955, r24967, MPFR_RNDN);
        mpfr_div(r24969, r24966, r24968, MPFR_RNDN);
        mpfr_fma(r24970, r24959, r24964, r24969, MPFR_RNDN);
        mpfr_log(r24971, r24970, MPFR_RNDN);
        ;
        mpfr_set_si(r24973, mpfr_cmp(r24955, r24972) <= 0, MPFR_RNDN);
        ;
        mpfr_mul(r24975, r24974, r24968, MPFR_RNDN);
        mpfr_add(r24976, r24975, r24955, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r24979, r24955, r24978, MPFR_RNDN);
        mpfr_mul(r24980, r24977, r24979, MPFR_RNDN);
        mpfr_sub(r24981, r24976, r24980, MPFR_RNDN);
        mpfr_hypot(r24982, r24958, r24955, MPFR_RNDN);
        mpfr_add(r24983, r24982, r24955, MPFR_RNDN);
        mpfr_sqrt(r24984, r24983, MPFR_RNDN);
        mpfr_log(r24985, r24984, MPFR_RNDN);
        mpfr_add(r24986, r24985, r24985, MPFR_RNDN);
        if (mpfr_get_si(r24973, MPFR_RNDN)) { mpfr_set(r24987, r24981, MPFR_RNDN); } else { mpfr_set(r24987, r24986, MPFR_RNDN); };
        if (mpfr_get_si(r24957, MPFR_RNDN)) { mpfr_set(r24988, r24971, MPFR_RNDN); } else { mpfr_set(r24988, r24987, MPFR_RNDN); };
        return mpfr_get_d(r24988, MPFR_RNDN);
}

