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

char *name = "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTicks from plot-0.2.3.4, B";

double f_if(float x, float y, float z, float t, float a) {
        float r49344 = x;
        float r49345 = y;
        float r49346 = z;
        float r49347 = t;
        float r49348 = r49346 - r49347;
        float r49349 = r49345 * r49348;
        float r49350 = a;
        float r49351 = r49350 - r49347;
        float r49352 = r49349 / r49351;
        float r49353 = r49344 + r49352;
        return r49353;
}

double f_id(double x, double y, double z, double t, double a) {
        double r49354 = x;
        double r49355 = y;
        double r49356 = z;
        double r49357 = t;
        double r49358 = r49356 - r49357;
        double r49359 = r49355 * r49358;
        double r49360 = a;
        double r49361 = r49360 - r49357;
        double r49362 = r49359 / r49361;
        double r49363 = r49354 + r49362;
        return r49363;
}


double f_of(float x, float y, float z, float t, float a) {
        float r49364 = x;
        float r49365 = y;
        float r49366 = 1;
        float r49367 = r49365 / r49366;
        float r49368 = z;
        float r49369 = t;
        float r49370 = r49368 - r49369;
        float r49371 = a;
        float r49372 = r49371 - r49369;
        float r49373 = r49370 / r49372;
        float r49374 = r49367 * r49373;
        float r49375 = r49364 + r49374;
        return r49375;
}

double f_od(double x, double y, double z, double t, double a) {
        double r49376 = x;
        double r49377 = y;
        double r49378 = 1;
        double r49379 = r49377 / r49378;
        double r49380 = z;
        double r49381 = t;
        double r49382 = r49380 - r49381;
        double r49383 = a;
        double r49384 = r49383 - r49381;
        double r49385 = r49382 / r49384;
        double r49386 = r49379 * r49385;
        double r49387 = r49376 + r49386;
        return r49387;
}

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 r49388, r49389, r49390, r49391, r49392, r49393, r49394, r49395, r49396, r49397;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r49388);
        mpfr_init(r49389);
        mpfr_init(r49390);
        mpfr_init(r49391);
        mpfr_init(r49392);
        mpfr_init(r49393);
        mpfr_init(r49394);
        mpfr_init(r49395);
        mpfr_init(r49396);
        mpfr_init(r49397);
}

double f_im(double x, double y, double z, double t, double a) {
        mpfr_set_d(r49388, x, MPFR_RNDN);
        mpfr_set_d(r49389, y, MPFR_RNDN);
        mpfr_set_d(r49390, z, MPFR_RNDN);
        mpfr_set_d(r49391, t, MPFR_RNDN);
        mpfr_sub(r49392, r49390, r49391, MPFR_RNDN);
        mpfr_mul(r49393, r49389, r49392, MPFR_RNDN);
        mpfr_set_d(r49394, a, MPFR_RNDN);
        mpfr_sub(r49395, r49394, r49391, MPFR_RNDN);
        mpfr_div(r49396, r49393, r49395, MPFR_RNDN);
        mpfr_add(r49397, r49388, r49396, MPFR_RNDN);
        return mpfr_get_d(r49397, MPFR_RNDN);
}

static mpfr_t r49398, r49399, r49400, r49401, r49402, r49403, r49404, r49405, r49406, r49407, r49408, r49409;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r49398);
        mpfr_init(r49399);
        mpfr_init_set_str(r49400, "1", 10, MPFR_RNDN);
        mpfr_init(r49401);
        mpfr_init(r49402);
        mpfr_init(r49403);
        mpfr_init(r49404);
        mpfr_init(r49405);
        mpfr_init(r49406);
        mpfr_init(r49407);
        mpfr_init(r49408);
        mpfr_init(r49409);
}

double f_fm(double x, double y, double z, double t, double a) {
        mpfr_set_d(r49398, x, MPFR_RNDN);
        mpfr_set_d(r49399, y, MPFR_RNDN);
        ;
        mpfr_div(r49401, r49399, r49400, MPFR_RNDN);
        mpfr_set_d(r49402, z, MPFR_RNDN);
        mpfr_set_d(r49403, t, MPFR_RNDN);
        mpfr_sub(r49404, r49402, r49403, MPFR_RNDN);
        mpfr_set_d(r49405, a, MPFR_RNDN);
        mpfr_sub(r49406, r49405, r49403, MPFR_RNDN);
        mpfr_div(r49407, r49404, r49406, MPFR_RNDN);
        mpfr_mul(r49408, r49401, r49407, MPFR_RNDN);
        mpfr_add(r49409, r49398, r49408, MPFR_RNDN);
        return mpfr_get_d(r49409, MPFR_RNDN);
}

static mpfr_t r49410, r49411, r49412, r49413, r49414, r49415, r49416, r49417, r49418, r49419, r49420, r49421;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r49410);
        mpfr_init(r49411);
        mpfr_init_set_str(r49412, "1", 10, MPFR_RNDN);
        mpfr_init(r49413);
        mpfr_init(r49414);
        mpfr_init(r49415);
        mpfr_init(r49416);
        mpfr_init(r49417);
        mpfr_init(r49418);
        mpfr_init(r49419);
        mpfr_init(r49420);
        mpfr_init(r49421);
}

double f_dm(double x, double y, double z, double t, double a) {
        mpfr_set_d(r49410, x, MPFR_RNDN);
        mpfr_set_d(r49411, y, MPFR_RNDN);
        ;
        mpfr_div(r49413, r49411, r49412, MPFR_RNDN);
        mpfr_set_d(r49414, z, MPFR_RNDN);
        mpfr_set_d(r49415, t, MPFR_RNDN);
        mpfr_sub(r49416, r49414, r49415, MPFR_RNDN);
        mpfr_set_d(r49417, a, MPFR_RNDN);
        mpfr_sub(r49418, r49417, r49415, MPFR_RNDN);
        mpfr_div(r49419, r49416, r49418, MPFR_RNDN);
        mpfr_mul(r49420, r49413, r49419, MPFR_RNDN);
        mpfr_add(r49421, r49410, r49420, MPFR_RNDN);
        return mpfr_get_d(r49421, MPFR_RNDN);
}

