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

char *name = "Statistics.Distribution.Poisson:$clogProbability from math-functions-0.1.5.2";

double f_if(float x, float y, float z) {
        float r40638 = x;
        float r40639 = y;
        float r40640 = log(r40639);
        float r40641 = r40638 * r40640;
        float r40642 = z;
        float r40643 = r40641 - r40642;
        float r40644 = r40643 - r40639;
        return r40644;
}

double f_id(double x, double y, double z) {
        double r40645 = x;
        double r40646 = y;
        double r40647 = log(r40646);
        double r40648 = r40645 * r40647;
        double r40649 = z;
        double r40650 = r40648 - r40649;
        double r40651 = r40650 - r40646;
        return r40651;
}


double f_of(float x, float y, float z) {
        float r40652 = x;
        float r40653 = y;
        float r40654 = log(r40653);
        float r40655 = r40652 * r40654;
        float r40656 = z;
        float r40657 = r40655 - r40656;
        float r40658 = r40657 - r40653;
        return r40658;
}

double f_od(double x, double y, double z) {
        double r40659 = x;
        double r40660 = y;
        double r40661 = log(r40660);
        double r40662 = r40659 * r40661;
        double r40663 = z;
        double r40664 = r40662 - r40663;
        double r40665 = r40664 - r40660;
        return r40665;
}

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 r40666, r40667, r40668, r40669, r40670, r40671, r40672;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r40666);
        mpfr_init(r40667);
        mpfr_init(r40668);
        mpfr_init(r40669);
        mpfr_init(r40670);
        mpfr_init(r40671);
        mpfr_init(r40672);
}

double f_im(double x, double y, double z) {
        mpfr_set_d(r40666, x, MPFR_RNDN);
        mpfr_set_d(r40667, y, MPFR_RNDN);
        mpfr_log(r40668, r40667, MPFR_RNDN);
        mpfr_mul(r40669, r40666, r40668, MPFR_RNDN);
        mpfr_set_d(r40670, z, MPFR_RNDN);
        mpfr_sub(r40671, r40669, r40670, MPFR_RNDN);
        mpfr_sub(r40672, r40671, r40667, MPFR_RNDN);
        return mpfr_get_d(r40672, MPFR_RNDN);
}

static mpfr_t r40673, r40674, r40675, r40676, r40677, r40678, r40679;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r40673);
        mpfr_init(r40674);
        mpfr_init(r40675);
        mpfr_init(r40676);
        mpfr_init(r40677);
        mpfr_init(r40678);
        mpfr_init(r40679);
}

double f_fm(double x, double y, double z) {
        mpfr_set_d(r40673, x, MPFR_RNDN);
        mpfr_set_d(r40674, y, MPFR_RNDN);
        mpfr_log(r40675, r40674, MPFR_RNDN);
        mpfr_mul(r40676, r40673, r40675, MPFR_RNDN);
        mpfr_set_d(r40677, z, MPFR_RNDN);
        mpfr_sub(r40678, r40676, r40677, MPFR_RNDN);
        mpfr_sub(r40679, r40678, r40674, MPFR_RNDN);
        return mpfr_get_d(r40679, MPFR_RNDN);
}

static mpfr_t r40680, r40681, r40682, r40683, r40684, r40685, r40686;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r40680);
        mpfr_init(r40681);
        mpfr_init(r40682);
        mpfr_init(r40683);
        mpfr_init(r40684);
        mpfr_init(r40685);
        mpfr_init(r40686);
}

double f_dm(double x, double y, double z) {
        mpfr_set_d(r40680, x, MPFR_RNDN);
        mpfr_set_d(r40681, y, MPFR_RNDN);
        mpfr_log(r40682, r40681, MPFR_RNDN);
        mpfr_mul(r40683, r40680, r40682, MPFR_RNDN);
        mpfr_set_d(r40684, z, MPFR_RNDN);
        mpfr_sub(r40685, r40683, r40684, MPFR_RNDN);
        mpfr_sub(r40686, r40685, r40681, MPFR_RNDN);
        return mpfr_get_d(r40686, MPFR_RNDN);
}

