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

char *name = "Diagrams.Solve.Polynomial:cubForm  from diagrams-solve-0.1";

double f_if(float x, float y, float z, float t, float a, float b, float c, float i, float j, float k) {
        float r17634 = x;
        float r17635 = 18.0f;
        float r17636 = r17634 * r17635;
        float r17637 = y;
        float r17638 = r17636 * r17637;
        float r17639 = z;
        float r17640 = r17638 * r17639;
        float r17641 = t;
        float r17642 = r17640 * r17641;
        float r17643 = a;
        float r17644 = 4.0f;
        float r17645 = r17643 * r17644;
        float r17646 = r17645 * r17641;
        float r17647 = r17642 - r17646;
        float r17648 = b;
        float r17649 = c;
        float r17650 = r17648 * r17649;
        float r17651 = r17647 + r17650;
        float r17652 = r17634 * r17644;
        float r17653 = i;
        float r17654 = r17652 * r17653;
        float r17655 = r17651 - r17654;
        float r17656 = j;
        float r17657 = 27.0f;
        float r17658 = r17656 * r17657;
        float r17659 = k;
        float r17660 = r17658 * r17659;
        float r17661 = r17655 - r17660;
        return r17661;
}

double f_id(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
        double r17662 = x;
        double r17663 = 18.0;
        double r17664 = r17662 * r17663;
        double r17665 = y;
        double r17666 = r17664 * r17665;
        double r17667 = z;
        double r17668 = r17666 * r17667;
        double r17669 = t;
        double r17670 = r17668 * r17669;
        double r17671 = a;
        double r17672 = 4.0;
        double r17673 = r17671 * r17672;
        double r17674 = r17673 * r17669;
        double r17675 = r17670 - r17674;
        double r17676 = b;
        double r17677 = c;
        double r17678 = r17676 * r17677;
        double r17679 = r17675 + r17678;
        double r17680 = r17662 * r17672;
        double r17681 = i;
        double r17682 = r17680 * r17681;
        double r17683 = r17679 - r17682;
        double r17684 = j;
        double r17685 = 27.0;
        double r17686 = r17684 * r17685;
        double r17687 = k;
        double r17688 = r17686 * r17687;
        double r17689 = r17683 - r17688;
        return r17689;
}


double f_of(float x, float y, float z, float t, float a, float b, float c, float i, float j, float k) {
        float r17690 = t;
        float r17691 = z;
        float r17692 = r17690 * r17691;
        float r17693 = 18.0f;
        float r17694 = y;
        float r17695 = x;
        float r17696 = r17694 * r17695;
        float r17697 = r17693 * r17696;
        float r17698 = b;
        float r17699 = c;
        float r17700 = r17698 * r17699;
        float r17701 = fma(r17692, r17697, r17700);
        float r17702 = 4.0f;
        float r17703 = i;
        float r17704 = a;
        float r17705 = r17690 * r17704;
        float r17706 = fma(r17703, r17695, r17705);
        float r17707 = 27.0f;
        float r17708 = j;
        float r17709 = k;
        float r17710 = r17708 * r17709;
        float r17711 = r17707 * r17710;
        float r17712 = fma(r17702, r17706, r17711);
        float r17713 = r17701 - r17712;
        return r17713;
}

double f_od(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
        double r17714 = t;
        double r17715 = z;
        double r17716 = r17714 * r17715;
        double r17717 = 18.0;
        double r17718 = y;
        double r17719 = x;
        double r17720 = r17718 * r17719;
        double r17721 = r17717 * r17720;
        double r17722 = b;
        double r17723 = c;
        double r17724 = r17722 * r17723;
        double r17725 = fma(r17716, r17721, r17724);
        double r17726 = 4.0;
        double r17727 = i;
        double r17728 = a;
        double r17729 = r17714 * r17728;
        double r17730 = fma(r17727, r17719, r17729);
        double r17731 = 27.0;
        double r17732 = j;
        double r17733 = k;
        double r17734 = r17732 * r17733;
        double r17735 = r17731 * r17734;
        double r17736 = fma(r17726, r17730, r17735);
        double r17737 = r17725 - r17736;
        return r17737;
}

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 r17738, r17739, r17740, r17741, r17742, r17743, r17744, r17745, r17746, r17747, r17748, r17749, r17750, r17751, r17752, r17753, r17754, r17755, r17756, r17757, r17758, r17759, r17760, r17761, r17762, r17763, r17764, r17765;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(144);
        mpfr_init(r17738);
        mpfr_init_set_str(r17739, "18.0", 10, MPFR_RNDN);
        mpfr_init(r17740);
        mpfr_init(r17741);
        mpfr_init(r17742);
        mpfr_init(r17743);
        mpfr_init(r17744);
        mpfr_init(r17745);
        mpfr_init(r17746);
        mpfr_init(r17747);
        mpfr_init_set_str(r17748, "4.0", 10, MPFR_RNDN);
        mpfr_init(r17749);
        mpfr_init(r17750);
        mpfr_init(r17751);
        mpfr_init(r17752);
        mpfr_init(r17753);
        mpfr_init(r17754);
        mpfr_init(r17755);
        mpfr_init(r17756);
        mpfr_init(r17757);
        mpfr_init(r17758);
        mpfr_init(r17759);
        mpfr_init(r17760);
        mpfr_init_set_str(r17761, "27.0", 10, MPFR_RNDN);
        mpfr_init(r17762);
        mpfr_init(r17763);
        mpfr_init(r17764);
        mpfr_init(r17765);
}

double f_im(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
        mpfr_set_d(r17738, x, MPFR_RNDN);
        ;
        mpfr_mul(r17740, r17738, r17739, MPFR_RNDN);
        mpfr_set_d(r17741, y, MPFR_RNDN);
        mpfr_mul(r17742, r17740, r17741, MPFR_RNDN);
        mpfr_set_d(r17743, z, MPFR_RNDN);
        mpfr_mul(r17744, r17742, r17743, MPFR_RNDN);
        mpfr_set_d(r17745, t, MPFR_RNDN);
        mpfr_mul(r17746, r17744, r17745, MPFR_RNDN);
        mpfr_set_d(r17747, a, MPFR_RNDN);
        ;
        mpfr_mul(r17749, r17747, r17748, MPFR_RNDN);
        mpfr_mul(r17750, r17749, r17745, MPFR_RNDN);
        mpfr_sub(r17751, r17746, r17750, MPFR_RNDN);
        mpfr_set_d(r17752, b, MPFR_RNDN);
        mpfr_set_d(r17753, c, MPFR_RNDN);
        mpfr_mul(r17754, r17752, r17753, MPFR_RNDN);
        mpfr_add(r17755, r17751, r17754, MPFR_RNDN);
        mpfr_mul(r17756, r17738, r17748, MPFR_RNDN);
        mpfr_set_d(r17757, i, MPFR_RNDN);
        mpfr_mul(r17758, r17756, r17757, MPFR_RNDN);
        mpfr_sub(r17759, r17755, r17758, MPFR_RNDN);
        mpfr_set_d(r17760, j, MPFR_RNDN);
        ;
        mpfr_mul(r17762, r17760, r17761, MPFR_RNDN);
        mpfr_set_d(r17763, k, MPFR_RNDN);
        mpfr_mul(r17764, r17762, r17763, MPFR_RNDN);
        mpfr_sub(r17765, r17759, r17764, MPFR_RNDN);
        return mpfr_get_d(r17765, MPFR_RNDN);
}

static mpfr_t r17766, r17767, r17768, r17769, r17770, r17771, r17772, r17773, r17774, r17775, r17776, r17777, r17778, r17779, r17780, r17781, r17782, r17783, r17784, r17785, r17786, r17787, r17788, r17789;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17766);
        mpfr_init(r17767);
        mpfr_init(r17768);
        mpfr_init_set_str(r17769, "18.0", 10, MPFR_RNDN);
        mpfr_init(r17770);
        mpfr_init(r17771);
        mpfr_init(r17772);
        mpfr_init(r17773);
        mpfr_init(r17774);
        mpfr_init(r17775);
        mpfr_init(r17776);
        mpfr_init(r17777);
        mpfr_init_set_str(r17778, "4.0", 10, MPFR_RNDN);
        mpfr_init(r17779);
        mpfr_init(r17780);
        mpfr_init(r17781);
        mpfr_init(r17782);
        mpfr_init_set_str(r17783, "27.0", 10, MPFR_RNDN);
        mpfr_init(r17784);
        mpfr_init(r17785);
        mpfr_init(r17786);
        mpfr_init(r17787);
        mpfr_init(r17788);
        mpfr_init(r17789);
}

double f_fm(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
        mpfr_set_d(r17766, t, MPFR_RNDN);
        mpfr_set_d(r17767, z, MPFR_RNDN);
        mpfr_mul(r17768, r17766, r17767, MPFR_RNDN);
        ;
        mpfr_set_d(r17770, y, MPFR_RNDN);
        mpfr_set_d(r17771, x, MPFR_RNDN);
        mpfr_mul(r17772, r17770, r17771, MPFR_RNDN);
        mpfr_mul(r17773, r17769, r17772, MPFR_RNDN);
        mpfr_set_d(r17774, b, MPFR_RNDN);
        mpfr_set_d(r17775, c, MPFR_RNDN);
        mpfr_mul(r17776, r17774, r17775, MPFR_RNDN);
        mpfr_fma(r17777, r17768, r17773, r17776, MPFR_RNDN);
        ;
        mpfr_set_d(r17779, i, MPFR_RNDN);
        mpfr_set_d(r17780, a, MPFR_RNDN);
        mpfr_mul(r17781, r17766, r17780, MPFR_RNDN);
        mpfr_fma(r17782, r17779, r17771, r17781, MPFR_RNDN);
        ;
        mpfr_set_d(r17784, j, MPFR_RNDN);
        mpfr_set_d(r17785, k, MPFR_RNDN);
        mpfr_mul(r17786, r17784, r17785, MPFR_RNDN);
        mpfr_mul(r17787, r17783, r17786, MPFR_RNDN);
        mpfr_fma(r17788, r17778, r17782, r17787, MPFR_RNDN);
        mpfr_sub(r17789, r17777, r17788, MPFR_RNDN);
        return mpfr_get_d(r17789, MPFR_RNDN);
}

static mpfr_t r17790, r17791, r17792, r17793, r17794, r17795, r17796, r17797, r17798, r17799, r17800, r17801, r17802, r17803, r17804, r17805, r17806, r17807, r17808, r17809, r17810, r17811, r17812, r17813;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(144);
        mpfr_init(r17790);
        mpfr_init(r17791);
        mpfr_init(r17792);
        mpfr_init_set_str(r17793, "18.0", 10, MPFR_RNDN);
        mpfr_init(r17794);
        mpfr_init(r17795);
        mpfr_init(r17796);
        mpfr_init(r17797);
        mpfr_init(r17798);
        mpfr_init(r17799);
        mpfr_init(r17800);
        mpfr_init(r17801);
        mpfr_init_set_str(r17802, "4.0", 10, MPFR_RNDN);
        mpfr_init(r17803);
        mpfr_init(r17804);
        mpfr_init(r17805);
        mpfr_init(r17806);
        mpfr_init_set_str(r17807, "27.0", 10, MPFR_RNDN);
        mpfr_init(r17808);
        mpfr_init(r17809);
        mpfr_init(r17810);
        mpfr_init(r17811);
        mpfr_init(r17812);
        mpfr_init(r17813);
}

double f_dm(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
        mpfr_set_d(r17790, t, MPFR_RNDN);
        mpfr_set_d(r17791, z, MPFR_RNDN);
        mpfr_mul(r17792, r17790, r17791, MPFR_RNDN);
        ;
        mpfr_set_d(r17794, y, MPFR_RNDN);
        mpfr_set_d(r17795, x, MPFR_RNDN);
        mpfr_mul(r17796, r17794, r17795, MPFR_RNDN);
        mpfr_mul(r17797, r17793, r17796, MPFR_RNDN);
        mpfr_set_d(r17798, b, MPFR_RNDN);
        mpfr_set_d(r17799, c, MPFR_RNDN);
        mpfr_mul(r17800, r17798, r17799, MPFR_RNDN);
        mpfr_fma(r17801, r17792, r17797, r17800, MPFR_RNDN);
        ;
        mpfr_set_d(r17803, i, MPFR_RNDN);
        mpfr_set_d(r17804, a, MPFR_RNDN);
        mpfr_mul(r17805, r17790, r17804, MPFR_RNDN);
        mpfr_fma(r17806, r17803, r17795, r17805, MPFR_RNDN);
        ;
        mpfr_set_d(r17808, j, MPFR_RNDN);
        mpfr_set_d(r17809, k, MPFR_RNDN);
        mpfr_mul(r17810, r17808, r17809, MPFR_RNDN);
        mpfr_mul(r17811, r17807, r17810, MPFR_RNDN);
        mpfr_fma(r17812, r17802, r17806, r17811, MPFR_RNDN);
        mpfr_sub(r17813, r17801, r17812, MPFR_RNDN);
        return mpfr_get_d(r17813, MPFR_RNDN);
}

