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

char *name = "Fuzzer 002";

double f_if(float a) {
        float r26533 = a;
        float r26534 = asin(r26533);
        float r26535 = fmod(r26533, r26534);
        float r26536 = atan(r26535);
        float r26537 = r26533 * r26533;
        float r26538 = pow(r26536, r26537);
        return r26538;
}

double f_id(double a) {
        double r26539 = a;
        double r26540 = asin(r26539);
        double r26541 = fmod(r26539, r26540);
        double r26542 = atan(r26541);
        double r26543 = r26539 * r26539;
        double r26544 = pow(r26542, r26543);
        return r26544;
}


double f_of(float a) {
        float r26545 = a;
        float r26546 = asin(r26545);
        float r26547 = fmod(r26545, r26546);
        float r26548 = atan(r26547);
        float r26549 = r26545 * r26545;
        float r26550 = pow(r26548, r26549);
        return r26550;
}

double f_od(double a) {
        double r26551 = a;
        double r26552 = asin(r26551);
        double r26553 = fmod(r26551, r26552);
        double r26554 = atan(r26553);
        double r26555 = r26551 * r26551;
        double r26556 = pow(r26554, r26555);
        return r26556;
}

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 r26557, r26558, r26559, r26560, r26561, r26562;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(2384);
        mpfr_init(r26557);
        mpfr_init(r26558);
        mpfr_init(r26559);
        mpfr_init(r26560);
        mpfr_init(r26561);
        mpfr_init(r26562);
}

double f_im(double a) {
        mpfr_set_d(r26557, a, MPFR_RNDN);
        mpfr_asin(r26558, r26557, MPFR_RNDN);
        mpfr_fmod(r26559, r26557, r26558, MPFR_RNDN);
        mpfr_atan(r26560, r26559, MPFR_RNDN);
        mpfr_mul(r26561, r26557, r26557, MPFR_RNDN);
        mpfr_pow(r26562, r26560, r26561, MPFR_RNDN);
        return mpfr_get_d(r26562, MPFR_RNDN);
}

static mpfr_t r26563, r26564, r26565, r26566, r26567, r26568;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(2384);
        mpfr_init(r26563);
        mpfr_init(r26564);
        mpfr_init(r26565);
        mpfr_init(r26566);
        mpfr_init(r26567);
        mpfr_init(r26568);
}

double f_fm(double a) {
        mpfr_set_d(r26563, a, MPFR_RNDN);
        mpfr_asin(r26564, r26563, MPFR_RNDN);
        mpfr_fmod(r26565, r26563, r26564, MPFR_RNDN);
        mpfr_atan(r26566, r26565, MPFR_RNDN);
        mpfr_mul(r26567, r26563, r26563, MPFR_RNDN);
        mpfr_pow(r26568, r26566, r26567, MPFR_RNDN);
        return mpfr_get_d(r26568, MPFR_RNDN);
}

static mpfr_t r26569, r26570, r26571, r26572, r26573, r26574;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(2384);
        mpfr_init(r26569);
        mpfr_init(r26570);
        mpfr_init(r26571);
        mpfr_init(r26572);
        mpfr_init(r26573);
        mpfr_init(r26574);
}

double f_dm(double a) {
        mpfr_set_d(r26569, a, MPFR_RNDN);
        mpfr_asin(r26570, r26569, MPFR_RNDN);
        mpfr_fmod(r26571, r26569, r26570, MPFR_RNDN);
        mpfr_atan(r26572, r26571, MPFR_RNDN);
        mpfr_mul(r26573, r26569, r26569, MPFR_RNDN);
        mpfr_pow(r26574, r26572, r26573, MPFR_RNDN);
        return mpfr_get_d(r26574, MPFR_RNDN);
}

