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

char *name = "Data.Colour.RGB:hslsv from colour-2.3.3, D";

double f_if(float x, float y) {
        float r56734 = x;
        float r56735 = y;
        float r56736 = r56734 - r56735;
        float r56737 = r56734 + r56735;
        float r56738 = r56736 / r56737;
        return r56738;
}

double f_id(double x, double y) {
        double r56739 = x;
        double r56740 = y;
        double r56741 = r56739 - r56740;
        double r56742 = r56739 + r56740;
        double r56743 = r56741 / r56742;
        return r56743;
}


double f_of(float x, float y) {
        float r56744 = x;
        float r56745 = y;
        float r56746 = r56744 - r56745;
        float r56747 = r56744 + r56745;
        float r56748 = r56746 / r56747;
        return r56748;
}

double f_od(double x, double y) {
        double r56749 = x;
        double r56750 = y;
        double r56751 = r56749 - r56750;
        double r56752 = r56749 + r56750;
        double r56753 = r56751 / r56752;
        return r56753;
}

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 r56754, r56755, r56756, r56757, r56758;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r56754);
        mpfr_init(r56755);
        mpfr_init(r56756);
        mpfr_init(r56757);
        mpfr_init(r56758);
}

double f_im(double x, double y) {
        mpfr_set_d(r56754, x, MPFR_RNDN);
        mpfr_set_d(r56755, y, MPFR_RNDN);
        mpfr_sub(r56756, r56754, r56755, MPFR_RNDN);
        mpfr_add(r56757, r56754, r56755, MPFR_RNDN);
        mpfr_div(r56758, r56756, r56757, MPFR_RNDN);
        return mpfr_get_d(r56758, MPFR_RNDN);
}

static mpfr_t r56759, r56760, r56761, r56762, r56763;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r56759);
        mpfr_init(r56760);
        mpfr_init(r56761);
        mpfr_init(r56762);
        mpfr_init(r56763);
}

double f_fm(double x, double y) {
        mpfr_set_d(r56759, x, MPFR_RNDN);
        mpfr_set_d(r56760, y, MPFR_RNDN);
        mpfr_sub(r56761, r56759, r56760, MPFR_RNDN);
        mpfr_add(r56762, r56759, r56760, MPFR_RNDN);
        mpfr_div(r56763, r56761, r56762, MPFR_RNDN);
        return mpfr_get_d(r56763, MPFR_RNDN);
}

static mpfr_t r56764, r56765, r56766, r56767, r56768;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r56764);
        mpfr_init(r56765);
        mpfr_init(r56766);
        mpfr_init(r56767);
        mpfr_init(r56768);
}

double f_dm(double x, double y) {
        mpfr_set_d(r56764, x, MPFR_RNDN);
        mpfr_set_d(r56765, y, MPFR_RNDN);
        mpfr_sub(r56766, r56764, r56765, MPFR_RNDN);
        mpfr_add(r56767, r56764, r56765, MPFR_RNDN);
        mpfr_div(r56768, r56766, r56767, MPFR_RNDN);
        return mpfr_get_d(r56768, MPFR_RNDN);
}

