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

char *name = "Graphics.Rendering.Plot.Render.Plot.Legend:renderLegendOutside from plot-0.2.3.4, C";

double f_if(float x, float y, float z) {
        float r49035 = x;
        float r49036 = y;
        float r49037 = z;
        float r49038 = r49036 + r49037;
        float r49039 = r49035 * r49038;
        float r49040 = 5.0;
        float r49041 = r49037 * r49040;
        float r49042 = r49039 + r49041;
        return r49042;
}

double f_id(double x, double y, double z) {
        double r49043 = x;
        double r49044 = y;
        double r49045 = z;
        double r49046 = r49044 + r49045;
        double r49047 = r49043 * r49046;
        double r49048 = 5.0;
        double r49049 = r49045 * r49048;
        double r49050 = r49047 + r49049;
        return r49050;
}


double f_of(float x, float y, float z) {
        float r49051 = x;
        float r49052 = y;
        float r49053 = z;
        float r49054 = r49052 + r49053;
        float r49055 = r49051 * r49054;
        float r49056 = 5.0;
        float r49057 = r49053 * r49056;
        float r49058 = r49055 + r49057;
        return r49058;
}

double f_od(double x, double y, double z) {
        double r49059 = x;
        double r49060 = y;
        double r49061 = z;
        double r49062 = r49060 + r49061;
        double r49063 = r49059 * r49062;
        double r49064 = 5.0;
        double r49065 = r49061 * r49064;
        double r49066 = r49063 + r49065;
        return r49066;
}

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 r49067, r49068, r49069, r49070, r49071, r49072, r49073, r49074;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1424);
        mpfr_init(r49067);
        mpfr_init(r49068);
        mpfr_init(r49069);
        mpfr_init(r49070);
        mpfr_init(r49071);
        mpfr_init_set_str(r49072, "5.0", 10, MPFR_RNDN);
        mpfr_init(r49073);
        mpfr_init(r49074);
}

double f_im(double x, double y, double z) {
        mpfr_set_d(r49067, x, MPFR_RNDN);
        mpfr_set_d(r49068, y, MPFR_RNDN);
        mpfr_set_d(r49069, z, MPFR_RNDN);
        mpfr_add(r49070, r49068, r49069, MPFR_RNDN);
        mpfr_mul(r49071, r49067, r49070, MPFR_RNDN);
        ;
        mpfr_mul(r49073, r49069, r49072, MPFR_RNDN);
        mpfr_add(r49074, r49071, r49073, MPFR_RNDN);
        return mpfr_get_d(r49074, MPFR_RNDN);
}

static mpfr_t r49075, r49076, r49077, r49078, r49079, r49080, r49081, r49082;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r49075);
        mpfr_init(r49076);
        mpfr_init(r49077);
        mpfr_init(r49078);
        mpfr_init(r49079);
        mpfr_init_set_str(r49080, "5.0", 10, MPFR_RNDN);
        mpfr_init(r49081);
        mpfr_init(r49082);
}

double f_fm(double x, double y, double z) {
        mpfr_set_d(r49075, x, MPFR_RNDN);
        mpfr_set_d(r49076, y, MPFR_RNDN);
        mpfr_set_d(r49077, z, MPFR_RNDN);
        mpfr_add(r49078, r49076, r49077, MPFR_RNDN);
        mpfr_mul(r49079, r49075, r49078, MPFR_RNDN);
        ;
        mpfr_mul(r49081, r49077, r49080, MPFR_RNDN);
        mpfr_add(r49082, r49079, r49081, MPFR_RNDN);
        return mpfr_get_d(r49082, MPFR_RNDN);
}

static mpfr_t r49083, r49084, r49085, r49086, r49087, r49088, r49089, r49090;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r49083);
        mpfr_init(r49084);
        mpfr_init(r49085);
        mpfr_init(r49086);
        mpfr_init(r49087);
        mpfr_init_set_str(r49088, "5.0", 10, MPFR_RNDN);
        mpfr_init(r49089);
        mpfr_init(r49090);
}

double f_dm(double x, double y, double z) {
        mpfr_set_d(r49083, x, MPFR_RNDN);
        mpfr_set_d(r49084, y, MPFR_RNDN);
        mpfr_set_d(r49085, z, MPFR_RNDN);
        mpfr_add(r49086, r49084, r49085, MPFR_RNDN);
        mpfr_mul(r49087, r49083, r49086, MPFR_RNDN);
        ;
        mpfr_mul(r49089, r49085, r49088, MPFR_RNDN);
        mpfr_add(r49090, r49087, r49089, MPFR_RNDN);
        return mpfr_get_d(r49090, MPFR_RNDN);
}

