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

char *name = "Toniolo and Linder, Equation (7)";

double f_if(float x, float l, float t) {
        float r20948 = 2;
        float r20949 = sqrt(r20948);
        float r20950 = t;
        float r20951 = r20949 * r20950;
        float r20952 = x;
        float r20953 = 1;
        float r20954 = r20952 + r20953;
        float r20955 = r20952 - r20953;
        float r20956 = r20954 / r20955;
        float r20957 = l;
        float r20958 = r20957 * r20957;
        float r20959 = r20950 * r20950;
        float r20960 = r20948 * r20959;
        float r20961 = r20958 + r20960;
        float r20962 = r20956 * r20961;
        float r20963 = r20962 - r20958;
        float r20964 = sqrt(r20963);
        float r20965 = r20951 / r20964;
        return r20965;
}

double f_id(double x, double l, double t) {
        double r20966 = 2;
        double r20967 = sqrt(r20966);
        double r20968 = t;
        double r20969 = r20967 * r20968;
        double r20970 = x;
        double r20971 = 1;
        double r20972 = r20970 + r20971;
        double r20973 = r20970 - r20971;
        double r20974 = r20972 / r20973;
        double r20975 = l;
        double r20976 = r20975 * r20975;
        double r20977 = r20968 * r20968;
        double r20978 = r20966 * r20977;
        double r20979 = r20976 + r20978;
        double r20980 = r20974 * r20979;
        double r20981 = r20980 - r20976;
        double r20982 = sqrt(r20981);
        double r20983 = r20969 / r20982;
        return r20983;
}


double f_of(float x, float l, float t) {
        float r20984 = t;
        float r20985 = -1.0262212597693044e+99;
        bool r20986 = r20984 <= r20985;
        float r20987 = 2;
        float r20988 = sqrt(r20987);
        float r20989 = r20984 * r20988;
        float r20990 = x;
        float r20991 = r20990 * r20990;
        float r20992 = r20984 / r20991;
        float r20993 = 1;
        float r20994 = r20993 / r20988;
        float r20995 = r20992 * r20994;
        float r20996 = r20987 / r20988;
        float r20997 = r20984 / r20990;
        float r20998 = fma(r20996, r20997, r20989);
        float r20999 = fma(r20996, r20992, r20998);
        float r21000 = r20995 - r20999;
        float r21001 = r20989 / r21000;
        float r21002 = -4.4287023113340517e-159;
        bool r21003 = r20984 <= r21002;
        float r21004 = sqrt(r20988);
        float r21005 = r20984 * r21004;
        float r21006 = r21005 * r21004;
        float r21007 = l;
        float r21008 = r21007 / r20990;
        float r21009 = r20984 * r20984;
        float r21010 = fma(r21008, r21007, r21009);
        float r21011 = 4;
        float r21012 = r20990 / r21011;
        float r21013 = r21009 / r21012;
        float r21014 = fma(r21010, r20987, r21013);
        float r21015 = sqrt(r21014);
        float r21016 = r21006 / r21015;
        float r21017 = -1.464599026626934e-260;
        bool r21018 = r20984 <= r21017;
        float r21019 = 9.394947846988656e+111;
        bool r21020 = r20984 <= r21019;
        float r21021 = r20989 / r21015;
        float r21022 = r20984 / r20988;
        float r21023 = r20987 / r20990;
        float r21024 = fma(r21022, r21023, r20989);
        float r21025 = r20996 - r20994;
        float r21026 = r20992 * r21025;
        float r21027 = r21024 + r21026;
        float r21028 = r20989 / r21027;
        float r21029 = r21020 ? r21021 : r21028;
        float r21030 = r21018 ? r21001 : r21029;
        float r21031 = r21003 ? r21016 : r21030;
        float r21032 = r20986 ? r21001 : r21031;
        return r21032;
}

double f_od(double x, double l, double t) {
        double r21033 = t;
        double r21034 = -1.0262212597693044e+99;
        bool r21035 = r21033 <= r21034;
        double r21036 = 2;
        double r21037 = sqrt(r21036);
        double r21038 = r21033 * r21037;
        double r21039 = x;
        double r21040 = r21039 * r21039;
        double r21041 = r21033 / r21040;
        double r21042 = 1;
        double r21043 = r21042 / r21037;
        double r21044 = r21041 * r21043;
        double r21045 = r21036 / r21037;
        double r21046 = r21033 / r21039;
        double r21047 = fma(r21045, r21046, r21038);
        double r21048 = fma(r21045, r21041, r21047);
        double r21049 = r21044 - r21048;
        double r21050 = r21038 / r21049;
        double r21051 = -4.4287023113340517e-159;
        bool r21052 = r21033 <= r21051;
        double r21053 = sqrt(r21037);
        double r21054 = r21033 * r21053;
        double r21055 = r21054 * r21053;
        double r21056 = l;
        double r21057 = r21056 / r21039;
        double r21058 = r21033 * r21033;
        double r21059 = fma(r21057, r21056, r21058);
        double r21060 = 4;
        double r21061 = r21039 / r21060;
        double r21062 = r21058 / r21061;
        double r21063 = fma(r21059, r21036, r21062);
        double r21064 = sqrt(r21063);
        double r21065 = r21055 / r21064;
        double r21066 = -1.464599026626934e-260;
        bool r21067 = r21033 <= r21066;
        double r21068 = 9.394947846988656e+111;
        bool r21069 = r21033 <= r21068;
        double r21070 = r21038 / r21064;
        double r21071 = r21033 / r21037;
        double r21072 = r21036 / r21039;
        double r21073 = fma(r21071, r21072, r21038);
        double r21074 = r21045 - r21043;
        double r21075 = r21041 * r21074;
        double r21076 = r21073 + r21075;
        double r21077 = r21038 / r21076;
        double r21078 = r21069 ? r21070 : r21077;
        double r21079 = r21067 ? r21050 : r21078;
        double r21080 = r21052 ? r21065 : r21079;
        double r21081 = r21035 ? r21050 : r21080;
        return r21081;
}

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 r21082, r21083, r21084, r21085, r21086, r21087, r21088, r21089, r21090, r21091, r21092, r21093, r21094, r21095, r21096, r21097, r21098, r21099;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1424);
        mpfr_init_set_str(r21082, "2", 10, MPFR_RNDN);
        mpfr_init(r21083);
        mpfr_init(r21084);
        mpfr_init(r21085);
        mpfr_init(r21086);
        mpfr_init_set_str(r21087, "1", 10, MPFR_RNDN);
        mpfr_init(r21088);
        mpfr_init(r21089);
        mpfr_init(r21090);
        mpfr_init(r21091);
        mpfr_init(r21092);
        mpfr_init(r21093);
        mpfr_init(r21094);
        mpfr_init(r21095);
        mpfr_init(r21096);
        mpfr_init(r21097);
        mpfr_init(r21098);
        mpfr_init(r21099);
}

double f_im(double x, double l, double t) {
        ;
        mpfr_sqrt(r21083, r21082, MPFR_RNDN);
        mpfr_set_d(r21084, t, MPFR_RNDN);
        mpfr_mul(r21085, r21083, r21084, MPFR_RNDN);
        mpfr_set_d(r21086, x, MPFR_RNDN);
        ;
        mpfr_add(r21088, r21086, r21087, MPFR_RNDN);
        mpfr_sub(r21089, r21086, r21087, MPFR_RNDN);
        mpfr_div(r21090, r21088, r21089, MPFR_RNDN);
        mpfr_set_d(r21091, l, MPFR_RNDN);
        mpfr_mul(r21092, r21091, r21091, MPFR_RNDN);
        mpfr_mul(r21093, r21084, r21084, MPFR_RNDN);
        mpfr_mul(r21094, r21082, r21093, MPFR_RNDN);
        mpfr_add(r21095, r21092, r21094, MPFR_RNDN);
        mpfr_mul(r21096, r21090, r21095, MPFR_RNDN);
        mpfr_sub(r21097, r21096, r21092, MPFR_RNDN);
        mpfr_sqrt(r21098, r21097, MPFR_RNDN);
        mpfr_div(r21099, r21085, r21098, MPFR_RNDN);
        return mpfr_get_d(r21099, MPFR_RNDN);
}

static mpfr_t r21100, r21101, r21102, r21103, r21104, r21105, r21106, r21107, r21108, r21109, r21110, r21111, r21112, r21113, r21114, r21115, r21116, r21117, r21118, r21119, r21120, r21121, r21122, r21123, r21124, r21125, r21126, r21127, r21128, r21129, r21130, r21131, r21132, r21133, r21134, r21135, r21136, r21137, r21138, r21139, r21140, r21141, r21142, r21143, r21144, r21145, r21146, r21147, r21148;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r21100);
        mpfr_init_set_str(r21101, "-1.0262212597693044e+99", 10, MPFR_RNDN);
        mpfr_init(r21102);
        mpfr_init_set_str(r21103, "2", 10, MPFR_RNDN);
        mpfr_init(r21104);
        mpfr_init(r21105);
        mpfr_init(r21106);
        mpfr_init(r21107);
        mpfr_init(r21108);
        mpfr_init_set_str(r21109, "1", 10, MPFR_RNDN);
        mpfr_init(r21110);
        mpfr_init(r21111);
        mpfr_init(r21112);
        mpfr_init(r21113);
        mpfr_init(r21114);
        mpfr_init(r21115);
        mpfr_init(r21116);
        mpfr_init(r21117);
        mpfr_init_set_str(r21118, "-4.4287023113340517e-159", 10, MPFR_RNDN);
        mpfr_init(r21119);
        mpfr_init(r21120);
        mpfr_init(r21121);
        mpfr_init(r21122);
        mpfr_init(r21123);
        mpfr_init(r21124);
        mpfr_init(r21125);
        mpfr_init(r21126);
        mpfr_init_set_str(r21127, "4", 10, MPFR_RNDN);
        mpfr_init(r21128);
        mpfr_init(r21129);
        mpfr_init(r21130);
        mpfr_init(r21131);
        mpfr_init(r21132);
        mpfr_init_set_str(r21133, "-1.464599026626934e-260", 10, MPFR_RNDN);
        mpfr_init(r21134);
        mpfr_init_set_str(r21135, "9.394947846988656e+111", 10, MPFR_RNDN);
        mpfr_init(r21136);
        mpfr_init(r21137);
        mpfr_init(r21138);
        mpfr_init(r21139);
        mpfr_init(r21140);
        mpfr_init(r21141);
        mpfr_init(r21142);
        mpfr_init(r21143);
        mpfr_init(r21144);
        mpfr_init(r21145);
        mpfr_init(r21146);
        mpfr_init(r21147);
        mpfr_init(r21148);
}

double f_fm(double x, double l, double t) {
        mpfr_set_d(r21100, t, MPFR_RNDN);
        ;
        mpfr_set_si(r21102, mpfr_cmp(r21100, r21101) <= 0, MPFR_RNDN);
        ;
        mpfr_sqrt(r21104, r21103, MPFR_RNDN);
        mpfr_mul(r21105, r21100, r21104, MPFR_RNDN);
        mpfr_set_d(r21106, x, MPFR_RNDN);
        mpfr_mul(r21107, r21106, r21106, MPFR_RNDN);
        mpfr_div(r21108, r21100, r21107, MPFR_RNDN);
        ;
        mpfr_div(r21110, r21109, r21104, MPFR_RNDN);
        mpfr_mul(r21111, r21108, r21110, MPFR_RNDN);
        mpfr_div(r21112, r21103, r21104, MPFR_RNDN);
        mpfr_div(r21113, r21100, r21106, MPFR_RNDN);
        mpfr_fma(r21114, r21112, r21113, r21105, MPFR_RNDN);
        mpfr_fma(r21115, r21112, r21108, r21114, MPFR_RNDN);
        mpfr_sub(r21116, r21111, r21115, MPFR_RNDN);
        mpfr_div(r21117, r21105, r21116, MPFR_RNDN);
        ;
        mpfr_set_si(r21119, mpfr_cmp(r21100, r21118) <= 0, MPFR_RNDN);
        mpfr_sqrt(r21120, r21104, MPFR_RNDN);
        mpfr_mul(r21121, r21100, r21120, MPFR_RNDN);
        mpfr_mul(r21122, r21121, r21120, MPFR_RNDN);
        mpfr_set_d(r21123, l, MPFR_RNDN);
        mpfr_div(r21124, r21123, r21106, MPFR_RNDN);
        mpfr_mul(r21125, r21100, r21100, MPFR_RNDN);
        mpfr_fma(r21126, r21124, r21123, r21125, MPFR_RNDN);
        ;
        mpfr_div(r21128, r21106, r21127, MPFR_RNDN);
        mpfr_div(r21129, r21125, r21128, MPFR_RNDN);
        mpfr_fma(r21130, r21126, r21103, r21129, MPFR_RNDN);
        mpfr_sqrt(r21131, r21130, MPFR_RNDN);
        mpfr_div(r21132, r21122, r21131, MPFR_RNDN);
        ;
        mpfr_set_si(r21134, mpfr_cmp(r21100, r21133) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r21136, mpfr_cmp(r21100, r21135) <= 0, MPFR_RNDN);
        mpfr_div(r21137, r21105, r21131, MPFR_RNDN);
        mpfr_div(r21138, r21100, r21104, MPFR_RNDN);
        mpfr_div(r21139, r21103, r21106, MPFR_RNDN);
        mpfr_fma(r21140, r21138, r21139, r21105, MPFR_RNDN);
        mpfr_sub(r21141, r21112, r21110, MPFR_RNDN);
        mpfr_mul(r21142, r21108, r21141, MPFR_RNDN);
        mpfr_add(r21143, r21140, r21142, MPFR_RNDN);
        mpfr_div(r21144, r21105, r21143, MPFR_RNDN);
        if (mpfr_get_si(r21136, MPFR_RNDN)) { mpfr_set(r21145, r21137, MPFR_RNDN); } else { mpfr_set(r21145, r21144, MPFR_RNDN); };
        if (mpfr_get_si(r21134, MPFR_RNDN)) { mpfr_set(r21146, r21117, MPFR_RNDN); } else { mpfr_set(r21146, r21145, MPFR_RNDN); };
        if (mpfr_get_si(r21119, MPFR_RNDN)) { mpfr_set(r21147, r21132, MPFR_RNDN); } else { mpfr_set(r21147, r21146, MPFR_RNDN); };
        if (mpfr_get_si(r21102, MPFR_RNDN)) { mpfr_set(r21148, r21117, MPFR_RNDN); } else { mpfr_set(r21148, r21147, MPFR_RNDN); };
        return mpfr_get_d(r21148, MPFR_RNDN);
}

static mpfr_t r21149, r21150, r21151, r21152, r21153, r21154, r21155, r21156, r21157, r21158, r21159, r21160, r21161, r21162, r21163, r21164, r21165, r21166, r21167, r21168, r21169, r21170, r21171, r21172, r21173, r21174, r21175, r21176, r21177, r21178, r21179, r21180, r21181, r21182, r21183, r21184, r21185, r21186, r21187, r21188, r21189, r21190, r21191, r21192, r21193, r21194, r21195, r21196, r21197;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1424);
        mpfr_init(r21149);
        mpfr_init_set_str(r21150, "-1.0262212597693044e+99", 10, MPFR_RNDN);
        mpfr_init(r21151);
        mpfr_init_set_str(r21152, "2", 10, MPFR_RNDN);
        mpfr_init(r21153);
        mpfr_init(r21154);
        mpfr_init(r21155);
        mpfr_init(r21156);
        mpfr_init(r21157);
        mpfr_init_set_str(r21158, "1", 10, MPFR_RNDN);
        mpfr_init(r21159);
        mpfr_init(r21160);
        mpfr_init(r21161);
        mpfr_init(r21162);
        mpfr_init(r21163);
        mpfr_init(r21164);
        mpfr_init(r21165);
        mpfr_init(r21166);
        mpfr_init_set_str(r21167, "-4.4287023113340517e-159", 10, MPFR_RNDN);
        mpfr_init(r21168);
        mpfr_init(r21169);
        mpfr_init(r21170);
        mpfr_init(r21171);
        mpfr_init(r21172);
        mpfr_init(r21173);
        mpfr_init(r21174);
        mpfr_init(r21175);
        mpfr_init_set_str(r21176, "4", 10, MPFR_RNDN);
        mpfr_init(r21177);
        mpfr_init(r21178);
        mpfr_init(r21179);
        mpfr_init(r21180);
        mpfr_init(r21181);
        mpfr_init_set_str(r21182, "-1.464599026626934e-260", 10, MPFR_RNDN);
        mpfr_init(r21183);
        mpfr_init_set_str(r21184, "9.394947846988656e+111", 10, MPFR_RNDN);
        mpfr_init(r21185);
        mpfr_init(r21186);
        mpfr_init(r21187);
        mpfr_init(r21188);
        mpfr_init(r21189);
        mpfr_init(r21190);
        mpfr_init(r21191);
        mpfr_init(r21192);
        mpfr_init(r21193);
        mpfr_init(r21194);
        mpfr_init(r21195);
        mpfr_init(r21196);
        mpfr_init(r21197);
}

double f_dm(double x, double l, double t) {
        mpfr_set_d(r21149, t, MPFR_RNDN);
        ;
        mpfr_set_si(r21151, mpfr_cmp(r21149, r21150) <= 0, MPFR_RNDN);
        ;
        mpfr_sqrt(r21153, r21152, MPFR_RNDN);
        mpfr_mul(r21154, r21149, r21153, MPFR_RNDN);
        mpfr_set_d(r21155, x, MPFR_RNDN);
        mpfr_mul(r21156, r21155, r21155, MPFR_RNDN);
        mpfr_div(r21157, r21149, r21156, MPFR_RNDN);
        ;
        mpfr_div(r21159, r21158, r21153, MPFR_RNDN);
        mpfr_mul(r21160, r21157, r21159, MPFR_RNDN);
        mpfr_div(r21161, r21152, r21153, MPFR_RNDN);
        mpfr_div(r21162, r21149, r21155, MPFR_RNDN);
        mpfr_fma(r21163, r21161, r21162, r21154, MPFR_RNDN);
        mpfr_fma(r21164, r21161, r21157, r21163, MPFR_RNDN);
        mpfr_sub(r21165, r21160, r21164, MPFR_RNDN);
        mpfr_div(r21166, r21154, r21165, MPFR_RNDN);
        ;
        mpfr_set_si(r21168, mpfr_cmp(r21149, r21167) <= 0, MPFR_RNDN);
        mpfr_sqrt(r21169, r21153, MPFR_RNDN);
        mpfr_mul(r21170, r21149, r21169, MPFR_RNDN);
        mpfr_mul(r21171, r21170, r21169, MPFR_RNDN);
        mpfr_set_d(r21172, l, MPFR_RNDN);
        mpfr_div(r21173, r21172, r21155, MPFR_RNDN);
        mpfr_mul(r21174, r21149, r21149, MPFR_RNDN);
        mpfr_fma(r21175, r21173, r21172, r21174, MPFR_RNDN);
        ;
        mpfr_div(r21177, r21155, r21176, MPFR_RNDN);
        mpfr_div(r21178, r21174, r21177, MPFR_RNDN);
        mpfr_fma(r21179, r21175, r21152, r21178, MPFR_RNDN);
        mpfr_sqrt(r21180, r21179, MPFR_RNDN);
        mpfr_div(r21181, r21171, r21180, MPFR_RNDN);
        ;
        mpfr_set_si(r21183, mpfr_cmp(r21149, r21182) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r21185, mpfr_cmp(r21149, r21184) <= 0, MPFR_RNDN);
        mpfr_div(r21186, r21154, r21180, MPFR_RNDN);
        mpfr_div(r21187, r21149, r21153, MPFR_RNDN);
        mpfr_div(r21188, r21152, r21155, MPFR_RNDN);
        mpfr_fma(r21189, r21187, r21188, r21154, MPFR_RNDN);
        mpfr_sub(r21190, r21161, r21159, MPFR_RNDN);
        mpfr_mul(r21191, r21157, r21190, MPFR_RNDN);
        mpfr_add(r21192, r21189, r21191, MPFR_RNDN);
        mpfr_div(r21193, r21154, r21192, MPFR_RNDN);
        if (mpfr_get_si(r21185, MPFR_RNDN)) { mpfr_set(r21194, r21186, MPFR_RNDN); } else { mpfr_set(r21194, r21193, MPFR_RNDN); };
        if (mpfr_get_si(r21183, MPFR_RNDN)) { mpfr_set(r21195, r21166, MPFR_RNDN); } else { mpfr_set(r21195, r21194, MPFR_RNDN); };
        if (mpfr_get_si(r21168, MPFR_RNDN)) { mpfr_set(r21196, r21181, MPFR_RNDN); } else { mpfr_set(r21196, r21195, MPFR_RNDN); };
        if (mpfr_get_si(r21151, MPFR_RNDN)) { mpfr_set(r21197, r21166, MPFR_RNDN); } else { mpfr_set(r21197, r21196, MPFR_RNDN); };
        return mpfr_get_d(r21197, MPFR_RNDN);
}

