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

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

double f_if(float t, float l, float k) {
        float r25302 = 2;
        float r25303 = t;
        float r25304 = 3;
        float r25305 = pow(r25303, r25304);
        float r25306 = l;
        float r25307 = r25306 * r25306;
        float r25308 = r25305 / r25307;
        float r25309 = k;
        float r25310 = sin(r25309);
        float r25311 = r25308 * r25310;
        float r25312 = tan(r25309);
        float r25313 = r25311 * r25312;
        float r25314 = 1;
        float r25315 = r25309 / r25303;
        float r25316 = pow(r25315, r25302);
        float r25317 = r25314 + r25316;
        float r25318 = r25317 + r25314;
        float r25319 = r25313 * r25318;
        float r25320 = r25302 / r25319;
        return r25320;
}

double f_id(double t, double l, double k) {
        double r25321 = 2;
        double r25322 = t;
        double r25323 = 3;
        double r25324 = pow(r25322, r25323);
        double r25325 = l;
        double r25326 = r25325 * r25325;
        double r25327 = r25324 / r25326;
        double r25328 = k;
        double r25329 = sin(r25328);
        double r25330 = r25327 * r25329;
        double r25331 = tan(r25328);
        double r25332 = r25330 * r25331;
        double r25333 = 1;
        double r25334 = r25328 / r25322;
        double r25335 = pow(r25334, r25321);
        double r25336 = r25333 + r25335;
        double r25337 = r25336 + r25333;
        double r25338 = r25332 * r25337;
        double r25339 = r25321 / r25338;
        return r25339;
}


double f_of(float t, float l, float k) {
        float r25340 = 2;
        float r25341 = t;
        float r25342 = l;
        float r25343 = r25342 / r25341;
        float r25344 = r25341 / r25343;
        float r25345 = r25341 / r25342;
        float r25346 = r25344 * r25345;
        float r25347 = k;
        float r25348 = sin(r25347);
        float r25349 = r25346 * r25348;
        float r25350 = tan(r25347);
        float r25351 = r25349 * r25350;
        float r25352 = 1;
        float r25353 = r25347 / r25341;
        float r25354 = pow(r25353, r25340);
        float r25355 = r25352 + r25354;
        float r25356 = r25355 + r25352;
        float r25357 = r25351 * r25356;
        float r25358 = r25340 / r25357;
        float r25359 = 2.3547161355365463e+230;
        bool r25360 = r25358 <= r25359;
        float r25361 = cos(r25347);
        float r25362 = r25343 * r25361;
        float r25363 = r25348 / r25343;
        float r25364 = r25363 * r25341;
        float r25365 = r25364 * r25348;
        float r25366 = r25365 * r25356;
        float r25367 = r25362 / r25366;
        float r25368 = r25352 / r25367;
        float r25369 = r25340 / r25368;
        float r25370 = r25348 * r25341;
        float r25371 = r25370 * r25348;
        float r25372 = r25371 * r25356;
        float r25373 = r25372 / r25343;
        float r25374 = r25373 / r25362;
        float r25375 = r25340 / r25374;
        float r25376 = r25360 ? r25369 : r25375;
        return r25376;
}

double f_od(double t, double l, double k) {
        double r25377 = 2;
        double r25378 = t;
        double r25379 = l;
        double r25380 = r25379 / r25378;
        double r25381 = r25378 / r25380;
        double r25382 = r25378 / r25379;
        double r25383 = r25381 * r25382;
        double r25384 = k;
        double r25385 = sin(r25384);
        double r25386 = r25383 * r25385;
        double r25387 = tan(r25384);
        double r25388 = r25386 * r25387;
        double r25389 = 1;
        double r25390 = r25384 / r25378;
        double r25391 = pow(r25390, r25377);
        double r25392 = r25389 + r25391;
        double r25393 = r25392 + r25389;
        double r25394 = r25388 * r25393;
        double r25395 = r25377 / r25394;
        double r25396 = 2.3547161355365463e+230;
        bool r25397 = r25395 <= r25396;
        double r25398 = cos(r25384);
        double r25399 = r25380 * r25398;
        double r25400 = r25385 / r25380;
        double r25401 = r25400 * r25378;
        double r25402 = r25401 * r25385;
        double r25403 = r25402 * r25393;
        double r25404 = r25399 / r25403;
        double r25405 = r25389 / r25404;
        double r25406 = r25377 / r25405;
        double r25407 = r25385 * r25378;
        double r25408 = r25407 * r25385;
        double r25409 = r25408 * r25393;
        double r25410 = r25409 / r25380;
        double r25411 = r25410 / r25399;
        double r25412 = r25377 / r25411;
        double r25413 = r25397 ? r25406 : r25412;
        return r25413;
}

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 r25414, r25415, r25416, r25417, r25418, r25419, r25420, r25421, r25422, r25423, r25424, r25425, r25426, r25427, r25428, r25429, r25430, r25431, r25432;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init_set_str(r25414, "2", 10, MPFR_RNDN);
        mpfr_init(r25415);
        mpfr_init_set_str(r25416, "3", 10, MPFR_RNDN);
        mpfr_init(r25417);
        mpfr_init(r25418);
        mpfr_init(r25419);
        mpfr_init(r25420);
        mpfr_init(r25421);
        mpfr_init(r25422);
        mpfr_init(r25423);
        mpfr_init(r25424);
        mpfr_init(r25425);
        mpfr_init_set_str(r25426, "1", 10, MPFR_RNDN);
        mpfr_init(r25427);
        mpfr_init(r25428);
        mpfr_init(r25429);
        mpfr_init(r25430);
        mpfr_init(r25431);
        mpfr_init(r25432);
}

double f_im(double t, double l, double k) {
        ;
        mpfr_set_d(r25415, t, MPFR_RNDN);
        ;
        mpfr_pow(r25417, r25415, r25416, MPFR_RNDN);
        mpfr_set_d(r25418, l, MPFR_RNDN);
        mpfr_mul(r25419, r25418, r25418, MPFR_RNDN);
        mpfr_div(r25420, r25417, r25419, MPFR_RNDN);
        mpfr_set_d(r25421, k, MPFR_RNDN);
        mpfr_sin(r25422, r25421, MPFR_RNDN);
        mpfr_mul(r25423, r25420, r25422, MPFR_RNDN);
        mpfr_tan(r25424, r25421, MPFR_RNDN);
        mpfr_mul(r25425, r25423, r25424, MPFR_RNDN);
        ;
        mpfr_div(r25427, r25421, r25415, MPFR_RNDN);
        mpfr_pow(r25428, r25427, r25414, MPFR_RNDN);
        mpfr_add(r25429, r25426, r25428, MPFR_RNDN);
        mpfr_add(r25430, r25429, r25426, MPFR_RNDN);
        mpfr_mul(r25431, r25425, r25430, MPFR_RNDN);
        mpfr_div(r25432, r25414, r25431, MPFR_RNDN);
        return mpfr_get_d(r25432, MPFR_RNDN);
}

static mpfr_t r25433, r25434, r25435, r25436, r25437, r25438, r25439, r25440, r25441, r25442, r25443, r25444, r25445, r25446, r25447, r25448, r25449, r25450, r25451, r25452, r25453, r25454, r25455, r25456, r25457, r25458, r25459, r25460, r25461, r25462, r25463, r25464, r25465, r25466, r25467, r25468, r25469;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init_set_str(r25433, "2", 10, MPFR_RNDN);
        mpfr_init(r25434);
        mpfr_init(r25435);
        mpfr_init(r25436);
        mpfr_init(r25437);
        mpfr_init(r25438);
        mpfr_init(r25439);
        mpfr_init(r25440);
        mpfr_init(r25441);
        mpfr_init(r25442);
        mpfr_init(r25443);
        mpfr_init(r25444);
        mpfr_init_set_str(r25445, "1", 10, MPFR_RNDN);
        mpfr_init(r25446);
        mpfr_init(r25447);
        mpfr_init(r25448);
        mpfr_init(r25449);
        mpfr_init(r25450);
        mpfr_init(r25451);
        mpfr_init_set_str(r25452, "2.3547161355365463e+230", 10, MPFR_RNDN);
        mpfr_init(r25453);
        mpfr_init(r25454);
        mpfr_init(r25455);
        mpfr_init(r25456);
        mpfr_init(r25457);
        mpfr_init(r25458);
        mpfr_init(r25459);
        mpfr_init(r25460);
        mpfr_init(r25461);
        mpfr_init(r25462);
        mpfr_init(r25463);
        mpfr_init(r25464);
        mpfr_init(r25465);
        mpfr_init(r25466);
        mpfr_init(r25467);
        mpfr_init(r25468);
        mpfr_init(r25469);
}

double f_fm(double t, double l, double k) {
        ;
        mpfr_set_d(r25434, t, MPFR_RNDN);
        mpfr_set_d(r25435, l, MPFR_RNDN);
        mpfr_div(r25436, r25435, r25434, MPFR_RNDN);
        mpfr_div(r25437, r25434, r25436, MPFR_RNDN);
        mpfr_div(r25438, r25434, r25435, MPFR_RNDN);
        mpfr_mul(r25439, r25437, r25438, MPFR_RNDN);
        mpfr_set_d(r25440, k, MPFR_RNDN);
        mpfr_sin(r25441, r25440, MPFR_RNDN);
        mpfr_mul(r25442, r25439, r25441, MPFR_RNDN);
        mpfr_tan(r25443, r25440, MPFR_RNDN);
        mpfr_mul(r25444, r25442, r25443, MPFR_RNDN);
        ;
        mpfr_div(r25446, r25440, r25434, MPFR_RNDN);
        mpfr_pow(r25447, r25446, r25433, MPFR_RNDN);
        mpfr_add(r25448, r25445, r25447, MPFR_RNDN);
        mpfr_add(r25449, r25448, r25445, MPFR_RNDN);
        mpfr_mul(r25450, r25444, r25449, MPFR_RNDN);
        mpfr_div(r25451, r25433, r25450, MPFR_RNDN);
        ;
        mpfr_set_si(r25453, mpfr_cmp(r25451, r25452) <= 0, MPFR_RNDN);
        mpfr_cos(r25454, r25440, MPFR_RNDN);
        mpfr_mul(r25455, r25436, r25454, MPFR_RNDN);
        mpfr_div(r25456, r25441, r25436, MPFR_RNDN);
        mpfr_mul(r25457, r25456, r25434, MPFR_RNDN);
        mpfr_mul(r25458, r25457, r25441, MPFR_RNDN);
        mpfr_mul(r25459, r25458, r25449, MPFR_RNDN);
        mpfr_div(r25460, r25455, r25459, MPFR_RNDN);
        mpfr_div(r25461, r25445, r25460, MPFR_RNDN);
        mpfr_div(r25462, r25433, r25461, MPFR_RNDN);
        mpfr_mul(r25463, r25441, r25434, MPFR_RNDN);
        mpfr_mul(r25464, r25463, r25441, MPFR_RNDN);
        mpfr_mul(r25465, r25464, r25449, MPFR_RNDN);
        mpfr_div(r25466, r25465, r25436, MPFR_RNDN);
        mpfr_div(r25467, r25466, r25455, MPFR_RNDN);
        mpfr_div(r25468, r25433, r25467, MPFR_RNDN);
        if (mpfr_get_si(r25453, MPFR_RNDN)) { mpfr_set(r25469, r25462, MPFR_RNDN); } else { mpfr_set(r25469, r25468, MPFR_RNDN); };
        return mpfr_get_d(r25469, MPFR_RNDN);
}

static mpfr_t r25470, r25471, r25472, r25473, r25474, r25475, r25476, r25477, r25478, r25479, r25480, r25481, r25482, r25483, r25484, r25485, r25486, r25487, r25488, r25489, r25490, r25491, r25492, r25493, r25494, r25495, r25496, r25497, r25498, r25499, r25500, r25501, r25502, r25503, r25504, r25505, r25506;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init_set_str(r25470, "2", 10, MPFR_RNDN);
        mpfr_init(r25471);
        mpfr_init(r25472);
        mpfr_init(r25473);
        mpfr_init(r25474);
        mpfr_init(r25475);
        mpfr_init(r25476);
        mpfr_init(r25477);
        mpfr_init(r25478);
        mpfr_init(r25479);
        mpfr_init(r25480);
        mpfr_init(r25481);
        mpfr_init_set_str(r25482, "1", 10, MPFR_RNDN);
        mpfr_init(r25483);
        mpfr_init(r25484);
        mpfr_init(r25485);
        mpfr_init(r25486);
        mpfr_init(r25487);
        mpfr_init(r25488);
        mpfr_init_set_str(r25489, "2.3547161355365463e+230", 10, MPFR_RNDN);
        mpfr_init(r25490);
        mpfr_init(r25491);
        mpfr_init(r25492);
        mpfr_init(r25493);
        mpfr_init(r25494);
        mpfr_init(r25495);
        mpfr_init(r25496);
        mpfr_init(r25497);
        mpfr_init(r25498);
        mpfr_init(r25499);
        mpfr_init(r25500);
        mpfr_init(r25501);
        mpfr_init(r25502);
        mpfr_init(r25503);
        mpfr_init(r25504);
        mpfr_init(r25505);
        mpfr_init(r25506);
}

double f_dm(double t, double l, double k) {
        ;
        mpfr_set_d(r25471, t, MPFR_RNDN);
        mpfr_set_d(r25472, l, MPFR_RNDN);
        mpfr_div(r25473, r25472, r25471, MPFR_RNDN);
        mpfr_div(r25474, r25471, r25473, MPFR_RNDN);
        mpfr_div(r25475, r25471, r25472, MPFR_RNDN);
        mpfr_mul(r25476, r25474, r25475, MPFR_RNDN);
        mpfr_set_d(r25477, k, MPFR_RNDN);
        mpfr_sin(r25478, r25477, MPFR_RNDN);
        mpfr_mul(r25479, r25476, r25478, MPFR_RNDN);
        mpfr_tan(r25480, r25477, MPFR_RNDN);
        mpfr_mul(r25481, r25479, r25480, MPFR_RNDN);
        ;
        mpfr_div(r25483, r25477, r25471, MPFR_RNDN);
        mpfr_pow(r25484, r25483, r25470, MPFR_RNDN);
        mpfr_add(r25485, r25482, r25484, MPFR_RNDN);
        mpfr_add(r25486, r25485, r25482, MPFR_RNDN);
        mpfr_mul(r25487, r25481, r25486, MPFR_RNDN);
        mpfr_div(r25488, r25470, r25487, MPFR_RNDN);
        ;
        mpfr_set_si(r25490, mpfr_cmp(r25488, r25489) <= 0, MPFR_RNDN);
        mpfr_cos(r25491, r25477, MPFR_RNDN);
        mpfr_mul(r25492, r25473, r25491, MPFR_RNDN);
        mpfr_div(r25493, r25478, r25473, MPFR_RNDN);
        mpfr_mul(r25494, r25493, r25471, MPFR_RNDN);
        mpfr_mul(r25495, r25494, r25478, MPFR_RNDN);
        mpfr_mul(r25496, r25495, r25486, MPFR_RNDN);
        mpfr_div(r25497, r25492, r25496, MPFR_RNDN);
        mpfr_div(r25498, r25482, r25497, MPFR_RNDN);
        mpfr_div(r25499, r25470, r25498, MPFR_RNDN);
        mpfr_mul(r25500, r25478, r25471, MPFR_RNDN);
        mpfr_mul(r25501, r25500, r25478, MPFR_RNDN);
        mpfr_mul(r25502, r25501, r25486, MPFR_RNDN);
        mpfr_div(r25503, r25502, r25473, MPFR_RNDN);
        mpfr_div(r25504, r25503, r25492, MPFR_RNDN);
        mpfr_div(r25505, r25470, r25504, MPFR_RNDN);
        if (mpfr_get_si(r25490, MPFR_RNDN)) { mpfr_set(r25506, r25499, MPFR_RNDN); } else { mpfr_set(r25506, r25505, MPFR_RNDN); };
        return mpfr_get_d(r25506, MPFR_RNDN);
}

