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

char *name = "Bearing on a great circle";

double f_if(float lambda1, float lambda2, float phi1, float phi2) {
        float r26542 = lambda1;
        float r26543 = lambda2;
        float r26544 = r26542 - r26543;
        float r26545 = sin(r26544);
        float r26546 = phi2;
        float r26547 = cos(r26546);
        float r26548 = r26545 * r26547;
        float r26549 = phi1;
        float r26550 = cos(r26549);
        float r26551 = sin(r26546);
        float r26552 = r26550 * r26551;
        float r26553 = sin(r26549);
        float r26554 = r26553 * r26547;
        float r26555 = cos(r26544);
        float r26556 = r26554 * r26555;
        float r26557 = r26552 - r26556;
        float r26558 = atan2(r26548, r26557);
        return r26558;
}

double f_id(double lambda1, double lambda2, double phi1, double phi2) {
        double r26559 = lambda1;
        double r26560 = lambda2;
        double r26561 = r26559 - r26560;
        double r26562 = sin(r26561);
        double r26563 = phi2;
        double r26564 = cos(r26563);
        double r26565 = r26562 * r26564;
        double r26566 = phi1;
        double r26567 = cos(r26566);
        double r26568 = sin(r26563);
        double r26569 = r26567 * r26568;
        double r26570 = sin(r26566);
        double r26571 = r26570 * r26564;
        double r26572 = cos(r26561);
        double r26573 = r26571 * r26572;
        double r26574 = r26569 - r26573;
        double r26575 = atan2(r26565, r26574);
        return r26575;
}


double f_of(float lambda1, float lambda2, float phi1, float phi2) {
        float r26576 = lambda1;
        float r26577 = sin(r26576);
        float r26578 = lambda2;
        float r26579 = cos(r26578);
        float r26580 = r26577 * r26579;
        float r26581 = cos(r26576);
        float r26582 = -r26578;
        float r26583 = sin(r26582);
        float r26584 = r26581 * r26583;
        float r26585 = r26580 + r26584;
        float r26586 = phi2;
        float r26587 = cos(r26586);
        float r26588 = r26585 * r26587;
        float r26589 = phi1;
        float r26590 = cos(r26589);
        float r26591 = sin(r26586);
        float r26592 = cbrt(r26591);
        float r26593 = r26592 * r26592;
        float r26594 = r26590 * r26593;
        float r26595 = r26594 * r26592;
        float r26596 = sin(r26589);
        float r26597 = r26596 * r26587;
        float r26598 = r26581 * r26579;
        float r26599 = r26577 * r26583;
        float r26600 = r26598 - r26599;
        float r26601 = r26597 * r26600;
        float r26602 = r26595 - r26601;
        float r26603 = atan2(r26588, r26602);
        return r26603;
}

double f_od(double lambda1, double lambda2, double phi1, double phi2) {
        double r26604 = lambda1;
        double r26605 = sin(r26604);
        double r26606 = lambda2;
        double r26607 = cos(r26606);
        double r26608 = r26605 * r26607;
        double r26609 = cos(r26604);
        double r26610 = -r26606;
        double r26611 = sin(r26610);
        double r26612 = r26609 * r26611;
        double r26613 = r26608 + r26612;
        double r26614 = phi2;
        double r26615 = cos(r26614);
        double r26616 = r26613 * r26615;
        double r26617 = phi1;
        double r26618 = cos(r26617);
        double r26619 = sin(r26614);
        double r26620 = cbrt(r26619);
        double r26621 = r26620 * r26620;
        double r26622 = r26618 * r26621;
        double r26623 = r26622 * r26620;
        double r26624 = sin(r26617);
        double r26625 = r26624 * r26615;
        double r26626 = r26609 * r26607;
        double r26627 = r26605 * r26611;
        double r26628 = r26626 - r26627;
        double r26629 = r26625 * r26628;
        double r26630 = r26623 - r26629;
        double r26631 = atan2(r26616, r26630);
        return r26631;
}

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 r26632, r26633, r26634, r26635, r26636, r26637, r26638, r26639, r26640, r26641, r26642, r26643, r26644, r26645, r26646, r26647, r26648;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26632);
        mpfr_init(r26633);
        mpfr_init(r26634);
        mpfr_init(r26635);
        mpfr_init(r26636);
        mpfr_init(r26637);
        mpfr_init(r26638);
        mpfr_init(r26639);
        mpfr_init(r26640);
        mpfr_init(r26641);
        mpfr_init(r26642);
        mpfr_init(r26643);
        mpfr_init(r26644);
        mpfr_init(r26645);
        mpfr_init(r26646);
        mpfr_init(r26647);
        mpfr_init(r26648);
}

double f_im(double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r26632, lambda1, MPFR_RNDN);
        mpfr_set_d(r26633, lambda2, MPFR_RNDN);
        mpfr_sub(r26634, r26632, r26633, MPFR_RNDN);
        mpfr_sin(r26635, r26634, MPFR_RNDN);
        mpfr_set_d(r26636, phi2, MPFR_RNDN);
        mpfr_cos(r26637, r26636, MPFR_RNDN);
        mpfr_mul(r26638, r26635, r26637, MPFR_RNDN);
        mpfr_set_d(r26639, phi1, MPFR_RNDN);
        mpfr_cos(r26640, r26639, MPFR_RNDN);
        mpfr_sin(r26641, r26636, MPFR_RNDN);
        mpfr_mul(r26642, r26640, r26641, MPFR_RNDN);
        mpfr_sin(r26643, r26639, MPFR_RNDN);
        mpfr_mul(r26644, r26643, r26637, MPFR_RNDN);
        mpfr_cos(r26645, r26634, MPFR_RNDN);
        mpfr_mul(r26646, r26644, r26645, MPFR_RNDN);
        mpfr_sub(r26647, r26642, r26646, MPFR_RNDN);
        mpfr_atan2(r26648, r26638, r26647, MPFR_RNDN);
        return mpfr_get_d(r26648, MPFR_RNDN);
}

static mpfr_t r26649, r26650, r26651, r26652, r26653, r26654, r26655, r26656, r26657, r26658, r26659, r26660, r26661, r26662, r26663, r26664, r26665, r26666, r26667, r26668, r26669, r26670, r26671, r26672, r26673, r26674, r26675, r26676;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26649);
        mpfr_init(r26650);
        mpfr_init(r26651);
        mpfr_init(r26652);
        mpfr_init(r26653);
        mpfr_init(r26654);
        mpfr_init(r26655);
        mpfr_init(r26656);
        mpfr_init(r26657);
        mpfr_init(r26658);
        mpfr_init(r26659);
        mpfr_init(r26660);
        mpfr_init(r26661);
        mpfr_init(r26662);
        mpfr_init(r26663);
        mpfr_init(r26664);
        mpfr_init(r26665);
        mpfr_init(r26666);
        mpfr_init(r26667);
        mpfr_init(r26668);
        mpfr_init(r26669);
        mpfr_init(r26670);
        mpfr_init(r26671);
        mpfr_init(r26672);
        mpfr_init(r26673);
        mpfr_init(r26674);
        mpfr_init(r26675);
        mpfr_init(r26676);
}

double f_fm(double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r26649, lambda1, MPFR_RNDN);
        mpfr_sin(r26650, r26649, MPFR_RNDN);
        mpfr_set_d(r26651, lambda2, MPFR_RNDN);
        mpfr_cos(r26652, r26651, MPFR_RNDN);
        mpfr_mul(r26653, r26650, r26652, MPFR_RNDN);
        mpfr_cos(r26654, r26649, MPFR_RNDN);
        mpfr_neg(r26655, r26651, MPFR_RNDN);
        mpfr_sin(r26656, r26655, MPFR_RNDN);
        mpfr_mul(r26657, r26654, r26656, MPFR_RNDN);
        mpfr_add(r26658, r26653, r26657, MPFR_RNDN);
        mpfr_set_d(r26659, phi2, MPFR_RNDN);
        mpfr_cos(r26660, r26659, MPFR_RNDN);
        mpfr_mul(r26661, r26658, r26660, MPFR_RNDN);
        mpfr_set_d(r26662, phi1, MPFR_RNDN);
        mpfr_cos(r26663, r26662, MPFR_RNDN);
        mpfr_sin(r26664, r26659, MPFR_RNDN);
        mpfr_cbrt(r26665, r26664, MPFR_RNDN);
        mpfr_mul(r26666, r26665, r26665, MPFR_RNDN);
        mpfr_mul(r26667, r26663, r26666, MPFR_RNDN);
        mpfr_mul(r26668, r26667, r26665, MPFR_RNDN);
        mpfr_sin(r26669, r26662, MPFR_RNDN);
        mpfr_mul(r26670, r26669, r26660, MPFR_RNDN);
        mpfr_mul(r26671, r26654, r26652, MPFR_RNDN);
        mpfr_mul(r26672, r26650, r26656, MPFR_RNDN);
        mpfr_sub(r26673, r26671, r26672, MPFR_RNDN);
        mpfr_mul(r26674, r26670, r26673, MPFR_RNDN);
        mpfr_sub(r26675, r26668, r26674, MPFR_RNDN);
        mpfr_atan2(r26676, r26661, r26675, MPFR_RNDN);
        return mpfr_get_d(r26676, MPFR_RNDN);
}

static mpfr_t r26677, r26678, r26679, r26680, r26681, r26682, r26683, r26684, r26685, r26686, r26687, r26688, r26689, r26690, r26691, r26692, r26693, r26694, r26695, r26696, r26697, r26698, r26699, r26700, r26701, r26702, r26703, r26704;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(1360);
        mpfr_init(r26677);
        mpfr_init(r26678);
        mpfr_init(r26679);
        mpfr_init(r26680);
        mpfr_init(r26681);
        mpfr_init(r26682);
        mpfr_init(r26683);
        mpfr_init(r26684);
        mpfr_init(r26685);
        mpfr_init(r26686);
        mpfr_init(r26687);
        mpfr_init(r26688);
        mpfr_init(r26689);
        mpfr_init(r26690);
        mpfr_init(r26691);
        mpfr_init(r26692);
        mpfr_init(r26693);
        mpfr_init(r26694);
        mpfr_init(r26695);
        mpfr_init(r26696);
        mpfr_init(r26697);
        mpfr_init(r26698);
        mpfr_init(r26699);
        mpfr_init(r26700);
        mpfr_init(r26701);
        mpfr_init(r26702);
        mpfr_init(r26703);
        mpfr_init(r26704);
}

double f_dm(double lambda1, double lambda2, double phi1, double phi2) {
        mpfr_set_d(r26677, lambda1, MPFR_RNDN);
        mpfr_sin(r26678, r26677, MPFR_RNDN);
        mpfr_set_d(r26679, lambda2, MPFR_RNDN);
        mpfr_cos(r26680, r26679, MPFR_RNDN);
        mpfr_mul(r26681, r26678, r26680, MPFR_RNDN);
        mpfr_cos(r26682, r26677, MPFR_RNDN);
        mpfr_neg(r26683, r26679, MPFR_RNDN);
        mpfr_sin(r26684, r26683, MPFR_RNDN);
        mpfr_mul(r26685, r26682, r26684, MPFR_RNDN);
        mpfr_add(r26686, r26681, r26685, MPFR_RNDN);
        mpfr_set_d(r26687, phi2, MPFR_RNDN);
        mpfr_cos(r26688, r26687, MPFR_RNDN);
        mpfr_mul(r26689, r26686, r26688, MPFR_RNDN);
        mpfr_set_d(r26690, phi1, MPFR_RNDN);
        mpfr_cos(r26691, r26690, MPFR_RNDN);
        mpfr_sin(r26692, r26687, MPFR_RNDN);
        mpfr_cbrt(r26693, r26692, MPFR_RNDN);
        mpfr_mul(r26694, r26693, r26693, MPFR_RNDN);
        mpfr_mul(r26695, r26691, r26694, MPFR_RNDN);
        mpfr_mul(r26696, r26695, r26693, MPFR_RNDN);
        mpfr_sin(r26697, r26690, MPFR_RNDN);
        mpfr_mul(r26698, r26697, r26688, MPFR_RNDN);
        mpfr_mul(r26699, r26682, r26680, MPFR_RNDN);
        mpfr_mul(r26700, r26678, r26684, MPFR_RNDN);
        mpfr_sub(r26701, r26699, r26700, MPFR_RNDN);
        mpfr_mul(r26702, r26698, r26701, MPFR_RNDN);
        mpfr_sub(r26703, r26696, r26702, MPFR_RNDN);
        mpfr_atan2(r26704, r26689, r26703, MPFR_RNDN);
        return mpfr_get_d(r26704, MPFR_RNDN);
}

