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

char *name = "Fuzzer 001";

double f_if(float a) {
        float r27107 = a;
        float r27108 = acos(r27107);
        float r27109 = -r27108;
        float r27110 = r27107 / r27109;
        return r27110;
}

double f_id(double a) {
        double r27111 = a;
        double r27112 = acos(r27111);
        double r27113 = -r27112;
        double r27114 = r27111 / r27113;
        return r27114;
}


double f_of(float a) {
        float r27115 = a;
        float r27116 = acos(r27115);
        float r27117 = -r27116;
        float r27118 = r27115 / r27117;
        return r27118;
}

double f_od(double a) {
        double r27119 = a;
        double r27120 = acos(r27119);
        double r27121 = -r27120;
        double r27122 = r27119 / r27121;
        return r27122;
}

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 r27123, r27124, r27125, r27126;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init(r27123);
        mpfr_init(r27124);
        mpfr_init(r27125);
        mpfr_init(r27126);
}

double f_im(double a) {
        mpfr_set_d(r27123, a, MPFR_RNDN);
        mpfr_acos(r27124, r27123, MPFR_RNDN);
        mpfr_neg(r27125, r27124, MPFR_RNDN);
        mpfr_div(r27126, r27123, r27125, MPFR_RNDN);
        return mpfr_get_d(r27126, MPFR_RNDN);
}

static mpfr_t r27127, r27128, r27129, r27130;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r27127);
        mpfr_init(r27128);
        mpfr_init(r27129);
        mpfr_init(r27130);
}

double f_fm(double a) {
        mpfr_set_d(r27127, a, MPFR_RNDN);
        mpfr_acos(r27128, r27127, MPFR_RNDN);
        mpfr_neg(r27129, r27128, MPFR_RNDN);
        mpfr_div(r27130, r27127, r27129, MPFR_RNDN);
        return mpfr_get_d(r27130, MPFR_RNDN);
}

static mpfr_t r27131, r27132, r27133, r27134;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r27131);
        mpfr_init(r27132);
        mpfr_init(r27133);
        mpfr_init(r27134);
}

double f_dm(double a) {
        mpfr_set_d(r27131, a, MPFR_RNDN);
        mpfr_acos(r27132, r27131, MPFR_RNDN);
        mpfr_neg(r27133, r27132, MPFR_RNDN);
        mpfr_div(r27134, r27131, r27133, MPFR_RNDN);
        return mpfr_get_d(r27134, MPFR_RNDN);
}

