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

char *name = "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2";

double f_if(float x, float y, float z, float t, float a, float b, float c, float i) {
        float r25320 = x;
        float r25321 = y;
        float r25322 = r25320 * r25321;
        float r25323 = z;
        float r25324 = r25322 + r25323;
        float r25325 = r25324 * r25321;
        float r25326 = 27464.7644705;
        float r25327 = r25325 + r25326;
        float r25328 = r25327 * r25321;
        float r25329 = 230661.510616;
        float r25330 = r25328 + r25329;
        float r25331 = r25330 * r25321;
        float r25332 = t;
        float r25333 = r25331 + r25332;
        float r25334 = a;
        float r25335 = r25321 + r25334;
        float r25336 = r25335 * r25321;
        float r25337 = b;
        float r25338 = r25336 + r25337;
        float r25339 = r25338 * r25321;
        float r25340 = c;
        float r25341 = r25339 + r25340;
        float r25342 = r25341 * r25321;
        float r25343 = i;
        float r25344 = r25342 + r25343;
        float r25345 = r25333 / r25344;
        return r25345;
}

double f_id(double x, double y, double z, double t, double a, double b, double c, double i) {
        double r25346 = x;
        double r25347 = y;
        double r25348 = r25346 * r25347;
        double r25349 = z;
        double r25350 = r25348 + r25349;
        double r25351 = r25350 * r25347;
        double r25352 = 27464.7644705;
        double r25353 = r25351 + r25352;
        double r25354 = r25353 * r25347;
        double r25355 = 230661.510616;
        double r25356 = r25354 + r25355;
        double r25357 = r25356 * r25347;
        double r25358 = t;
        double r25359 = r25357 + r25358;
        double r25360 = a;
        double r25361 = r25347 + r25360;
        double r25362 = r25361 * r25347;
        double r25363 = b;
        double r25364 = r25362 + r25363;
        double r25365 = r25364 * r25347;
        double r25366 = c;
        double r25367 = r25365 + r25366;
        double r25368 = r25367 * r25347;
        double r25369 = i;
        double r25370 = r25368 + r25369;
        double r25371 = r25359 / r25370;
        return r25371;
}


double f_of(float x, float y, float z, float t, float a, float b, float c, float i) {
        float r25372 = x;
        float r25373 = y;
        float r25374 = r25372 * r25373;
        float r25375 = z;
        float r25376 = r25374 + r25375;
        float r25377 = r25376 * r25373;
        float r25378 = 27464.7644705;
        float r25379 = r25377 + r25378;
        float r25380 = r25379 * r25373;
        float r25381 = 230661.510616;
        float r25382 = r25380 + r25381;
        float r25383 = r25382 * r25373;
        float r25384 = t;
        float r25385 = r25383 + r25384;
        float r25386 = 1;
        float r25387 = a;
        float r25388 = r25373 + r25387;
        float r25389 = r25388 * r25373;
        float r25390 = b;
        float r25391 = r25389 + r25390;
        float r25392 = r25391 * r25373;
        float r25393 = c;
        float r25394 = r25392 + r25393;
        float r25395 = r25394 * r25373;
        float r25396 = i;
        float r25397 = r25395 + r25396;
        float r25398 = r25386 / r25397;
        float r25399 = r25385 * r25398;
        return r25399;
}

double f_od(double x, double y, double z, double t, double a, double b, double c, double i) {
        double r25400 = x;
        double r25401 = y;
        double r25402 = r25400 * r25401;
        double r25403 = z;
        double r25404 = r25402 + r25403;
        double r25405 = r25404 * r25401;
        double r25406 = 27464.7644705;
        double r25407 = r25405 + r25406;
        double r25408 = r25407 * r25401;
        double r25409 = 230661.510616;
        double r25410 = r25408 + r25409;
        double r25411 = r25410 * r25401;
        double r25412 = t;
        double r25413 = r25411 + r25412;
        double r25414 = 1;
        double r25415 = a;
        double r25416 = r25401 + r25415;
        double r25417 = r25416 * r25401;
        double r25418 = b;
        double r25419 = r25417 + r25418;
        double r25420 = r25419 * r25401;
        double r25421 = c;
        double r25422 = r25420 + r25421;
        double r25423 = r25422 * r25401;
        double r25424 = i;
        double r25425 = r25423 + r25424;
        double r25426 = r25414 / r25425;
        double r25427 = r25413 * r25426;
        return r25427;
}

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 r25428, r25429, r25430, r25431, r25432, r25433, r25434, r25435, r25436, r25437, r25438, r25439, r25440, r25441, r25442, r25443, r25444, r25445, r25446, r25447, r25448, r25449, r25450, r25451, r25452, r25453;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r25428);
        mpfr_init(r25429);
        mpfr_init(r25430);
        mpfr_init(r25431);
        mpfr_init(r25432);
        mpfr_init(r25433);
        mpfr_init_set_str(r25434, "27464.7644705", 10, MPFR_RNDN);
        mpfr_init(r25435);
        mpfr_init(r25436);
        mpfr_init_set_str(r25437, "230661.510616", 10, MPFR_RNDN);
        mpfr_init(r25438);
        mpfr_init(r25439);
        mpfr_init(r25440);
        mpfr_init(r25441);
        mpfr_init(r25442);
        mpfr_init(r25443);
        mpfr_init(r25444);
        mpfr_init(r25445);
        mpfr_init(r25446);
        mpfr_init(r25447);
        mpfr_init(r25448);
        mpfr_init(r25449);
        mpfr_init(r25450);
        mpfr_init(r25451);
        mpfr_init(r25452);
        mpfr_init(r25453);
}

double f_im(double x, double y, double z, double t, double a, double b, double c, double i) {
        mpfr_set_d(r25428, x, MPFR_RNDN);
        mpfr_set_d(r25429, y, MPFR_RNDN);
        mpfr_mul(r25430, r25428, r25429, MPFR_RNDN);
        mpfr_set_d(r25431, z, MPFR_RNDN);
        mpfr_add(r25432, r25430, r25431, MPFR_RNDN);
        mpfr_mul(r25433, r25432, r25429, MPFR_RNDN);
        ;
        mpfr_add(r25435, r25433, r25434, MPFR_RNDN);
        mpfr_mul(r25436, r25435, r25429, MPFR_RNDN);
        ;
        mpfr_add(r25438, r25436, r25437, MPFR_RNDN);
        mpfr_mul(r25439, r25438, r25429, MPFR_RNDN);
        mpfr_set_d(r25440, t, MPFR_RNDN);
        mpfr_add(r25441, r25439, r25440, MPFR_RNDN);
        mpfr_set_d(r25442, a, MPFR_RNDN);
        mpfr_add(r25443, r25429, r25442, MPFR_RNDN);
        mpfr_mul(r25444, r25443, r25429, MPFR_RNDN);
        mpfr_set_d(r25445, b, MPFR_RNDN);
        mpfr_add(r25446, r25444, r25445, MPFR_RNDN);
        mpfr_mul(r25447, r25446, r25429, MPFR_RNDN);
        mpfr_set_d(r25448, c, MPFR_RNDN);
        mpfr_add(r25449, r25447, r25448, MPFR_RNDN);
        mpfr_mul(r25450, r25449, r25429, MPFR_RNDN);
        mpfr_set_d(r25451, i, MPFR_RNDN);
        mpfr_add(r25452, r25450, r25451, MPFR_RNDN);
        mpfr_div(r25453, r25441, r25452, MPFR_RNDN);
        return mpfr_get_d(r25453, MPFR_RNDN);
}

static mpfr_t r25454, r25455, r25456, r25457, r25458, r25459, r25460, r25461, r25462, r25463, r25464, r25465, r25466, r25467, r25468, r25469, r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init(r25456);
        mpfr_init(r25457);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init_set_str(r25460, "27464.7644705", 10, MPFR_RNDN);
        mpfr_init(r25461);
        mpfr_init(r25462);
        mpfr_init_set_str(r25463, "230661.510616", 10, MPFR_RNDN);
        mpfr_init(r25464);
        mpfr_init(r25465);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init_set_str(r25468, "1", 10, MPFR_RNDN);
        mpfr_init(r25469);
        mpfr_init(r25470);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init(r25477);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init(r25481);
}

double f_fm(double x, double y, double z, double t, double a, double b, double c, double i) {
        mpfr_set_d(r25454, x, MPFR_RNDN);
        mpfr_set_d(r25455, y, MPFR_RNDN);
        mpfr_mul(r25456, r25454, r25455, MPFR_RNDN);
        mpfr_set_d(r25457, z, MPFR_RNDN);
        mpfr_add(r25458, r25456, r25457, MPFR_RNDN);
        mpfr_mul(r25459, r25458, r25455, MPFR_RNDN);
        ;
        mpfr_add(r25461, r25459, r25460, MPFR_RNDN);
        mpfr_mul(r25462, r25461, r25455, MPFR_RNDN);
        ;
        mpfr_add(r25464, r25462, r25463, MPFR_RNDN);
        mpfr_mul(r25465, r25464, r25455, MPFR_RNDN);
        mpfr_set_d(r25466, t, MPFR_RNDN);
        mpfr_add(r25467, r25465, r25466, MPFR_RNDN);
        ;
        mpfr_set_d(r25469, a, MPFR_RNDN);
        mpfr_add(r25470, r25455, r25469, MPFR_RNDN);
        mpfr_mul(r25471, r25470, r25455, MPFR_RNDN);
        mpfr_set_d(r25472, b, MPFR_RNDN);
        mpfr_add(r25473, r25471, r25472, MPFR_RNDN);
        mpfr_mul(r25474, r25473, r25455, MPFR_RNDN);
        mpfr_set_d(r25475, c, MPFR_RNDN);
        mpfr_add(r25476, r25474, r25475, MPFR_RNDN);
        mpfr_mul(r25477, r25476, r25455, MPFR_RNDN);
        mpfr_set_d(r25478, i, MPFR_RNDN);
        mpfr_add(r25479, r25477, r25478, MPFR_RNDN);
        mpfr_div(r25480, r25468, r25479, MPFR_RNDN);
        mpfr_mul(r25481, r25467, r25480, MPFR_RNDN);
        return mpfr_get_d(r25481, MPFR_RNDN);
}

static mpfr_t r25482, r25483, r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502, r25503, r25504, r25505, r25506, r25507, r25508, r25509;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r25482);
        mpfr_init(r25483);
        mpfr_init(r25484);
        mpfr_init(r25485);
        mpfr_init(r25486);
        mpfr_init(r25487);
        mpfr_init_set_str(r25488, "27464.7644705", 10, MPFR_RNDN);
        mpfr_init(r25489);
        mpfr_init(r25490);
        mpfr_init_set_str(r25491, "230661.510616", 10, MPFR_RNDN);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init_set_str(r25496, "1", 10, MPFR_RNDN);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
        mpfr_init(r25507);
        mpfr_init(r25508);
        mpfr_init(r25509);
}

double f_dm(double x, double y, double z, double t, double a, double b, double c, double i) {
        mpfr_set_d(r25482, x, MPFR_RNDN);
        mpfr_set_d(r25483, y, MPFR_RNDN);
        mpfr_mul(r25484, r25482, r25483, MPFR_RNDN);
        mpfr_set_d(r25485, z, MPFR_RNDN);
        mpfr_add(r25486, r25484, r25485, MPFR_RNDN);
        mpfr_mul(r25487, r25486, r25483, MPFR_RNDN);
        ;
        mpfr_add(r25489, r25487, r25488, MPFR_RNDN);
        mpfr_mul(r25490, r25489, r25483, MPFR_RNDN);
        ;
        mpfr_add(r25492, r25490, r25491, MPFR_RNDN);
        mpfr_mul(r25493, r25492, r25483, MPFR_RNDN);
        mpfr_set_d(r25494, t, MPFR_RNDN);
        mpfr_add(r25495, r25493, r25494, MPFR_RNDN);
        ;
        mpfr_set_d(r25497, a, MPFR_RNDN);
        mpfr_add(r25498, r25483, r25497, MPFR_RNDN);
        mpfr_mul(r25499, r25498, r25483, MPFR_RNDN);
        mpfr_set_d(r25500, b, MPFR_RNDN);
        mpfr_add(r25501, r25499, r25500, MPFR_RNDN);
        mpfr_mul(r25502, r25501, r25483, MPFR_RNDN);
        mpfr_set_d(r25503, c, MPFR_RNDN);
        mpfr_add(r25504, r25502, r25503, MPFR_RNDN);
        mpfr_mul(r25505, r25504, r25483, MPFR_RNDN);
        mpfr_set_d(r25506, i, MPFR_RNDN);
        mpfr_add(r25507, r25505, r25506, MPFR_RNDN);
        mpfr_div(r25508, r25496, r25507, MPFR_RNDN);
        mpfr_mul(r25509, r25495, r25508, MPFR_RNDN);
        return mpfr_get_d(r25509, MPFR_RNDN);
}

