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

char *name = "NMSE example 3.6";

double f_if(float x) {
        float r4619888 = 1.0f;
        float r4619889 = x;
        float r4619890 = sqrt(r4619889);
        float r4619891 = r4619888 / r4619890;
        float r4619892 = r4619889 + r4619888;
        float r4619893 = sqrt(r4619892);
        float r4619894 = r4619888 / r4619893;
        float r4619895 = r4619891 - r4619894;
        return r4619895;
}

double f_id(double x) {
        double r4619896 = 1.0;
        double r4619897 = x;
        double r4619898 = sqrt(r4619897);
        double r4619899 = r4619896 / r4619898;
        double r4619900 = r4619897 + r4619896;
        double r4619901 = sqrt(r4619900);
        double r4619902 = r4619896 / r4619901;
        double r4619903 = r4619899 - r4619902;
        return r4619903;
}


double f_of(float x) {
        float r4619904 = 1.0f;
        float r4619905 = x;
        float r4619906 = r4619904 + r4619905;
        float r4619907 = sqrt(r4619906);
        float r4619908 = sqrt(r4619905);
        float r4619909 = r4619907 + r4619908;
        float r4619910 = r4619904 / r4619909;
        float r4619911 = r4619910 / r4619908;
        float r4619912 = r4619905 + r4619904;
        float r4619913 = sqrt(r4619912);
        float r4619914 = r4619911 / r4619913;
        return r4619914;
}

double f_od(double x) {
        double r4619915 = 1.0;
        double r4619916 = x;
        double r4619917 = r4619915 + r4619916;
        double r4619918 = sqrt(r4619917);
        double r4619919 = sqrt(r4619916);
        double r4619920 = r4619918 + r4619919;
        double r4619921 = r4619915 / r4619920;
        double r4619922 = r4619921 / r4619919;
        double r4619923 = r4619916 + r4619915;
        double r4619924 = sqrt(r4619923);
        double r4619925 = r4619922 / r4619924;
        return r4619925;
}

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 r4619926, r4619927, r4619928, r4619929, r4619930, r4619931, r4619932, r4619933;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r4619926, "1", 10, MPFR_RNDN);
        mpfr_init(r4619927);
        mpfr_init(r4619928);
        mpfr_init(r4619929);
        mpfr_init(r4619930);
        mpfr_init(r4619931);
        mpfr_init(r4619932);
        mpfr_init(r4619933);
}

double f_im(double x) {
        ;
        mpfr_set_d(r4619927, x, MPFR_RNDN);
        mpfr_sqrt(r4619928, r4619927, MPFR_RNDN);
        mpfr_div(r4619929, r4619926, r4619928, MPFR_RNDN);
        mpfr_add(r4619930, r4619927, r4619926, MPFR_RNDN);
        mpfr_sqrt(r4619931, r4619930, MPFR_RNDN);
        mpfr_div(r4619932, r4619926, r4619931, MPFR_RNDN);
        mpfr_sub(r4619933, r4619929, r4619932, MPFR_RNDN);
        return mpfr_get_d(r4619933, MPFR_RNDN);
}

static mpfr_t r4619934, r4619935, r4619936, r4619937, r4619938, r4619939, r4619940, r4619941, r4619942, r4619943, r4619944;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r4619934, "1", 10, MPFR_RNDN);
        mpfr_init(r4619935);
        mpfr_init(r4619936);
        mpfr_init(r4619937);
        mpfr_init(r4619938);
        mpfr_init(r4619939);
        mpfr_init(r4619940);
        mpfr_init(r4619941);
        mpfr_init(r4619942);
        mpfr_init(r4619943);
        mpfr_init(r4619944);
}

double f_fm(double x) {
        ;
        mpfr_set_d(r4619935, x, MPFR_RNDN);
        mpfr_add(r4619936, r4619934, r4619935, MPFR_RNDN);
        mpfr_sqrt(r4619937, r4619936, MPFR_RNDN);
        mpfr_sqrt(r4619938, r4619935, MPFR_RNDN);
        mpfr_add(r4619939, r4619937, r4619938, MPFR_RNDN);
        mpfr_div(r4619940, r4619934, r4619939, MPFR_RNDN);
        mpfr_div(r4619941, r4619940, r4619938, MPFR_RNDN);
        mpfr_add(r4619942, r4619935, r4619934, MPFR_RNDN);
        mpfr_sqrt(r4619943, r4619942, MPFR_RNDN);
        mpfr_div(r4619944, r4619941, r4619943, MPFR_RNDN);
        return mpfr_get_d(r4619944, MPFR_RNDN);
}

static mpfr_t r4619945, r4619946, r4619947, r4619948, r4619949, r4619950, r4619951, r4619952, r4619953, r4619954, r4619955;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init_set_str(r4619945, "1", 10, MPFR_RNDN);
        mpfr_init(r4619946);
        mpfr_init(r4619947);
        mpfr_init(r4619948);
        mpfr_init(r4619949);
        mpfr_init(r4619950);
        mpfr_init(r4619951);
        mpfr_init(r4619952);
        mpfr_init(r4619953);
        mpfr_init(r4619954);
        mpfr_init(r4619955);
}

double f_dm(double x) {
        ;
        mpfr_set_d(r4619946, x, MPFR_RNDN);
        mpfr_add(r4619947, r4619945, r4619946, MPFR_RNDN);
        mpfr_sqrt(r4619948, r4619947, MPFR_RNDN);
        mpfr_sqrt(r4619949, r4619946, MPFR_RNDN);
        mpfr_add(r4619950, r4619948, r4619949, MPFR_RNDN);
        mpfr_div(r4619951, r4619945, r4619950, MPFR_RNDN);
        mpfr_div(r4619952, r4619951, r4619949, MPFR_RNDN);
        mpfr_add(r4619953, r4619946, r4619945, MPFR_RNDN);
        mpfr_sqrt(r4619954, r4619953, MPFR_RNDN);
        mpfr_div(r4619955, r4619952, r4619954, MPFR_RNDN);
        return mpfr_get_d(r4619955, MPFR_RNDN);
}

