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

char *name = "2tan (problem 3.3.2)";

double f_if(float x, float eps) {
        float r24847 = x;
        float r24848 = eps;
        float r24849 = r24847 + r24848;
        float r24850 = tan(r24849);
        float r24851 = tan(r24847);
        float r24852 = r24850 - r24851;
        return r24852;
}

double f_id(double x, double eps) {
        double r24853 = x;
        double r24854 = eps;
        double r24855 = r24853 + r24854;
        double r24856 = tan(r24855);
        double r24857 = tan(r24853);
        double r24858 = r24856 - r24857;
        return r24858;
}


double f_of(float x, float eps) {
        float r24859 = eps;
        float r24860 = 3;
        float r24861 = pow(r24859, r24860);
        float r24862 = x;
        float r24863 = 2;
        float r24864 = pow(r24862, r24863);
        float r24865 = r24861 * r24864;
        float r24866 = pow(r24859, r24863);
        float r24867 = r24866 * r24862;
        float r24868 = r24865 + r24867;
        float r24869 = r24859 + r24868;
        float r24870 = -4.873817797528772e-31;
        bool r24871 = r24869 <= r24870;
        float r24872 = tan(r24859);
        float r24873 = tan(r24862);
        float r24874 = r24872 + r24873;
        float r24875 = 1;
        float r24876 = r24872 * r24873;
        float r24877 = r24875 - r24876;
        float r24878 = r24874 / r24877;
        float r24879 = pow(r24878, r24860);
        float r24880 = cbrt(r24879);
        float r24881 = r24880 - r24873;
        float r24882 = 4.386919576830508e-21;
        bool r24883 = r24869 <= r24882;
        float r24884 = r24873 + r24872;
        float r24885 = cbrt(r24872);
        float r24886 = r24885 * r24885;
        float r24887 = r24873 * r24886;
        float r24888 = r24887 * r24885;
        float r24889 = r24875 - r24888;
        float r24890 = r24884 / r24889;
        float r24891 = r24890 - r24873;
        float r24892 = r24883 ? r24869 : r24891;
        float r24893 = r24871 ? r24881 : r24892;
        return r24893;
}

double f_od(double x, double eps) {
        double r24894 = eps;
        double r24895 = 3;
        double r24896 = pow(r24894, r24895);
        double r24897 = x;
        double r24898 = 2;
        double r24899 = pow(r24897, r24898);
        double r24900 = r24896 * r24899;
        double r24901 = pow(r24894, r24898);
        double r24902 = r24901 * r24897;
        double r24903 = r24900 + r24902;
        double r24904 = r24894 + r24903;
        double r24905 = -4.873817797528772e-31;
        bool r24906 = r24904 <= r24905;
        double r24907 = tan(r24894);
        double r24908 = tan(r24897);
        double r24909 = r24907 + r24908;
        double r24910 = 1;
        double r24911 = r24907 * r24908;
        double r24912 = r24910 - r24911;
        double r24913 = r24909 / r24912;
        double r24914 = pow(r24913, r24895);
        double r24915 = cbrt(r24914);
        double r24916 = r24915 - r24908;
        double r24917 = 4.386919576830508e-21;
        bool r24918 = r24904 <= r24917;
        double r24919 = r24908 + r24907;
        double r24920 = cbrt(r24907);
        double r24921 = r24920 * r24920;
        double r24922 = r24908 * r24921;
        double r24923 = r24922 * r24920;
        double r24924 = r24910 - r24923;
        double r24925 = r24919 / r24924;
        double r24926 = r24925 - r24908;
        double r24927 = r24918 ? r24904 : r24926;
        double r24928 = r24906 ? r24916 : r24927;
        return r24928;
}

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 r24929, r24930, r24931, r24932, r24933, r24934;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(2448);
        mpfr_init(r24929);
        mpfr_init(r24930);
        mpfr_init(r24931);
        mpfr_init(r24932);
        mpfr_init(r24933);
        mpfr_init(r24934);
}

double f_im(double x, double eps) {
        mpfr_set_d(r24929, x, MPFR_RNDN);
        mpfr_set_d(r24930, eps, MPFR_RNDN);
        mpfr_add(r24931, r24929, r24930, MPFR_RNDN);
        mpfr_tan(r24932, r24931, MPFR_RNDN);
        mpfr_tan(r24933, r24929, MPFR_RNDN);
        mpfr_sub(r24934, r24932, r24933, MPFR_RNDN);
        return mpfr_get_d(r24934, MPFR_RNDN);
}

static mpfr_t r24935, r24936, r24937, r24938, r24939, r24940, r24941, r24942, r24943, r24944, r24945, r24946, r24947, r24948, r24949, r24950, r24951, r24952, r24953, r24954, r24955, r24956, r24957, r24958, r24959, r24960, r24961, r24962, r24963, r24964, r24965, r24966, r24967, r24968, r24969;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(2448);
        mpfr_init(r24935);
        mpfr_init_set_str(r24936, "3", 10, MPFR_RNDN);
        mpfr_init(r24937);
        mpfr_init(r24938);
        mpfr_init_set_str(r24939, "2", 10, MPFR_RNDN);
        mpfr_init(r24940);
        mpfr_init(r24941);
        mpfr_init(r24942);
        mpfr_init(r24943);
        mpfr_init(r24944);
        mpfr_init(r24945);
        mpfr_init_set_str(r24946, "-4.873817797528772e-31", 10, MPFR_RNDN);
        mpfr_init(r24947);
        mpfr_init(r24948);
        mpfr_init(r24949);
        mpfr_init(r24950);
        mpfr_init_set_str(r24951, "1", 10, MPFR_RNDN);
        mpfr_init(r24952);
        mpfr_init(r24953);
        mpfr_init(r24954);
        mpfr_init(r24955);
        mpfr_init(r24956);
        mpfr_init(r24957);
        mpfr_init_set_str(r24958, "4.386919576830508e-21", 10, MPFR_RNDN);
        mpfr_init(r24959);
        mpfr_init(r24960);
        mpfr_init(r24961);
        mpfr_init(r24962);
        mpfr_init(r24963);
        mpfr_init(r24964);
        mpfr_init(r24965);
        mpfr_init(r24966);
        mpfr_init(r24967);
        mpfr_init(r24968);
        mpfr_init(r24969);
}

double f_fm(double x, double eps) {
        mpfr_set_d(r24935, eps, MPFR_RNDN);
        ;
        mpfr_pow(r24937, r24935, r24936, MPFR_RNDN);
        mpfr_set_d(r24938, x, MPFR_RNDN);
        ;
        mpfr_pow(r24940, r24938, r24939, MPFR_RNDN);
        mpfr_mul(r24941, r24937, r24940, MPFR_RNDN);
        mpfr_pow(r24942, r24935, r24939, MPFR_RNDN);
        mpfr_mul(r24943, r24942, r24938, MPFR_RNDN);
        mpfr_add(r24944, r24941, r24943, MPFR_RNDN);
        mpfr_add(r24945, r24935, r24944, MPFR_RNDN);
        ;
        mpfr_set_si(r24947, mpfr_cmp(r24945, r24946) <= 0, MPFR_RNDN);
        mpfr_tan(r24948, r24935, MPFR_RNDN);
        mpfr_tan(r24949, r24938, MPFR_RNDN);
        mpfr_add(r24950, r24948, r24949, MPFR_RNDN);
        ;
        mpfr_mul(r24952, r24948, r24949, MPFR_RNDN);
        mpfr_sub(r24953, r24951, r24952, MPFR_RNDN);
        mpfr_div(r24954, r24950, r24953, MPFR_RNDN);
        mpfr_pow(r24955, r24954, r24936, MPFR_RNDN);
        mpfr_cbrt(r24956, r24955, MPFR_RNDN);
        mpfr_sub(r24957, r24956, r24949, MPFR_RNDN);
        ;
        mpfr_set_si(r24959, mpfr_cmp(r24945, r24958) <= 0, MPFR_RNDN);
        mpfr_add(r24960, r24949, r24948, MPFR_RNDN);
        mpfr_cbrt(r24961, r24948, MPFR_RNDN);
        mpfr_mul(r24962, r24961, r24961, MPFR_RNDN);
        mpfr_mul(r24963, r24949, r24962, MPFR_RNDN);
        mpfr_mul(r24964, r24963, r24961, MPFR_RNDN);
        mpfr_sub(r24965, r24951, r24964, MPFR_RNDN);
        mpfr_div(r24966, r24960, r24965, MPFR_RNDN);
        mpfr_sub(r24967, r24966, r24949, MPFR_RNDN);
        if (mpfr_get_si(r24959, MPFR_RNDN)) { mpfr_set(r24968, r24945, MPFR_RNDN); } else { mpfr_set(r24968, r24967, MPFR_RNDN); };
        if (mpfr_get_si(r24947, MPFR_RNDN)) { mpfr_set(r24969, r24957, MPFR_RNDN); } else { mpfr_set(r24969, r24968, MPFR_RNDN); };
        return mpfr_get_d(r24969, MPFR_RNDN);
}

static mpfr_t r24970, r24971, r24972, r24973, r24974, r24975, r24976, r24977, r24978, r24979, r24980, r24981, r24982, r24983, r24984, r24985, r24986, r24987, r24988, r24989, r24990, r24991, r24992, r24993, r24994, r24995, r24996, r24997, r24998, r24999, r25000, r25001, r25002, r25003, r25004;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(2448);
        mpfr_init(r24970);
        mpfr_init_set_str(r24971, "3", 10, MPFR_RNDN);
        mpfr_init(r24972);
        mpfr_init(r24973);
        mpfr_init_set_str(r24974, "2", 10, MPFR_RNDN);
        mpfr_init(r24975);
        mpfr_init(r24976);
        mpfr_init(r24977);
        mpfr_init(r24978);
        mpfr_init(r24979);
        mpfr_init(r24980);
        mpfr_init_set_str(r24981, "-4.873817797528772e-31", 10, MPFR_RNDN);
        mpfr_init(r24982);
        mpfr_init(r24983);
        mpfr_init(r24984);
        mpfr_init(r24985);
        mpfr_init_set_str(r24986, "1", 10, MPFR_RNDN);
        mpfr_init(r24987);
        mpfr_init(r24988);
        mpfr_init(r24989);
        mpfr_init(r24990);
        mpfr_init(r24991);
        mpfr_init(r24992);
        mpfr_init_set_str(r24993, "4.386919576830508e-21", 10, MPFR_RNDN);
        mpfr_init(r24994);
        mpfr_init(r24995);
        mpfr_init(r24996);
        mpfr_init(r24997);
        mpfr_init(r24998);
        mpfr_init(r24999);
        mpfr_init(r25000);
        mpfr_init(r25001);
        mpfr_init(r25002);
        mpfr_init(r25003);
        mpfr_init(r25004);
}

double f_dm(double x, double eps) {
        mpfr_set_d(r24970, eps, MPFR_RNDN);
        ;
        mpfr_pow(r24972, r24970, r24971, MPFR_RNDN);
        mpfr_set_d(r24973, x, MPFR_RNDN);
        ;
        mpfr_pow(r24975, r24973, r24974, MPFR_RNDN);
        mpfr_mul(r24976, r24972, r24975, MPFR_RNDN);
        mpfr_pow(r24977, r24970, r24974, MPFR_RNDN);
        mpfr_mul(r24978, r24977, r24973, MPFR_RNDN);
        mpfr_add(r24979, r24976, r24978, MPFR_RNDN);
        mpfr_add(r24980, r24970, r24979, MPFR_RNDN);
        ;
        mpfr_set_si(r24982, mpfr_cmp(r24980, r24981) <= 0, MPFR_RNDN);
        mpfr_tan(r24983, r24970, MPFR_RNDN);
        mpfr_tan(r24984, r24973, MPFR_RNDN);
        mpfr_add(r24985, r24983, r24984, MPFR_RNDN);
        ;
        mpfr_mul(r24987, r24983, r24984, MPFR_RNDN);
        mpfr_sub(r24988, r24986, r24987, MPFR_RNDN);
        mpfr_div(r24989, r24985, r24988, MPFR_RNDN);
        mpfr_pow(r24990, r24989, r24971, MPFR_RNDN);
        mpfr_cbrt(r24991, r24990, MPFR_RNDN);
        mpfr_sub(r24992, r24991, r24984, MPFR_RNDN);
        ;
        mpfr_set_si(r24994, mpfr_cmp(r24980, r24993) <= 0, MPFR_RNDN);
        mpfr_add(r24995, r24984, r24983, MPFR_RNDN);
        mpfr_cbrt(r24996, r24983, MPFR_RNDN);
        mpfr_mul(r24997, r24996, r24996, MPFR_RNDN);
        mpfr_mul(r24998, r24984, r24997, MPFR_RNDN);
        mpfr_mul(r24999, r24998, r24996, MPFR_RNDN);
        mpfr_sub(r25000, r24986, r24999, MPFR_RNDN);
        mpfr_div(r25001, r24995, r25000, MPFR_RNDN);
        mpfr_sub(r25002, r25001, r24984, MPFR_RNDN);
        if (mpfr_get_si(r24994, MPFR_RNDN)) { mpfr_set(r25003, r24980, MPFR_RNDN); } else { mpfr_set(r25003, r25002, MPFR_RNDN); };
        if (mpfr_get_si(r24982, MPFR_RNDN)) { mpfr_set(r25004, r24992, MPFR_RNDN); } else { mpfr_set(r25004, r25003, MPFR_RNDN); };
        return mpfr_get_d(r25004, MPFR_RNDN);
}

