#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 r9908 = a;
        float r9909 = asin(r9908);
        float r9910 = fmod(r9908, r9909);
        float r9911 = atan(r9910);
        float r9912 = r9908 * r9908;
        float r9913 = pow(r9911, r9912);
        return r9913;
}

double f_id(double a) {
        double r9914 = a;
        double r9915 = asin(r9914);
        double r9916 = fmod(r9914, r9915);
        double r9917 = atan(r9916);
        double r9918 = r9914 * r9914;
        double r9919 = pow(r9917, r9918);
        return r9919;
}


double f_of(float a) {
        float r9920 = a;
        float r9921 = asin(r9920);
        float r9922 = fmod(r9920, r9921);
        float r9923 = atan(r9922);
        float r9924 = r9920 * r9920;
        float r9925 = pow(r9923, r9924);
        return r9925;
}

double f_od(double a) {
        double r9926 = a;
        double r9927 = asin(r9926);
        double r9928 = fmod(r9926, r9927);
        double r9929 = atan(r9928);
        double r9930 = r9926 * r9926;
        double r9931 = pow(r9929, r9930);
        return r9931;
}

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 r9932, r9933, r9934, r9935, r9936, r9937;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(2384);
        mpfr_init(r9932);
        mpfr_init(r9933);
        mpfr_init(r9934);
        mpfr_init(r9935);
        mpfr_init(r9936);
        mpfr_init(r9937);
}

double f_im(double a) {
        mpfr_set_d(r9932, a, MPFR_RNDN);
        mpfr_asin(r9933, r9932, MPFR_RNDN);
        mpfr_fmod(r9934, r9932, r9933, MPFR_RNDN);
        mpfr_atan(r9935, r9934, MPFR_RNDN);
        mpfr_mul(r9936, r9932, r9932, MPFR_RNDN);
        mpfr_pow(r9937, r9935, r9936, MPFR_RNDN);
        return mpfr_get_d(r9937, MPFR_RNDN);
}

static mpfr_t r9938, r9939, r9940, r9941, r9942, r9943;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(2384);
        mpfr_init(r9938);
        mpfr_init(r9939);
        mpfr_init(r9940);
        mpfr_init(r9941);
        mpfr_init(r9942);
        mpfr_init(r9943);
}

double f_fm(double a) {
        mpfr_set_d(r9938, a, MPFR_RNDN);
        mpfr_asin(r9939, r9938, MPFR_RNDN);
        mpfr_fmod(r9940, r9938, r9939, MPFR_RNDN);
        mpfr_atan(r9941, r9940, MPFR_RNDN);
        mpfr_mul(r9942, r9938, r9938, MPFR_RNDN);
        mpfr_pow(r9943, r9941, r9942, MPFR_RNDN);
        return mpfr_get_d(r9943, MPFR_RNDN);
}

static mpfr_t r9944, r9945, r9946, r9947, r9948, r9949;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(2384);
        mpfr_init(r9944);
        mpfr_init(r9945);
        mpfr_init(r9946);
        mpfr_init(r9947);
        mpfr_init(r9948);
        mpfr_init(r9949);
}

double f_dm(double a) {
        mpfr_set_d(r9944, a, MPFR_RNDN);
        mpfr_asin(r9945, r9944, MPFR_RNDN);
        mpfr_fmod(r9946, r9944, r9945, MPFR_RNDN);
        mpfr_atan(r9947, r9946, MPFR_RNDN);
        mpfr_mul(r9948, r9944, r9944, MPFR_RNDN);
        mpfr_pow(r9949, r9947, r9948, MPFR_RNDN);
        return mpfr_get_d(r9949, MPFR_RNDN);
}

