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

char *name = "Numeric.Interval.Internal:bisect from intervals-0.7.1, A";

double f_if(float x, float y) {
        float r46024 = x;
        float r46025 = y;
        float r46026 = r46025 - r46024;
        float r46027 = 2.0;
        float r46028 = r46026 / r46027;
        float r46029 = r46024 + r46028;
        return r46029;
}

double f_id(double x, double y) {
        double r46030 = x;
        double r46031 = y;
        double r46032 = r46031 - r46030;
        double r46033 = 2.0;
        double r46034 = r46032 / r46033;
        double r46035 = r46030 + r46034;
        return r46035;
}


double f_of(float x, float y) {
        float r46036 = x;
        float r46037 = y;
        float r46038 = r46037 - r46036;
        float r46039 = 2.0;
        float r46040 = r46038 / r46039;
        float r46041 = r46036 + r46040;
        return r46041;
}

double f_od(double x, double y) {
        double r46042 = x;
        double r46043 = y;
        double r46044 = r46043 - r46042;
        double r46045 = 2.0;
        double r46046 = r46044 / r46045;
        double r46047 = r46042 + r46046;
        return r46047;
}

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 r46048, r46049, r46050, r46051, r46052, r46053;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r46048);
        mpfr_init(r46049);
        mpfr_init(r46050);
        mpfr_init_set_str(r46051, "2.0", 10, MPFR_RNDN);
        mpfr_init(r46052);
        mpfr_init(r46053);
}

double f_im(double x, double y) {
        mpfr_set_d(r46048, x, MPFR_RNDN);
        mpfr_set_d(r46049, y, MPFR_RNDN);
        mpfr_sub(r46050, r46049, r46048, MPFR_RNDN);
        ;
        mpfr_div(r46052, r46050, r46051, MPFR_RNDN);
        mpfr_add(r46053, r46048, r46052, MPFR_RNDN);
        return mpfr_get_d(r46053, MPFR_RNDN);
}

static mpfr_t r46054, r46055, r46056, r46057, r46058, r46059;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r46054);
        mpfr_init(r46055);
        mpfr_init(r46056);
        mpfr_init_set_str(r46057, "2.0", 10, MPFR_RNDN);
        mpfr_init(r46058);
        mpfr_init(r46059);
}

double f_fm(double x, double y) {
        mpfr_set_d(r46054, x, MPFR_RNDN);
        mpfr_set_d(r46055, y, MPFR_RNDN);
        mpfr_sub(r46056, r46055, r46054, MPFR_RNDN);
        ;
        mpfr_div(r46058, r46056, r46057, MPFR_RNDN);
        mpfr_add(r46059, r46054, r46058, MPFR_RNDN);
        return mpfr_get_d(r46059, MPFR_RNDN);
}

static mpfr_t r46060, r46061, r46062, r46063, r46064, r46065;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r46060);
        mpfr_init(r46061);
        mpfr_init(r46062);
        mpfr_init_set_str(r46063, "2.0", 10, MPFR_RNDN);
        mpfr_init(r46064);
        mpfr_init(r46065);
}

double f_dm(double x, double y) {
        mpfr_set_d(r46060, x, MPFR_RNDN);
        mpfr_set_d(r46061, y, MPFR_RNDN);
        mpfr_sub(r46062, r46061, r46060, MPFR_RNDN);
        ;
        mpfr_div(r46064, r46062, r46063, MPFR_RNDN);
        mpfr_add(r46065, r46060, r46064, MPFR_RNDN);
        return mpfr_get_d(r46065, MPFR_RNDN);
}

