#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 r9365 = 2;
        float r9366 = t;
        float r9367 = 3;
        float r9368 = pow(r9366, r9367);
        float r9369 = l;
        float r9370 = r9369 * r9369;
        float r9371 = r9368 / r9370;
        float r9372 = k;
        float r9373 = sin(r9372);
        float r9374 = r9371 * r9373;
        float r9375 = tan(r9372);
        float r9376 = r9374 * r9375;
        float r9377 = 1;
        float r9378 = r9372 / r9366;
        float r9379 = pow(r9378, r9365);
        float r9380 = r9377 + r9379;
        float r9381 = r9380 + r9377;
        float r9382 = r9376 * r9381;
        float r9383 = r9365 / r9382;
        return r9383;
}

double f_id(double t, double l, double k) {
        double r9384 = 2;
        double r9385 = t;
        double r9386 = 3;
        double r9387 = pow(r9385, r9386);
        double r9388 = l;
        double r9389 = r9388 * r9388;
        double r9390 = r9387 / r9389;
        double r9391 = k;
        double r9392 = sin(r9391);
        double r9393 = r9390 * r9392;
        double r9394 = tan(r9391);
        double r9395 = r9393 * r9394;
        double r9396 = 1;
        double r9397 = r9391 / r9385;
        double r9398 = pow(r9397, r9384);
        double r9399 = r9396 + r9398;
        double r9400 = r9399 + r9396;
        double r9401 = r9395 * r9400;
        double r9402 = r9384 / r9401;
        return r9402;
}


double f_of(float t, float l, float k) {
        float r9403 = k;
        float r9404 = t;
        float r9405 = r9403 / r9404;
        float r9406 = r9405 * r9405;
        float r9407 = 1;
        float r9408 = r9407 + r9407;
        float r9409 = r9406 + r9408;
        float r9410 = l;
        float r9411 = r9404 / r9410;
        float r9412 = r9404 * r9411;
        float r9413 = tan(r9403);
        float r9414 = r9412 * r9413;
        float r9415 = r9409 * r9414;
        float r9416 = sin(r9403);
        float r9417 = r9411 * r9416;
        float r9418 = r9415 * r9417;
        float r9419 = -1.4027502456406147e+170;
        bool r9420 = r9418 <= r9419;
        float r9421 = 3.2871527882312187e-229;
        bool r9422 = r9418 <= r9421;
        float r9423 = !r9422;
        bool r9424 = r9420 || r9423;
        float r9425 = 2;
        float r9426 = r9411 * r9417;
        float r9427 = r9413 * r9426;
        float r9428 = r9404 * r9427;
        float r9429 = pow(r9405, r9425);
        float r9430 = r9429 + r9407;
        float r9431 = r9430 + r9407;
        float r9432 = r9428 * r9431;
        float r9433 = r9425 / r9432;
        float r9434 = r9417 * r9412;
        float r9435 = r9413 * r9434;
        float r9436 = r9435 * r9431;
        float r9437 = cbrt(r9436);
        float r9438 = r9437 * r9437;
        float r9439 = r9437 * r9438;
        float r9440 = r9425 / r9439;
        float r9441 = r9424 ? r9433 : r9440;
        return r9441;
}

double f_od(double t, double l, double k) {
        double r9442 = k;
        double r9443 = t;
        double r9444 = r9442 / r9443;
        double r9445 = r9444 * r9444;
        double r9446 = 1;
        double r9447 = r9446 + r9446;
        double r9448 = r9445 + r9447;
        double r9449 = l;
        double r9450 = r9443 / r9449;
        double r9451 = r9443 * r9450;
        double r9452 = tan(r9442);
        double r9453 = r9451 * r9452;
        double r9454 = r9448 * r9453;
        double r9455 = sin(r9442);
        double r9456 = r9450 * r9455;
        double r9457 = r9454 * r9456;
        double r9458 = -1.4027502456406147e+170;
        bool r9459 = r9457 <= r9458;
        double r9460 = 3.2871527882312187e-229;
        bool r9461 = r9457 <= r9460;
        double r9462 = !r9461;
        bool r9463 = r9459 || r9462;
        double r9464 = 2;
        double r9465 = r9450 * r9456;
        double r9466 = r9452 * r9465;
        double r9467 = r9443 * r9466;
        double r9468 = pow(r9444, r9464);
        double r9469 = r9468 + r9446;
        double r9470 = r9469 + r9446;
        double r9471 = r9467 * r9470;
        double r9472 = r9464 / r9471;
        double r9473 = r9456 * r9451;
        double r9474 = r9452 * r9473;
        double r9475 = r9474 * r9470;
        double r9476 = cbrt(r9475);
        double r9477 = r9476 * r9476;
        double r9478 = r9476 * r9477;
        double r9479 = r9464 / r9478;
        double r9480 = r9463 ? r9472 : r9479;
        return r9480;
}

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 r9481, r9482, r9483, r9484, r9485, r9486, r9487, r9488, r9489, r9490, r9491, r9492, r9493, r9494, r9495, r9496, r9497, r9498, r9499;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(592);
        mpfr_init_set_str(r9481, "2", 10, MPFR_RNDN);
        mpfr_init(r9482);
        mpfr_init_set_str(r9483, "3", 10, MPFR_RNDN);
        mpfr_init(r9484);
        mpfr_init(r9485);
        mpfr_init(r9486);
        mpfr_init(r9487);
        mpfr_init(r9488);
        mpfr_init(r9489);
        mpfr_init(r9490);
        mpfr_init(r9491);
        mpfr_init(r9492);
        mpfr_init_set_str(r9493, "1", 10, MPFR_RNDN);
        mpfr_init(r9494);
        mpfr_init(r9495);
        mpfr_init(r9496);
        mpfr_init(r9497);
        mpfr_init(r9498);
        mpfr_init(r9499);
}

double f_im(double t, double l, double k) {
        ;
        mpfr_set_d(r9482, t, MPFR_RNDN);
        ;
        mpfr_pow(r9484, r9482, r9483, MPFR_RNDN);
        mpfr_set_d(r9485, l, MPFR_RNDN);
        mpfr_mul(r9486, r9485, r9485, MPFR_RNDN);
        mpfr_div(r9487, r9484, r9486, MPFR_RNDN);
        mpfr_set_d(r9488, k, MPFR_RNDN);
        mpfr_sin(r9489, r9488, MPFR_RNDN);
        mpfr_mul(r9490, r9487, r9489, MPFR_RNDN);
        mpfr_tan(r9491, r9488, MPFR_RNDN);
        mpfr_mul(r9492, r9490, r9491, MPFR_RNDN);
        ;
        mpfr_div(r9494, r9488, r9482, MPFR_RNDN);
        mpfr_pow(r9495, r9494, r9481, MPFR_RNDN);
        mpfr_add(r9496, r9493, r9495, MPFR_RNDN);
        mpfr_add(r9497, r9496, r9493, MPFR_RNDN);
        mpfr_mul(r9498, r9492, r9497, MPFR_RNDN);
        mpfr_div(r9499, r9481, r9498, MPFR_RNDN);
        return mpfr_get_d(r9499, MPFR_RNDN);
}

static mpfr_t r9500, r9501, r9502, r9503, r9504, r9505, r9506, r9507, r9508, r9509, r9510, r9511, r9512, r9513, r9514, r9515, r9516, r9517, r9518, r9519, r9520, r9521, r9522, r9523, r9524, r9525, r9526, r9527, r9528, r9529, r9530, r9531, r9532, r9533, r9534, r9535, r9536, r9537, r9538;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(592);
        mpfr_init(r9500);
        mpfr_init(r9501);
        mpfr_init(r9502);
        mpfr_init(r9503);
        mpfr_init_set_str(r9504, "1", 10, MPFR_RNDN);
        mpfr_init(r9505);
        mpfr_init(r9506);
        mpfr_init(r9507);
        mpfr_init(r9508);
        mpfr_init(r9509);
        mpfr_init(r9510);
        mpfr_init(r9511);
        mpfr_init(r9512);
        mpfr_init(r9513);
        mpfr_init(r9514);
        mpfr_init(r9515);
        mpfr_init_set_str(r9516, "-1.4027502456406147e+170", 10, MPFR_RNDN);
        mpfr_init(r9517);
        mpfr_init_set_str(r9518, "3.2871527882312187e-229", 10, MPFR_RNDN);
        mpfr_init(r9519);
        mpfr_init(r9520);
        mpfr_init(r9521);
        mpfr_init_set_str(r9522, "2", 10, MPFR_RNDN);
        mpfr_init(r9523);
        mpfr_init(r9524);
        mpfr_init(r9525);
        mpfr_init(r9526);
        mpfr_init(r9527);
        mpfr_init(r9528);
        mpfr_init(r9529);
        mpfr_init(r9530);
        mpfr_init(r9531);
        mpfr_init(r9532);
        mpfr_init(r9533);
        mpfr_init(r9534);
        mpfr_init(r9535);
        mpfr_init(r9536);
        mpfr_init(r9537);
        mpfr_init(r9538);
}

double f_fm(double t, double l, double k) {
        mpfr_set_d(r9500, k, MPFR_RNDN);
        mpfr_set_d(r9501, t, MPFR_RNDN);
        mpfr_div(r9502, r9500, r9501, MPFR_RNDN);
        mpfr_mul(r9503, r9502, r9502, MPFR_RNDN);
        ;
        mpfr_add(r9505, r9504, r9504, MPFR_RNDN);
        mpfr_add(r9506, r9503, r9505, MPFR_RNDN);
        mpfr_set_d(r9507, l, MPFR_RNDN);
        mpfr_div(r9508, r9501, r9507, MPFR_RNDN);
        mpfr_mul(r9509, r9501, r9508, MPFR_RNDN);
        mpfr_tan(r9510, r9500, MPFR_RNDN);
        mpfr_mul(r9511, r9509, r9510, MPFR_RNDN);
        mpfr_mul(r9512, r9506, r9511, MPFR_RNDN);
        mpfr_sin(r9513, r9500, MPFR_RNDN);
        mpfr_mul(r9514, r9508, r9513, MPFR_RNDN);
        mpfr_mul(r9515, r9512, r9514, MPFR_RNDN);
        ;
        mpfr_set_si(r9517, mpfr_cmp(r9515, r9516) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r9519, mpfr_cmp(r9515, r9518) <= 0, MPFR_RNDN);
        mpfr_set_si(r9520, !mpfr_get_si(r9519, MPFR_RNDN), MPFR_RNDN);
        mpfr_set_si(r9521, mpfr_get_si(r9517, MPFR_RNDN) || mpfr_get_si(r9520, MPFR_RNDN), MPFR_RNDN);
        ;
        mpfr_mul(r9523, r9508, r9514, MPFR_RNDN);
        mpfr_mul(r9524, r9510, r9523, MPFR_RNDN);
        mpfr_mul(r9525, r9501, r9524, MPFR_RNDN);
        mpfr_pow(r9526, r9502, r9522, MPFR_RNDN);
        mpfr_add(r9527, r9526, r9504, MPFR_RNDN);
        mpfr_add(r9528, r9527, r9504, MPFR_RNDN);
        mpfr_mul(r9529, r9525, r9528, MPFR_RNDN);
        mpfr_div(r9530, r9522, r9529, MPFR_RNDN);
        mpfr_mul(r9531, r9514, r9509, MPFR_RNDN);
        mpfr_mul(r9532, r9510, r9531, MPFR_RNDN);
        mpfr_mul(r9533, r9532, r9528, MPFR_RNDN);
        mpfr_cbrt(r9534, r9533, MPFR_RNDN);
        mpfr_mul(r9535, r9534, r9534, MPFR_RNDN);
        mpfr_mul(r9536, r9534, r9535, MPFR_RNDN);
        mpfr_div(r9537, r9522, r9536, MPFR_RNDN);
        if (mpfr_get_si(r9521, MPFR_RNDN)) { mpfr_set(r9538, r9530, MPFR_RNDN); } else { mpfr_set(r9538, r9537, MPFR_RNDN); };
        return mpfr_get_d(r9538, MPFR_RNDN);
}

static mpfr_t r9539, r9540, r9541, r9542, r9543, r9544, r9545, r9546, r9547, r9548, r9549, r9550, r9551, r9552, r9553, r9554, r9555, r9556, r9557, r9558, r9559, r9560, r9561, r9562, r9563, r9564, r9565, r9566, r9567, r9568, r9569, r9570, r9571, r9572, r9573, r9574, r9575, r9576, r9577;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(592);
        mpfr_init(r9539);
        mpfr_init(r9540);
        mpfr_init(r9541);
        mpfr_init(r9542);
        mpfr_init_set_str(r9543, "1", 10, MPFR_RNDN);
        mpfr_init(r9544);
        mpfr_init(r9545);
        mpfr_init(r9546);
        mpfr_init(r9547);
        mpfr_init(r9548);
        mpfr_init(r9549);
        mpfr_init(r9550);
        mpfr_init(r9551);
        mpfr_init(r9552);
        mpfr_init(r9553);
        mpfr_init(r9554);
        mpfr_init_set_str(r9555, "-1.4027502456406147e+170", 10, MPFR_RNDN);
        mpfr_init(r9556);
        mpfr_init_set_str(r9557, "3.2871527882312187e-229", 10, MPFR_RNDN);
        mpfr_init(r9558);
        mpfr_init(r9559);
        mpfr_init(r9560);
        mpfr_init_set_str(r9561, "2", 10, MPFR_RNDN);
        mpfr_init(r9562);
        mpfr_init(r9563);
        mpfr_init(r9564);
        mpfr_init(r9565);
        mpfr_init(r9566);
        mpfr_init(r9567);
        mpfr_init(r9568);
        mpfr_init(r9569);
        mpfr_init(r9570);
        mpfr_init(r9571);
        mpfr_init(r9572);
        mpfr_init(r9573);
        mpfr_init(r9574);
        mpfr_init(r9575);
        mpfr_init(r9576);
        mpfr_init(r9577);
}

double f_dm(double t, double l, double k) {
        mpfr_set_d(r9539, k, MPFR_RNDN);
        mpfr_set_d(r9540, t, MPFR_RNDN);
        mpfr_div(r9541, r9539, r9540, MPFR_RNDN);
        mpfr_mul(r9542, r9541, r9541, MPFR_RNDN);
        ;
        mpfr_add(r9544, r9543, r9543, MPFR_RNDN);
        mpfr_add(r9545, r9542, r9544, MPFR_RNDN);
        mpfr_set_d(r9546, l, MPFR_RNDN);
        mpfr_div(r9547, r9540, r9546, MPFR_RNDN);
        mpfr_mul(r9548, r9540, r9547, MPFR_RNDN);
        mpfr_tan(r9549, r9539, MPFR_RNDN);
        mpfr_mul(r9550, r9548, r9549, MPFR_RNDN);
        mpfr_mul(r9551, r9545, r9550, MPFR_RNDN);
        mpfr_sin(r9552, r9539, MPFR_RNDN);
        mpfr_mul(r9553, r9547, r9552, MPFR_RNDN);
        mpfr_mul(r9554, r9551, r9553, MPFR_RNDN);
        ;
        mpfr_set_si(r9556, mpfr_cmp(r9554, r9555) <= 0, MPFR_RNDN);
        ;
        mpfr_set_si(r9558, mpfr_cmp(r9554, r9557) <= 0, MPFR_RNDN);
        mpfr_set_si(r9559, !mpfr_get_si(r9558, MPFR_RNDN), MPFR_RNDN);
        mpfr_set_si(r9560, mpfr_get_si(r9556, MPFR_RNDN) || mpfr_get_si(r9559, MPFR_RNDN), MPFR_RNDN);
        ;
        mpfr_mul(r9562, r9547, r9553, MPFR_RNDN);
        mpfr_mul(r9563, r9549, r9562, MPFR_RNDN);
        mpfr_mul(r9564, r9540, r9563, MPFR_RNDN);
        mpfr_pow(r9565, r9541, r9561, MPFR_RNDN);
        mpfr_add(r9566, r9565, r9543, MPFR_RNDN);
        mpfr_add(r9567, r9566, r9543, MPFR_RNDN);
        mpfr_mul(r9568, r9564, r9567, MPFR_RNDN);
        mpfr_div(r9569, r9561, r9568, MPFR_RNDN);
        mpfr_mul(r9570, r9553, r9548, MPFR_RNDN);
        mpfr_mul(r9571, r9549, r9570, MPFR_RNDN);
        mpfr_mul(r9572, r9571, r9567, MPFR_RNDN);
        mpfr_cbrt(r9573, r9572, MPFR_RNDN);
        mpfr_mul(r9574, r9573, r9573, MPFR_RNDN);
        mpfr_mul(r9575, r9573, r9574, MPFR_RNDN);
        mpfr_div(r9576, r9561, r9575, MPFR_RNDN);
        if (mpfr_get_si(r9560, MPFR_RNDN)) { mpfr_set(r9577, r9569, MPFR_RNDN); } else { mpfr_set(r9577, r9576, MPFR_RNDN); };
        return mpfr_get_d(r9577, MPFR_RNDN);
}

