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

char *name = "math.cube on real";

double f_if(float x) {
        float r12114 = x;
        float r12115 = r12114 * r12114;
        float r12116 = r12115 * r12114;
        return r12116;
}

double f_id(double x) {
        double r12117 = x;
        double r12118 = r12117 * r12117;
        double r12119 = r12118 * r12117;
        return r12119;
}


double f_of(float x) {
        float r12120 = x;
        float r12121 = 3.0f;
        float r12122 = pow(r12120, r12121);
        return r12122;
}

double f_od(double x) {
        double r12123 = x;
        double r12124 = 3.0;
        double r12125 = pow(r12123, r12124);
        return r12125;
}

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 r12126, r12127, r12128;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r12126);
        mpfr_init(r12127);
        mpfr_init(r12128);
}

double f_im(double x) {
        mpfr_set_d(r12126, x, MPFR_RNDN);
        mpfr_mul(r12127, r12126, r12126, MPFR_RNDN);
        mpfr_mul(r12128, r12127, r12126, MPFR_RNDN);
        return mpfr_get_d(r12128, MPFR_RNDN);
}

static mpfr_t r12129, r12130, r12131;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r12129);
        mpfr_init_set_str(r12130, "3", 10, MPFR_RNDN);
        mpfr_init(r12131);
}

double f_fm(double x) {
        mpfr_set_d(r12129, x, MPFR_RNDN);
        ;
        mpfr_pow(r12131, r12129, r12130, MPFR_RNDN);
        return mpfr_get_d(r12131, MPFR_RNDN);
}

static mpfr_t r12132, r12133, r12134;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r12132);
        mpfr_init_set_str(r12133, "3", 10, MPFR_RNDN);
        mpfr_init(r12134);
}

double f_dm(double x) {
        mpfr_set_d(r12132, x, MPFR_RNDN);
        ;
        mpfr_pow(r12134, r12132, r12133, MPFR_RNDN);
        return mpfr_get_d(r12134, MPFR_RNDN);
}

