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

char *name = "Hakyll.Web.Tags:renderTagCloud from hakyll-4.7.2.3";

double f_if(float x, float y, float z, float t, float a) {
        float r17671 = x;
        float r17672 = y;
        float r17673 = z;
        float r17674 = r17672 - r17673;
        float r17675 = t;
        float r17676 = 1.0f;
        float r17677 = r17675 + r17676;
        float r17678 = r17677 - r17673;
        float r17679 = r17674 / r17678;
        float r17680 = a;
        float r17681 = r17680 - r17671;
        float r17682 = r17679 * r17681;
        float r17683 = r17671 + r17682;
        return r17683;
}

double f_id(double x, double y, double z, double t, double a) {
        double r17684 = x;
        double r17685 = y;
        double r17686 = z;
        double r17687 = r17685 - r17686;
        double r17688 = t;
        double r17689 = 1.0;
        double r17690 = r17688 + r17689;
        double r17691 = r17690 - r17686;
        double r17692 = r17687 / r17691;
        double r17693 = a;
        double r17694 = r17693 - r17684;
        double r17695 = r17692 * r17694;
        double r17696 = r17684 + r17695;
        return r17696;
}


double f_of(float x, float y, float z, float t, float a) {
        float r17697 = z;
        float r17698 = -5.1325224070800066e+179f;
        bool r17699 = r17697 <= r17698;
        float r17700 = x;
        float r17701 = a;
        float r17702 = r17700 - r17701;
        float r17703 = y;
        float r17704 = r17703 / r17697;
        float r17705 = fma(r17702, r17704, r17701);
        float r17706 = 2.0992353763185187e+175f;
        bool r17707 = r17697 <= r17706;
        float r17708 = r17701 - r17700;
        float r17709 = r17703 - r17697;
        float r17710 = 1.0f;
        float r17711 = t;
        float r17712 = r17710 + r17711;
        float r17713 = r17712 - r17697;
        float r17714 = r17709 / r17713;
        float r17715 = r17708 * r17714;
        float r17716 = r17715 + r17700;
        float r17717 = r17707 ? r17716 : r17705;
        float r17718 = r17699 ? r17705 : r17717;
        return r17718;
}

double f_od(double x, double y, double z, double t, double a) {
        double r17719 = z;
        double r17720 = -5.1325224070800066e+179;
        bool r17721 = r17719 <= r17720;
        double r17722 = x;
        double r17723 = a;
        double r17724 = r17722 - r17723;
        double r17725 = y;
        double r17726 = r17725 / r17719;
        double r17727 = fma(r17724, r17726, r17723);
        double r17728 = 2.0992353763185187e+175;
        bool r17729 = r17719 <= r17728;
        double r17730 = r17723 - r17722;
        double r17731 = r17725 - r17719;
        double r17732 = 1.0;
        double r17733 = t;
        double r17734 = r17732 + r17733;
        double r17735 = r17734 - r17719;
        double r17736 = r17731 / r17735;
        double r17737 = r17730 * r17736;
        double r17738 = r17737 + r17722;
        double r17739 = r17729 ? r17738 : r17727;
        double r17740 = r17721 ? r17727 : r17739;
        return r17740;
}

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 r17741, r17742, r17743, r17744, r17745, r17746, r17747, r17748, r17749, r17750, r17751, r17752, r17753;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init(r17741);
        mpfr_init(r17742);
        mpfr_init(r17743);
        mpfr_init(r17744);
        mpfr_init(r17745);
        mpfr_init_set_str(r17746, "1.0", 10, MPFR_RNDN);
        mpfr_init(r17747);
        mpfr_init(r17748);
        mpfr_init(r17749);
        mpfr_init(r17750);
        mpfr_init(r17751);
        mpfr_init(r17752);
        mpfr_init(r17753);
}

double f_im(double x, double y, double z, double t, double a) {
        mpfr_set_d(r17741, x, MPFR_RNDN);
        mpfr_set_d(r17742, y, MPFR_RNDN);
        mpfr_set_d(r17743, z, MPFR_RNDN);
        mpfr_sub(r17744, r17742, r17743, MPFR_RNDN);
        mpfr_set_d(r17745, t, MPFR_RNDN);
        ;
        mpfr_add(r17747, r17745, r17746, MPFR_RNDN);
        mpfr_sub(r17748, r17747, r17743, MPFR_RNDN);
        mpfr_div(r17749, r17744, r17748, MPFR_RNDN);
        mpfr_set_d(r17750, a, MPFR_RNDN);
        mpfr_sub(r17751, r17750, r17741, MPFR_RNDN);
        mpfr_mul(r17752, r17749, r17751, MPFR_RNDN);
        mpfr_add(r17753, r17741, r17752, MPFR_RNDN);
        return mpfr_get_d(r17753, MPFR_RNDN);
}

static mpfr_t r17754, r17755, r17756, r17757, r17758, r17759, r17760, r17761, r17762, r17763, r17764, r17765, r17766, r17767, r17768, r17769, r17770, r17771, r17772, r17773, r17774, r17775;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17754);
        mpfr_init_set_str(r17755, "-5.1325224070800066e+179", 10, MPFR_RNDN);
        mpfr_init(r17756);
        mpfr_init(r17757);
        mpfr_init(r17758);
        mpfr_init(r17759);
        mpfr_init(r17760);
        mpfr_init(r17761);
        mpfr_init(r17762);
        mpfr_init_set_str(r17763, "2.0992353763185187e+175", 10, MPFR_RNDN);
        mpfr_init(r17764);
        mpfr_init(r17765);
        mpfr_init(r17766);
        mpfr_init_set_str(r17767, "1.0", 10, MPFR_RNDN);
        mpfr_init(r17768);
        mpfr_init(r17769);
        mpfr_init(r17770);
        mpfr_init(r17771);
        mpfr_init(r17772);
        mpfr_init(r17773);
        mpfr_init(r17774);
        mpfr_init(r17775);
}

double f_fm(double x, double y, double z, double t, double a) {
        mpfr_set_d(r17754, z, MPFR_RNDN);
        ;
        mpfr_set_si(r17756, mpfr_cmp(r17754, r17755) <= 0, MPFR_RNDN);
        mpfr_set_d(r17757, x, MPFR_RNDN);
        mpfr_set_d(r17758, a, MPFR_RNDN);
        mpfr_sub(r17759, r17757, r17758, MPFR_RNDN);
        mpfr_set_d(r17760, y, MPFR_RNDN);
        mpfr_div(r17761, r17760, r17754, MPFR_RNDN);
        mpfr_fma(r17762, r17759, r17761, r17758, MPFR_RNDN);
        ;
        mpfr_set_si(r17764, mpfr_cmp(r17754, r17763) <= 0, MPFR_RNDN);
        mpfr_sub(r17765, r17758, r17757, MPFR_RNDN);
        mpfr_sub(r17766, r17760, r17754, MPFR_RNDN);
        ;
        mpfr_set_d(r17768, t, MPFR_RNDN);
        mpfr_add(r17769, r17767, r17768, MPFR_RNDN);
        mpfr_sub(r17770, r17769, r17754, MPFR_RNDN);
        mpfr_div(r17771, r17766, r17770, MPFR_RNDN);
        mpfr_mul(r17772, r17765, r17771, MPFR_RNDN);
        mpfr_add(r17773, r17772, r17757, MPFR_RNDN);
        if (mpfr_get_si(r17764, MPFR_RNDN)) { mpfr_set(r17774, r17773, MPFR_RNDN); } else { mpfr_set(r17774, r17762, MPFR_RNDN); };
        if (mpfr_get_si(r17756, MPFR_RNDN)) { mpfr_set(r17775, r17762, MPFR_RNDN); } else { mpfr_set(r17775, r17774, MPFR_RNDN); };
        return mpfr_get_d(r17775, MPFR_RNDN);
}

static mpfr_t r17776, r17777, r17778, r17779, r17780, r17781, r17782, r17783, r17784, r17785, r17786, r17787, r17788, r17789, r17790, r17791, r17792, r17793, r17794, r17795, r17796, r17797;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17776);
        mpfr_init_set_str(r17777, "-5.1325224070800066e+179", 10, MPFR_RNDN);
        mpfr_init(r17778);
        mpfr_init(r17779);
        mpfr_init(r17780);
        mpfr_init(r17781);
        mpfr_init(r17782);
        mpfr_init(r17783);
        mpfr_init(r17784);
        mpfr_init_set_str(r17785, "2.0992353763185187e+175", 10, MPFR_RNDN);
        mpfr_init(r17786);
        mpfr_init(r17787);
        mpfr_init(r17788);
        mpfr_init_set_str(r17789, "1.0", 10, MPFR_RNDN);
        mpfr_init(r17790);
        mpfr_init(r17791);
        mpfr_init(r17792);
        mpfr_init(r17793);
        mpfr_init(r17794);
        mpfr_init(r17795);
        mpfr_init(r17796);
        mpfr_init(r17797);
}

double f_dm(double x, double y, double z, double t, double a) {
        mpfr_set_d(r17776, z, MPFR_RNDN);
        ;
        mpfr_set_si(r17778, mpfr_cmp(r17776, r17777) <= 0, MPFR_RNDN);
        mpfr_set_d(r17779, x, MPFR_RNDN);
        mpfr_set_d(r17780, a, MPFR_RNDN);
        mpfr_sub(r17781, r17779, r17780, MPFR_RNDN);
        mpfr_set_d(r17782, y, MPFR_RNDN);
        mpfr_div(r17783, r17782, r17776, MPFR_RNDN);
        mpfr_fma(r17784, r17781, r17783, r17780, MPFR_RNDN);
        ;
        mpfr_set_si(r17786, mpfr_cmp(r17776, r17785) <= 0, MPFR_RNDN);
        mpfr_sub(r17787, r17780, r17779, MPFR_RNDN);
        mpfr_sub(r17788, r17782, r17776, MPFR_RNDN);
        ;
        mpfr_set_d(r17790, t, MPFR_RNDN);
        mpfr_add(r17791, r17789, r17790, MPFR_RNDN);
        mpfr_sub(r17792, r17791, r17776, MPFR_RNDN);
        mpfr_div(r17793, r17788, r17792, MPFR_RNDN);
        mpfr_mul(r17794, r17787, r17793, MPFR_RNDN);
        mpfr_add(r17795, r17794, r17779, MPFR_RNDN);
        if (mpfr_get_si(r17786, MPFR_RNDN)) { mpfr_set(r17796, r17795, MPFR_RNDN); } else { mpfr_set(r17796, r17784, MPFR_RNDN); };
        if (mpfr_get_si(r17778, MPFR_RNDN)) { mpfr_set(r17797, r17784, MPFR_RNDN); } else { mpfr_set(r17797, r17796, MPFR_RNDN); };
        return mpfr_get_d(r17797, MPFR_RNDN);
}

