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

char *name = "From Warwick Tucker's Validated Numerics";

double f_if() {
        float r20231 = 333.75;
        float r20232 = 33096;
        float r20233 = 6;
        float r20234 = pow(r20232, r20233);
        float r20235 = r20231 * r20234;
        float r20236 = 77617;
        float r20237 = r20236 * r20236;
        float r20238 = 11;
        float r20239 = r20238 * r20237;
        float r20240 = r20232 * r20232;
        float r20241 = r20239 * r20240;
        float r20242 = -r20234;
        float r20243 = r20241 + r20242;
        float r20244 = -121;
        float r20245 = 4;
        float r20246 = pow(r20232, r20245);
        float r20247 = r20244 * r20246;
        float r20248 = r20243 + r20247;
        float r20249 = -2;
        float r20250 = r20248 + r20249;
        float r20251 = r20237 * r20250;
        float r20252 = r20235 + r20251;
        float r20253 = 5.5;
        float r20254 = 8;
        float r20255 = pow(r20232, r20254);
        float r20256 = r20253 * r20255;
        float r20257 = r20252 + r20256;
        float r20258 = 2;
        float r20259 = r20258 * r20232;
        float r20260 = r20236 / r20259;
        float r20261 = r20257 + r20260;
        return r20261;
}

double f_id() {
        double r20262 = 333.75;
        double r20263 = 33096;
        double r20264 = 6;
        double r20265 = pow(r20263, r20264);
        double r20266 = r20262 * r20265;
        double r20267 = 77617;
        double r20268 = r20267 * r20267;
        double r20269 = 11;
        double r20270 = r20269 * r20268;
        double r20271 = r20263 * r20263;
        double r20272 = r20270 * r20271;
        double r20273 = -r20265;
        double r20274 = r20272 + r20273;
        double r20275 = -121;
        double r20276 = 4;
        double r20277 = pow(r20263, r20276);
        double r20278 = r20275 * r20277;
        double r20279 = r20274 + r20278;
        double r20280 = -2;
        double r20281 = r20279 + r20280;
        double r20282 = r20268 * r20281;
        double r20283 = r20266 + r20282;
        double r20284 = 5.5;
        double r20285 = 8;
        double r20286 = pow(r20263, r20285);
        double r20287 = r20284 * r20286;
        double r20288 = r20283 + r20287;
        double r20289 = 2;
        double r20290 = r20289 * r20263;
        double r20291 = r20267 / r20290;
        double r20292 = r20288 + r20291;
        return r20292;
}


double f_of() {
        float r20293 = 333.75;
        float r20294 = 33096;
        float r20295 = 6;
        float r20296 = pow(r20294, r20295);
        float r20297 = r20293 * r20296;
        float r20298 = 77617;
        float r20299 = r20298 * r20298;
        float r20300 = 11;
        float r20301 = r20300 * r20299;
        float r20302 = r20294 * r20294;
        float r20303 = r20301 * r20302;
        float r20304 = -r20296;
        float r20305 = r20303 + r20304;
        float r20306 = -121;
        float r20307 = 4;
        float r20308 = pow(r20294, r20307);
        float r20309 = r20306 * r20308;
        float r20310 = r20305 + r20309;
        float r20311 = -2;
        float r20312 = r20310 + r20311;
        float r20313 = r20299 * r20312;
        float r20314 = r20297 + r20313;
        float r20315 = r20314 * r20314;
        float r20316 = 5.5;
        float r20317 = 8;
        float r20318 = pow(r20294, r20317);
        float r20319 = r20316 * r20318;
        float r20320 = r20319 * r20319;
        float r20321 = r20315 - r20320;
        float r20322 = log(r20321);
        float r20323 = cbrt(r20322);
        float r20324 = r20323 * r20323;
        float r20325 = exp(r20324);
        float r20326 = cbrt(r20323);
        float r20327 = r20326 * r20326;
        float r20328 = pow(r20325, r20327);
        float r20329 = pow(r20328, r20326);
        float r20330 = r20314 - r20319;
        float r20331 = r20329 / r20330;
        float r20332 = 2;
        float r20333 = r20332 * r20294;
        float r20334 = r20298 / r20333;
        float r20335 = r20331 + r20334;
        return r20335;
}

double f_od() {
        double r20336 = 333.75;
        double r20337 = 33096;
        double r20338 = 6;
        double r20339 = pow(r20337, r20338);
        double r20340 = r20336 * r20339;
        double r20341 = 77617;
        double r20342 = r20341 * r20341;
        double r20343 = 11;
        double r20344 = r20343 * r20342;
        double r20345 = r20337 * r20337;
        double r20346 = r20344 * r20345;
        double r20347 = -r20339;
        double r20348 = r20346 + r20347;
        double r20349 = -121;
        double r20350 = 4;
        double r20351 = pow(r20337, r20350);
        double r20352 = r20349 * r20351;
        double r20353 = r20348 + r20352;
        double r20354 = -2;
        double r20355 = r20353 + r20354;
        double r20356 = r20342 * r20355;
        double r20357 = r20340 + r20356;
        double r20358 = r20357 * r20357;
        double r20359 = 5.5;
        double r20360 = 8;
        double r20361 = pow(r20337, r20360);
        double r20362 = r20359 * r20361;
        double r20363 = r20362 * r20362;
        double r20364 = r20358 - r20363;
        double r20365 = log(r20364);
        double r20366 = cbrt(r20365);
        double r20367 = r20366 * r20366;
        double r20368 = exp(r20367);
        double r20369 = cbrt(r20366);
        double r20370 = r20369 * r20369;
        double r20371 = pow(r20368, r20370);
        double r20372 = pow(r20371, r20369);
        double r20373 = r20357 - r20362;
        double r20374 = r20372 / r20373;
        double r20375 = 2;
        double r20376 = r20375 * r20337;
        double r20377 = r20341 / r20376;
        double r20378 = r20374 + r20377;
        return r20378;
}

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 r20379, r20380, r20381, r20382, r20383, r20384, r20385, r20386, r20387, r20388, r20389, r20390, r20391, r20392, r20393, r20394, r20395, r20396, r20397, r20398, r20399, r20400, r20401, r20402, r20403, r20404, r20405, r20406, r20407, r20408, r20409;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r20379, "333.75", 10, MPFR_RNDN);
        mpfr_init_set_str(r20380, "33096", 10, MPFR_RNDN);
        mpfr_init_set_str(r20381, "6", 10, MPFR_RNDN);
        mpfr_init(r20382);
        mpfr_init(r20383);
        mpfr_init_set_str(r20384, "77617", 10, MPFR_RNDN);
        mpfr_init(r20385);
        mpfr_init_set_str(r20386, "11", 10, MPFR_RNDN);
        mpfr_init(r20387);
        mpfr_init(r20388);
        mpfr_init(r20389);
        mpfr_init(r20390);
        mpfr_init(r20391);
        mpfr_init_set_str(r20392, "-121", 10, MPFR_RNDN);
        mpfr_init_set_str(r20393, "4", 10, MPFR_RNDN);
        mpfr_init(r20394);
        mpfr_init(r20395);
        mpfr_init(r20396);
        mpfr_init_set_str(r20397, "-2", 10, MPFR_RNDN);
        mpfr_init(r20398);
        mpfr_init(r20399);
        mpfr_init(r20400);
        mpfr_init_set_str(r20401, "5.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r20402, "8", 10, MPFR_RNDN);
        mpfr_init(r20403);
        mpfr_init(r20404);
        mpfr_init(r20405);
        mpfr_init_set_str(r20406, "2", 10, MPFR_RNDN);
        mpfr_init(r20407);
        mpfr_init(r20408);
        mpfr_init(r20409);
}

double f_im() {
        ;
        ;
        ;
        mpfr_pow(r20382, r20380, r20381, MPFR_RNDN);
        mpfr_mul(r20383, r20379, r20382, MPFR_RNDN);
        ;
        mpfr_mul(r20385, r20384, r20384, MPFR_RNDN);
        ;
        mpfr_mul(r20387, r20386, r20385, MPFR_RNDN);
        mpfr_mul(r20388, r20380, r20380, MPFR_RNDN);
        mpfr_mul(r20389, r20387, r20388, MPFR_RNDN);
        mpfr_neg(r20390, r20382, MPFR_RNDN);
        mpfr_add(r20391, r20389, r20390, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20394, r20380, r20393, MPFR_RNDN);
        mpfr_mul(r20395, r20392, r20394, MPFR_RNDN);
        mpfr_add(r20396, r20391, r20395, MPFR_RNDN);
        ;
        mpfr_add(r20398, r20396, r20397, MPFR_RNDN);
        mpfr_mul(r20399, r20385, r20398, MPFR_RNDN);
        mpfr_add(r20400, r20383, r20399, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20403, r20380, r20402, MPFR_RNDN);
        mpfr_mul(r20404, r20401, r20403, MPFR_RNDN);
        mpfr_add(r20405, r20400, r20404, MPFR_RNDN);
        ;
        mpfr_mul(r20407, r20406, r20380, MPFR_RNDN);
        mpfr_div(r20408, r20384, r20407, MPFR_RNDN);
        mpfr_add(r20409, r20405, r20408, MPFR_RNDN);
        return mpfr_get_d(r20409, MPFR_RNDN);
}

static mpfr_t r20410, r20411, r20412, r20413, r20414, r20415, r20416, r20417, r20418, r20419, r20420, r20421, r20422, r20423, r20424, r20425, r20426, r20427, r20428, r20429, r20430, r20431, r20432, r20433, r20434, r20435, r20436, r20437, r20438, r20439, r20440, r20441, r20442, r20443, r20444, r20445, r20446, r20447, r20448, r20449, r20450, r20451, r20452;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r20410, "333.75", 10, MPFR_RNDN);
        mpfr_init_set_str(r20411, "33096", 10, MPFR_RNDN);
        mpfr_init_set_str(r20412, "6", 10, MPFR_RNDN);
        mpfr_init(r20413);
        mpfr_init(r20414);
        mpfr_init_set_str(r20415, "77617", 10, MPFR_RNDN);
        mpfr_init(r20416);
        mpfr_init_set_str(r20417, "11", 10, MPFR_RNDN);
        mpfr_init(r20418);
        mpfr_init(r20419);
        mpfr_init(r20420);
        mpfr_init(r20421);
        mpfr_init(r20422);
        mpfr_init_set_str(r20423, "-121", 10, MPFR_RNDN);
        mpfr_init_set_str(r20424, "4", 10, MPFR_RNDN);
        mpfr_init(r20425);
        mpfr_init(r20426);
        mpfr_init(r20427);
        mpfr_init_set_str(r20428, "-2", 10, MPFR_RNDN);
        mpfr_init(r20429);
        mpfr_init(r20430);
        mpfr_init(r20431);
        mpfr_init(r20432);
        mpfr_init_set_str(r20433, "5.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r20434, "8", 10, MPFR_RNDN);
        mpfr_init(r20435);
        mpfr_init(r20436);
        mpfr_init(r20437);
        mpfr_init(r20438);
        mpfr_init(r20439);
        mpfr_init(r20440);
        mpfr_init(r20441);
        mpfr_init(r20442);
        mpfr_init(r20443);
        mpfr_init(r20444);
        mpfr_init(r20445);
        mpfr_init(r20446);
        mpfr_init(r20447);
        mpfr_init(r20448);
        mpfr_init_set_str(r20449, "2", 10, MPFR_RNDN);
        mpfr_init(r20450);
        mpfr_init(r20451);
        mpfr_init(r20452);
}

double f_fm() {
        ;
        ;
        ;
        mpfr_pow(r20413, r20411, r20412, MPFR_RNDN);
        mpfr_mul(r20414, r20410, r20413, MPFR_RNDN);
        ;
        mpfr_mul(r20416, r20415, r20415, MPFR_RNDN);
        ;
        mpfr_mul(r20418, r20417, r20416, MPFR_RNDN);
        mpfr_mul(r20419, r20411, r20411, MPFR_RNDN);
        mpfr_mul(r20420, r20418, r20419, MPFR_RNDN);
        mpfr_neg(r20421, r20413, MPFR_RNDN);
        mpfr_add(r20422, r20420, r20421, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20425, r20411, r20424, MPFR_RNDN);
        mpfr_mul(r20426, r20423, r20425, MPFR_RNDN);
        mpfr_add(r20427, r20422, r20426, MPFR_RNDN);
        ;
        mpfr_add(r20429, r20427, r20428, MPFR_RNDN);
        mpfr_mul(r20430, r20416, r20429, MPFR_RNDN);
        mpfr_add(r20431, r20414, r20430, MPFR_RNDN);
        mpfr_mul(r20432, r20431, r20431, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20435, r20411, r20434, MPFR_RNDN);
        mpfr_mul(r20436, r20433, r20435, MPFR_RNDN);
        mpfr_mul(r20437, r20436, r20436, MPFR_RNDN);
        mpfr_sub(r20438, r20432, r20437, MPFR_RNDN);
        mpfr_log(r20439, r20438, MPFR_RNDN);
        mpfr_cbrt(r20440, r20439, MPFR_RNDN);
        mpfr_mul(r20441, r20440, r20440, MPFR_RNDN);
        mpfr_exp(r20442, r20441, MPFR_RNDN);
        mpfr_cbrt(r20443, r20440, MPFR_RNDN);
        mpfr_mul(r20444, r20443, r20443, MPFR_RNDN);
        mpfr_pow(r20445, r20442, r20444, MPFR_RNDN);
        mpfr_pow(r20446, r20445, r20443, MPFR_RNDN);
        mpfr_sub(r20447, r20431, r20436, MPFR_RNDN);
        mpfr_div(r20448, r20446, r20447, MPFR_RNDN);
        ;
        mpfr_mul(r20450, r20449, r20411, MPFR_RNDN);
        mpfr_div(r20451, r20415, r20450, MPFR_RNDN);
        mpfr_add(r20452, r20448, r20451, MPFR_RNDN);
        return mpfr_get_d(r20452, MPFR_RNDN);
}

static mpfr_t r20453, r20454, r20455, r20456, r20457, r20458, r20459, r20460, r20461, r20462, r20463, r20464, r20465, r20466, r20467, r20468, r20469, r20470, r20471, r20472, r20473, r20474, r20475, r20476, r20477, r20478, r20479, r20480, r20481, r20482, r20483, r20484, r20485, r20486, r20487, r20488, r20489, r20490, r20491, r20492, r20493, r20494, r20495;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init_set_str(r20453, "333.75", 10, MPFR_RNDN);
        mpfr_init_set_str(r20454, "33096", 10, MPFR_RNDN);
        mpfr_init_set_str(r20455, "6", 10, MPFR_RNDN);
        mpfr_init(r20456);
        mpfr_init(r20457);
        mpfr_init_set_str(r20458, "77617", 10, MPFR_RNDN);
        mpfr_init(r20459);
        mpfr_init_set_str(r20460, "11", 10, MPFR_RNDN);
        mpfr_init(r20461);
        mpfr_init(r20462);
        mpfr_init(r20463);
        mpfr_init(r20464);
        mpfr_init(r20465);
        mpfr_init_set_str(r20466, "-121", 10, MPFR_RNDN);
        mpfr_init_set_str(r20467, "4", 10, MPFR_RNDN);
        mpfr_init(r20468);
        mpfr_init(r20469);
        mpfr_init(r20470);
        mpfr_init_set_str(r20471, "-2", 10, MPFR_RNDN);
        mpfr_init(r20472);
        mpfr_init(r20473);
        mpfr_init(r20474);
        mpfr_init(r20475);
        mpfr_init_set_str(r20476, "5.5", 10, MPFR_RNDN);
        mpfr_init_set_str(r20477, "8", 10, MPFR_RNDN);
        mpfr_init(r20478);
        mpfr_init(r20479);
        mpfr_init(r20480);
        mpfr_init(r20481);
        mpfr_init(r20482);
        mpfr_init(r20483);
        mpfr_init(r20484);
        mpfr_init(r20485);
        mpfr_init(r20486);
        mpfr_init(r20487);
        mpfr_init(r20488);
        mpfr_init(r20489);
        mpfr_init(r20490);
        mpfr_init(r20491);
        mpfr_init_set_str(r20492, "2", 10, MPFR_RNDN);
        mpfr_init(r20493);
        mpfr_init(r20494);
        mpfr_init(r20495);
}

double f_dm() {
        ;
        ;
        ;
        mpfr_pow(r20456, r20454, r20455, MPFR_RNDN);
        mpfr_mul(r20457, r20453, r20456, MPFR_RNDN);
        ;
        mpfr_mul(r20459, r20458, r20458, MPFR_RNDN);
        ;
        mpfr_mul(r20461, r20460, r20459, MPFR_RNDN);
        mpfr_mul(r20462, r20454, r20454, MPFR_RNDN);
        mpfr_mul(r20463, r20461, r20462, MPFR_RNDN);
        mpfr_neg(r20464, r20456, MPFR_RNDN);
        mpfr_add(r20465, r20463, r20464, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20468, r20454, r20467, MPFR_RNDN);
        mpfr_mul(r20469, r20466, r20468, MPFR_RNDN);
        mpfr_add(r20470, r20465, r20469, MPFR_RNDN);
        ;
        mpfr_add(r20472, r20470, r20471, MPFR_RNDN);
        mpfr_mul(r20473, r20459, r20472, MPFR_RNDN);
        mpfr_add(r20474, r20457, r20473, MPFR_RNDN);
        mpfr_mul(r20475, r20474, r20474, MPFR_RNDN);
        ;
        ;
        mpfr_pow(r20478, r20454, r20477, MPFR_RNDN);
        mpfr_mul(r20479, r20476, r20478, MPFR_RNDN);
        mpfr_mul(r20480, r20479, r20479, MPFR_RNDN);
        mpfr_sub(r20481, r20475, r20480, MPFR_RNDN);
        mpfr_log(r20482, r20481, MPFR_RNDN);
        mpfr_cbrt(r20483, r20482, MPFR_RNDN);
        mpfr_mul(r20484, r20483, r20483, MPFR_RNDN);
        mpfr_exp(r20485, r20484, MPFR_RNDN);
        mpfr_cbrt(r20486, r20483, MPFR_RNDN);
        mpfr_mul(r20487, r20486, r20486, MPFR_RNDN);
        mpfr_pow(r20488, r20485, r20487, MPFR_RNDN);
        mpfr_pow(r20489, r20488, r20486, MPFR_RNDN);
        mpfr_sub(r20490, r20474, r20479, MPFR_RNDN);
        mpfr_div(r20491, r20489, r20490, MPFR_RNDN);
        ;
        mpfr_mul(r20493, r20492, r20454, MPFR_RNDN);
        mpfr_div(r20494, r20458, r20493, MPFR_RNDN);
        mpfr_add(r20495, r20491, r20494, MPFR_RNDN);
        return mpfr_get_d(r20495, MPFR_RNDN);
}

