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

char *name = "Equirectangular approximation to distance on a great circle";

double f_if(float R, float lambda1, float lambda2, float phi1, float phi2) {
        float r25389 = R;
        float r25390 = lambda1;
        float r25391 = lambda2;
        float r25392 = r25390 - r25391;
        float r25393 = phi1;
        float r25394 = phi2;
        float r25395 = r25393 + r25394;
        float r25396 = 2;
        float r25397 = r25395 / r25396;
        float r25398 = cos(r25397);
        float r25399 = r25392 * r25398;
        float r25400 = r25399 * r25399;
        float r25401 = r25393 - r25394;
        float r25402 = r25401 * r25401;
        float r25403 = r25400 + r25402;
        float r25404 = sqrt(r25403);
        float r25405 = r25389 * r25404;
        return r25405;
}

double f_id(double R, double lambda1, double lambda2, double phi1, double phi2) {
        double r25406 = R;
        double r25407 = lambda1;
        double r25408 = lambda2;
        double r25409 = r25407 - r25408;
        double r25410 = phi1;
        double r25411 = phi2;
        double r25412 = r25410 + r25411;
        double r25413 = 2;
        double r25414 = r25412 / r25413;
        double r25415 = cos(r25414);
        double r25416 = r25409 * r25415;
        double r25417 = r25416 * r25416;
        double r25418 = r25410 - r25411;
        double r25419 = r25418 * r25418;
        double r25420 = r25417 + r25419;
        double r25421 = sqrt(r25420);
        double r25422 = r25406 * r25421;
        return r25422;
}


double f_of(float R, float lambda1, float lambda2, float phi1, float phi2) {
        float r25423 = phi2;
        float r25424 = phi1;
        float r25425 = r25423 - r25424;
        float r25426 = -1.4030670556456484e+173;
        bool r25427 = r25425 <= r25426;
        float r25428 = R;
        float r25429 = 1/2;
        float r25430 = r25424 + r25423;
        float r25431 = r25429 * r25430;
        float r25432 = cos(r25431);
        float r25433 = 2;
        float r25434 = pow(r25432, r25433);
        float r25435 = lambda1;
        float r25436 = lambda2;
        float r25437 = r25424 * r25436;
        float r25438 = r25435 * r25437;
        float r25439 = r25434 * r25438;
        float r25440 = pow(r25423, r25433);
        float r25441 = r25439 / r25440;
        float r25442 = r25435 * r25436;
        float r25443 = r25434 * r25442;
        float r25444 = r25443 / r25423;
        float r25445 = r25424 + r25444;
        float r25446 = r25441 + r25445;
        float r25447 = r25428 * r25446;
        float r25448 = 1.4329139041545177e+133;
        bool r25449 = r25425 <= r25448;
        float r25450 = r25429 * r25423;
        float r25451 = cos(r25450);
        float r25452 = r25429 * r25424;
        float r25453 = cos(r25452);
        float r25454 = r25451 * r25453;
        float r25455 = sin(r25450);
        float r25456 = sin(r25452);
        float r25457 = r25455 * r25456;
        float r25458 = r25454 - r25457;
        float r25459 = r25458 * r25458;
        float r25460 = r25436 * r25436;
        float r25461 = r25436 * r25433;
        float r25462 = r25435 - r25461;
        float r25463 = r25435 * r25462;
        float r25464 = r25460 + r25463;
        float r25465 = r25459 * r25464;
        float r25466 = r25424 - r25423;
        float r25467 = r25466 * r25466;
        float r25468 = r25465 + r25467;
        float r25469 = sqrt(r25468);
        float r25470 = r25428 * r25469;
        float r25471 = r25428 * r25425;
        float r25472 = r25449 ? r25470 : r25471;
        float r25473 = r25427 ? r25447 : r25472;
        return r25473;
}

double f_od(double R, double lambda1, double lambda2, double phi1, double phi2) {
        double r25474 = phi2;
        double r25475 = phi1;
        double r25476 = r25474 - r25475;
        double r25477 = -1.4030670556456484e+173;
        bool r25478 = r25476 <= r25477;
        double r25479 = R;
        double r25480 = 1/2;
        double r25481 = r25475 + r25474;
        double r25482 = r25480 * r25481;
        double r25483 = cos(r25482);
        double r25484 = 2;
        double r25485 = pow(r25483, r25484);
        double r25486 = lambda1;
        double r25487 = lambda2;
        double r25488 = r25475 * r25487;
        double r25489 = r25486 * r25488;
        double r25490 = r25485 * r25489;
        double r25491 = pow(r25474, r25484);
        double r25492 = r25490 / r25491;
        double r25493 = r25486 * r25487;
        double r25494 = r25485 * r25493;
        double r25495 = r25494 / r25474;
        double r25496 = r25475 + r25495;
        double r25497 = r25492 + r25496;
        double r25498 = r25479 * r25497;
        double r25499 = 1.4329139041545177e+133;
        bool r25500 = r25476 <= r25499;
        double r25501 = r25480 * r25474;
        double r25502 = cos(r25501);
        double r25503 = r25480 * r25475;
        double r25504 = cos(r25503);
        double r25505 = r25502 * r25504;
        double r25506 = sin(r25501);
        double r25507 = sin(r25503);
        double r25508 = r25506 * r25507;
        double r25509 = r25505 - r25508;
        double r25510 = r25509 * r25509;
        double r25511 = r25487 * r25487;
        double r25512 = r25487 * r25484;
        double r25513 = r25486 - r25512;
        double r25514 = r25486 * r25513;
        double r25515 = r25511 + r25514;
        double r25516 = r25510 * r25515;
        double r25517 = r25475 - r25474;
        double r25518 = r25517 * r25517;
        double r25519 = r25516 + r25518;
        double r25520 = sqrt(r25519);
        double r25521 = r25479 * r25520;
        double r25522 = r25479 * r25476;
        double r25523 = r25500 ? r25521 : r25522;
        double r25524 = r25478 ? r25498 : r25523;
        return r25524;
}

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 r25525, r25526, r25527, r25528, r25529, r25530, r25531, r25532, r25533, r25534, r25535, r25536, r25537, r25538, r25539, r25540, r25541;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25525);
        mpfr_init(r25526);
        mpfr_init(r25527);
        mpfr_init(r25528);
        mpfr_init(r25529);
        mpfr_init(r25530);
        mpfr_init(r25531);
        mpfr_init_set_str(r25532, "2", 10, MPFR_RNDN);
        mpfr_init(r25533);
        mpfr_init(r25534);
        mpfr_init(r25535);
        mpfr_init(r25536);
        mpfr_init(r25537);
        mpfr_init(r25538);
        mpfr_init(r25539);
        mpfr_init(r25540);
        mpfr_init(r25541);
}

double f_im(double R, double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r25525, R, MPFR_RNDN);
        mpfr_set_d(r25526, lambda1, MPFR_RNDN);
        mpfr_set_d(r25527, lambda2, MPFR_RNDN);
        mpfr_sub(r25528, r25526, r25527, MPFR_RNDN);
        mpfr_set_d(r25529, phi1, MPFR_RNDN);
        mpfr_set_d(r25530, phi2, MPFR_RNDN);
        mpfr_add(r25531, r25529, r25530, MPFR_RNDN);
        ;
        mpfr_div(r25533, r25531, r25532, MPFR_RNDN);
        mpfr_cos(r25534, r25533, MPFR_RNDN);
        mpfr_mul(r25535, r25528, r25534, MPFR_RNDN);
        mpfr_mul(r25536, r25535, r25535, MPFR_RNDN);
        mpfr_sub(r25537, r25529, r25530, MPFR_RNDN);
        mpfr_mul(r25538, r25537, r25537, MPFR_RNDN);
        mpfr_add(r25539, r25536, r25538, MPFR_RNDN);
        mpfr_sqrt(r25540, r25539, MPFR_RNDN);
        mpfr_mul(r25541, r25525, r25540, MPFR_RNDN);
        return mpfr_get_d(r25541, MPFR_RNDN);
}

static mpfr_t r25542, r25543, r25544, r25545, r25546, r25547, r25548, r25549, r25550, r25551, r25552, r25553, r25554, r25555, r25556, r25557, r25558, r25559, r25560, r25561, r25562, r25563, r25564, r25565, r25566, r25567, r25568, r25569, r25570, r25571, r25572, r25573, r25574, r25575, r25576, r25577, r25578, r25579, r25580, r25581, r25582, r25583, r25584, r25585, r25586, r25587, r25588, r25589, r25590, r25591, r25592;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25542);
        mpfr_init(r25543);
        mpfr_init(r25544);
        mpfr_init_set_str(r25545, "-1.4030670556456484e+173", 10, MPFR_RNDN);
        mpfr_init(r25546);
        mpfr_init(r25547);
        mpfr_init_set_str(r25548, "1/2", 10, MPFR_RNDN);
        mpfr_init(r25549);
        mpfr_init(r25550);
        mpfr_init(r25551);
        mpfr_init_set_str(r25552, "2", 10, MPFR_RNDN);
        mpfr_init(r25553);
        mpfr_init(r25554);
        mpfr_init(r25555);
        mpfr_init(r25556);
        mpfr_init(r25557);
        mpfr_init(r25558);
        mpfr_init(r25559);
        mpfr_init(r25560);
        mpfr_init(r25561);
        mpfr_init(r25562);
        mpfr_init(r25563);
        mpfr_init(r25564);
        mpfr_init(r25565);
        mpfr_init(r25566);
        mpfr_init_set_str(r25567, "1.4329139041545177e+133", 10, MPFR_RNDN);
        mpfr_init(r25568);
        mpfr_init(r25569);
        mpfr_init(r25570);
        mpfr_init(r25571);
        mpfr_init(r25572);
        mpfr_init(r25573);
        mpfr_init(r25574);
        mpfr_init(r25575);
        mpfr_init(r25576);
        mpfr_init(r25577);
        mpfr_init(r25578);
        mpfr_init(r25579);
        mpfr_init(r25580);
        mpfr_init(r25581);
        mpfr_init(r25582);
        mpfr_init(r25583);
        mpfr_init(r25584);
        mpfr_init(r25585);
        mpfr_init(r25586);
        mpfr_init(r25587);
        mpfr_init(r25588);
        mpfr_init(r25589);
        mpfr_init(r25590);
        mpfr_init(r25591);
        mpfr_init(r25592);
}

double f_fm(double R, double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r25542, phi2, MPFR_RNDN);
        mpfr_set_d(r25543, phi1, MPFR_RNDN);
        mpfr_sub(r25544, r25542, r25543, MPFR_RNDN);
        ;
        mpfr_set_si(r25546, mpfr_cmp(r25544, r25545) <= 0, MPFR_RNDN);
        mpfr_set_d(r25547, R, MPFR_RNDN);
        ;
        mpfr_add(r25549, r25543, r25542, MPFR_RNDN);
        mpfr_mul(r25550, r25548, r25549, MPFR_RNDN);
        mpfr_cos(r25551, r25550, MPFR_RNDN);
        ;
        mpfr_pow(r25553, r25551, r25552, MPFR_RNDN);
        mpfr_set_d(r25554, lambda1, MPFR_RNDN);
        mpfr_set_d(r25555, lambda2, MPFR_RNDN);
        mpfr_mul(r25556, r25543, r25555, MPFR_RNDN);
        mpfr_mul(r25557, r25554, r25556, MPFR_RNDN);
        mpfr_mul(r25558, r25553, r25557, MPFR_RNDN);
        mpfr_pow(r25559, r25542, r25552, MPFR_RNDN);
        mpfr_div(r25560, r25558, r25559, MPFR_RNDN);
        mpfr_mul(r25561, r25554, r25555, MPFR_RNDN);
        mpfr_mul(r25562, r25553, r25561, MPFR_RNDN);
        mpfr_div(r25563, r25562, r25542, MPFR_RNDN);
        mpfr_add(r25564, r25543, r25563, MPFR_RNDN);
        mpfr_add(r25565, r25560, r25564, MPFR_RNDN);
        mpfr_mul(r25566, r25547, r25565, MPFR_RNDN);
        ;
        mpfr_set_si(r25568, mpfr_cmp(r25544, r25567) <= 0, MPFR_RNDN);
        mpfr_mul(r25569, r25548, r25542, MPFR_RNDN);
        mpfr_cos(r25570, r25569, MPFR_RNDN);
        mpfr_mul(r25571, r25548, r25543, MPFR_RNDN);
        mpfr_cos(r25572, r25571, MPFR_RNDN);
        mpfr_mul(r25573, r25570, r25572, MPFR_RNDN);
        mpfr_sin(r25574, r25569, MPFR_RNDN);
        mpfr_sin(r25575, r25571, MPFR_RNDN);
        mpfr_mul(r25576, r25574, r25575, MPFR_RNDN);
        mpfr_sub(r25577, r25573, r25576, MPFR_RNDN);
        mpfr_mul(r25578, r25577, r25577, MPFR_RNDN);
        mpfr_mul(r25579, r25555, r25555, MPFR_RNDN);
        mpfr_mul(r25580, r25555, r25552, MPFR_RNDN);
        mpfr_sub(r25581, r25554, r25580, MPFR_RNDN);
        mpfr_mul(r25582, r25554, r25581, MPFR_RNDN);
        mpfr_add(r25583, r25579, r25582, MPFR_RNDN);
        mpfr_mul(r25584, r25578, r25583, MPFR_RNDN);
        mpfr_sub(r25585, r25543, r25542, MPFR_RNDN);
        mpfr_mul(r25586, r25585, r25585, MPFR_RNDN);
        mpfr_add(r25587, r25584, r25586, MPFR_RNDN);
        mpfr_sqrt(r25588, r25587, MPFR_RNDN);
        mpfr_mul(r25589, r25547, r25588, MPFR_RNDN);
        mpfr_mul(r25590, r25547, r25544, MPFR_RNDN);
        if (mpfr_get_si(r25568, MPFR_RNDN)) { mpfr_set(r25591, r25589, MPFR_RNDN); } else { mpfr_set(r25591, r25590, MPFR_RNDN); };
        if (mpfr_get_si(r25546, MPFR_RNDN)) { mpfr_set(r25592, r25566, MPFR_RNDN); } else { mpfr_set(r25592, r25591, MPFR_RNDN); };
        return mpfr_get_d(r25592, MPFR_RNDN);
}

static mpfr_t r25593, r25594, r25595, r25596, r25597, r25598, r25599, r25600, r25601, r25602, r25603, r25604, r25605, r25606, r25607, r25608, r25609, r25610, r25611, r25612, r25613, r25614, r25615, r25616, r25617, r25618, r25619, r25620, r25621, r25622, r25623, r25624, r25625, r25626, r25627, r25628, r25629, r25630, r25631, r25632, r25633, r25634, r25635, r25636, r25637, r25638, r25639, r25640, r25641, r25642, r25643;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r25593);
        mpfr_init(r25594);
        mpfr_init(r25595);
        mpfr_init_set_str(r25596, "-1.4030670556456484e+173", 10, MPFR_RNDN);
        mpfr_init(r25597);
        mpfr_init(r25598);
        mpfr_init_set_str(r25599, "1/2", 10, MPFR_RNDN);
        mpfr_init(r25600);
        mpfr_init(r25601);
        mpfr_init(r25602);
        mpfr_init_set_str(r25603, "2", 10, MPFR_RNDN);
        mpfr_init(r25604);
        mpfr_init(r25605);
        mpfr_init(r25606);
        mpfr_init(r25607);
        mpfr_init(r25608);
        mpfr_init(r25609);
        mpfr_init(r25610);
        mpfr_init(r25611);
        mpfr_init(r25612);
        mpfr_init(r25613);
        mpfr_init(r25614);
        mpfr_init(r25615);
        mpfr_init(r25616);
        mpfr_init(r25617);
        mpfr_init_set_str(r25618, "1.4329139041545177e+133", 10, MPFR_RNDN);
        mpfr_init(r25619);
        mpfr_init(r25620);
        mpfr_init(r25621);
        mpfr_init(r25622);
        mpfr_init(r25623);
        mpfr_init(r25624);
        mpfr_init(r25625);
        mpfr_init(r25626);
        mpfr_init(r25627);
        mpfr_init(r25628);
        mpfr_init(r25629);
        mpfr_init(r25630);
        mpfr_init(r25631);
        mpfr_init(r25632);
        mpfr_init(r25633);
        mpfr_init(r25634);
        mpfr_init(r25635);
        mpfr_init(r25636);
        mpfr_init(r25637);
        mpfr_init(r25638);
        mpfr_init(r25639);
        mpfr_init(r25640);
        mpfr_init(r25641);
        mpfr_init(r25642);
        mpfr_init(r25643);
}

double f_dm(double R, double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r25593, phi2, MPFR_RNDN);
        mpfr_set_d(r25594, phi1, MPFR_RNDN);
        mpfr_sub(r25595, r25593, r25594, MPFR_RNDN);
        ;
        mpfr_set_si(r25597, mpfr_cmp(r25595, r25596) <= 0, MPFR_RNDN);
        mpfr_set_d(r25598, R, MPFR_RNDN);
        ;
        mpfr_add(r25600, r25594, r25593, MPFR_RNDN);
        mpfr_mul(r25601, r25599, r25600, MPFR_RNDN);
        mpfr_cos(r25602, r25601, MPFR_RNDN);
        ;
        mpfr_pow(r25604, r25602, r25603, MPFR_RNDN);
        mpfr_set_d(r25605, lambda1, MPFR_RNDN);
        mpfr_set_d(r25606, lambda2, MPFR_RNDN);
        mpfr_mul(r25607, r25594, r25606, MPFR_RNDN);
        mpfr_mul(r25608, r25605, r25607, MPFR_RNDN);
        mpfr_mul(r25609, r25604, r25608, MPFR_RNDN);
        mpfr_pow(r25610, r25593, r25603, MPFR_RNDN);
        mpfr_div(r25611, r25609, r25610, MPFR_RNDN);
        mpfr_mul(r25612, r25605, r25606, MPFR_RNDN);
        mpfr_mul(r25613, r25604, r25612, MPFR_RNDN);
        mpfr_div(r25614, r25613, r25593, MPFR_RNDN);
        mpfr_add(r25615, r25594, r25614, MPFR_RNDN);
        mpfr_add(r25616, r25611, r25615, MPFR_RNDN);
        mpfr_mul(r25617, r25598, r25616, MPFR_RNDN);
        ;
        mpfr_set_si(r25619, mpfr_cmp(r25595, r25618) <= 0, MPFR_RNDN);
        mpfr_mul(r25620, r25599, r25593, MPFR_RNDN);
        mpfr_cos(r25621, r25620, MPFR_RNDN);
        mpfr_mul(r25622, r25599, r25594, MPFR_RNDN);
        mpfr_cos(r25623, r25622, MPFR_RNDN);
        mpfr_mul(r25624, r25621, r25623, MPFR_RNDN);
        mpfr_sin(r25625, r25620, MPFR_RNDN);
        mpfr_sin(r25626, r25622, MPFR_RNDN);
        mpfr_mul(r25627, r25625, r25626, MPFR_RNDN);
        mpfr_sub(r25628, r25624, r25627, MPFR_RNDN);
        mpfr_mul(r25629, r25628, r25628, MPFR_RNDN);
        mpfr_mul(r25630, r25606, r25606, MPFR_RNDN);
        mpfr_mul(r25631, r25606, r25603, MPFR_RNDN);
        mpfr_sub(r25632, r25605, r25631, MPFR_RNDN);
        mpfr_mul(r25633, r25605, r25632, MPFR_RNDN);
        mpfr_add(r25634, r25630, r25633, MPFR_RNDN);
        mpfr_mul(r25635, r25629, r25634, MPFR_RNDN);
        mpfr_sub(r25636, r25594, r25593, MPFR_RNDN);
        mpfr_mul(r25637, r25636, r25636, MPFR_RNDN);
        mpfr_add(r25638, r25635, r25637, MPFR_RNDN);
        mpfr_sqrt(r25639, r25638, MPFR_RNDN);
        mpfr_mul(r25640, r25598, r25639, MPFR_RNDN);
        mpfr_mul(r25641, r25598, r25595, MPFR_RNDN);
        if (mpfr_get_si(r25619, MPFR_RNDN)) { mpfr_set(r25642, r25640, MPFR_RNDN); } else { mpfr_set(r25642, r25641, MPFR_RNDN); };
        if (mpfr_get_si(r25597, MPFR_RNDN)) { mpfr_set(r25643, r25617, MPFR_RNDN); } else { mpfr_set(r25643, r25642, MPFR_RNDN); };
        return mpfr_get_d(r25643, MPFR_RNDN);
}

