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

char *name = "invcot (example 3.9)";

double f_if(float x) {
        float r24074 = 1;
        float r24075 = x;
        float r24076 = r24074 / r24075;
        float r24077 = tan(r24075);
        float r24078 = r24074 / r24077;
        float r24079 = r24076 - r24078;
        return r24079;
}

double f_id(double x) {
        double r24080 = 1;
        double r24081 = x;
        double r24082 = r24080 / r24081;
        double r24083 = tan(r24081);
        double r24084 = r24080 / r24083;
        double r24085 = r24082 - r24084;
        return r24085;
}


double f_of(float x) {
        float r24086 = 1/45;
        float r24087 = x;
        float r24088 = 3;
        float r24089 = pow(r24087, r24088);
        float r24090 = r24086 * r24089;
        float r24091 = 2/945;
        float r24092 = 5;
        float r24093 = pow(r24087, r24092);
        float r24094 = r24091 * r24093;
        float r24095 = 1/3;
        float r24096 = r24095 * r24087;
        float r24097 = r24094 + r24096;
        float r24098 = r24090 + r24097;
        return r24098;
}

double f_od(double x) {
        double r24099 = 1/45;
        double r24100 = x;
        double r24101 = 3;
        double r24102 = pow(r24100, r24101);
        double r24103 = r24099 * r24102;
        double r24104 = 2/945;
        double r24105 = 5;
        double r24106 = pow(r24100, r24105);
        double r24107 = r24104 * r24106;
        double r24108 = 1/3;
        double r24109 = r24108 * r24100;
        double r24110 = r24107 + r24109;
        double r24111 = r24103 + r24110;
        return r24111;
}

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 r24112, r24113, r24114, r24115, r24116, r24117;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(2448);
        mpfr_init_set_str(r24112, "1", 10, MPFR_RNDN);
        mpfr_init(r24113);
        mpfr_init(r24114);
        mpfr_init(r24115);
        mpfr_init(r24116);
        mpfr_init(r24117);
}

double f_im(double x) {
        ;
        mpfr_set_d(r24113, x, MPFR_RNDN);
        mpfr_div(r24114, r24112, r24113, MPFR_RNDN);
        mpfr_tan(r24115, r24113, MPFR_RNDN);
        mpfr_div(r24116, r24112, r24115, MPFR_RNDN);
        mpfr_sub(r24117, r24114, r24116, MPFR_RNDN);
        return mpfr_get_d(r24117, MPFR_RNDN);
}

static mpfr_t r24118, r24119, r24120, r24121, r24122, r24123, r24124, r24125, r24126, r24127, r24128, r24129, r24130;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(2448);
        mpfr_init_set_str(r24118, "1/45", 10, MPFR_RNDN);
        mpfr_init(r24119);
        mpfr_init_set_str(r24120, "3", 10, MPFR_RNDN);
        mpfr_init(r24121);
        mpfr_init(r24122);
        mpfr_init_set_str(r24123, "2/945", 10, MPFR_RNDN);
        mpfr_init_set_str(r24124, "5", 10, MPFR_RNDN);
        mpfr_init(r24125);
        mpfr_init(r24126);
        mpfr_init_set_str(r24127, "1/3", 10, MPFR_RNDN);
        mpfr_init(r24128);
        mpfr_init(r24129);
        mpfr_init(r24130);
}

double f_fm(double x) {
        ;
        mpfr_set_d(r24119, x, MPFR_RNDN);
        ;
        mpfr_pow(r24121, r24119, r24120, MPFR_RNDN);
        mpfr_mul(r24122, r24118, r24121, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r24125, r24119, r24124, MPFR_RNDN);
        mpfr_mul(r24126, r24123, r24125, MPFR_RNDN);
        ;
        mpfr_mul(r24128, r24127, r24119, MPFR_RNDN);
        mpfr_add(r24129, r24126, r24128, MPFR_RNDN);
        mpfr_add(r24130, r24122, r24129, MPFR_RNDN);
        return mpfr_get_d(r24130, MPFR_RNDN);
}

static mpfr_t r24131, r24132, r24133, r24134, r24135, r24136, r24137, r24138, r24139, r24140, r24141, r24142, r24143;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(2448);
        mpfr_init_set_str(r24131, "1/45", 10, MPFR_RNDN);
        mpfr_init(r24132);
        mpfr_init_set_str(r24133, "3", 10, MPFR_RNDN);
        mpfr_init(r24134);
        mpfr_init(r24135);
        mpfr_init_set_str(r24136, "2/945", 10, MPFR_RNDN);
        mpfr_init_set_str(r24137, "5", 10, MPFR_RNDN);
        mpfr_init(r24138);
        mpfr_init(r24139);
        mpfr_init_set_str(r24140, "1/3", 10, MPFR_RNDN);
        mpfr_init(r24141);
        mpfr_init(r24142);
        mpfr_init(r24143);
}

double f_dm(double x) {
        ;
        mpfr_set_d(r24132, x, MPFR_RNDN);
        ;
        mpfr_pow(r24134, r24132, r24133, MPFR_RNDN);
        mpfr_mul(r24135, r24131, r24134, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r24138, r24132, r24137, MPFR_RNDN);
        mpfr_mul(r24139, r24136, r24138, MPFR_RNDN);
        ;
        mpfr_mul(r24141, r24140, r24132, MPFR_RNDN);
        mpfr_add(r24142, r24139, r24141, MPFR_RNDN);
        mpfr_add(r24143, r24135, r24142, MPFR_RNDN);
        return mpfr_get_d(r24143, MPFR_RNDN);
}

