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

char *name = "Linear.Matrix:det33 from linear-1.19.1.3";

double f_if(float x, float y, float z, float t, float a, float b, float c, float i, float j) {
        float r22535 = x;
        float r22536 = y;
        float r22537 = z;
        float r22538 = r22536 * r22537;
        float r22539 = t;
        float r22540 = a;
        float r22541 = r22539 * r22540;
        float r22542 = r22538 - r22541;
        float r22543 = r22535 * r22542;
        float r22544 = b;
        float r22545 = c;
        float r22546 = r22545 * r22537;
        float r22547 = i;
        float r22548 = r22547 * r22540;
        float r22549 = r22546 - r22548;
        float r22550 = r22544 * r22549;
        float r22551 = r22543 - r22550;
        float r22552 = j;
        float r22553 = r22545 * r22539;
        float r22554 = r22547 * r22536;
        float r22555 = r22553 - r22554;
        float r22556 = r22552 * r22555;
        float r22557 = r22551 + r22556;
        return r22557;
}

double f_id(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
        double r22558 = x;
        double r22559 = y;
        double r22560 = z;
        double r22561 = r22559 * r22560;
        double r22562 = t;
        double r22563 = a;
        double r22564 = r22562 * r22563;
        double r22565 = r22561 - r22564;
        double r22566 = r22558 * r22565;
        double r22567 = b;
        double r22568 = c;
        double r22569 = r22568 * r22560;
        double r22570 = i;
        double r22571 = r22570 * r22563;
        double r22572 = r22569 - r22571;
        double r22573 = r22567 * r22572;
        double r22574 = r22566 - r22573;
        double r22575 = j;
        double r22576 = r22568 * r22562;
        double r22577 = r22570 * r22559;
        double r22578 = r22576 - r22577;
        double r22579 = r22575 * r22578;
        double r22580 = r22574 + r22579;
        return r22580;
}


double f_of(float x, float y, float z, float t, float a, float b, float c, float i, float j) {
        float r22581 = j;
        float r22582 = c;
        float r22583 = t;
        float r22584 = r22582 * r22583;
        float r22585 = i;
        float r22586 = y;
        float r22587 = r22585 * r22586;
        float r22588 = r22584 - r22587;
        float r22589 = z;
        float r22590 = r22589 * r22586;
        float r22591 = a;
        float r22592 = r22591 * r22583;
        float r22593 = r22590 - r22592;
        float r22594 = x;
        float r22595 = r22593 * r22594;
        float r22596 = 0;
        float r22597 = r22595 - r22596;
        float r22598 = fma(r22581, r22588, r22597);
        float r22599 = -8.689672231024969e+290;
        bool r22600 = r22598 <= r22599;
        float r22601 = r22583 * r22582;
        float r22602 = r22586 * r22585;
        float r22603 = r22601 - r22602;
        float r22604 = r22591 * r22585;
        float r22605 = r22582 * r22589;
        float r22606 = r22604 - r22605;
        float r22607 = b;
        float r22608 = r22606 * r22607;
        float r22609 = r22591 * r22594;
        float r22610 = r22609 * r22583;
        float r22611 = r22608 - r22610;
        float r22612 = fma(r22581, r22603, r22611);
        float r22613 = 1.2513342757769092e+305;
        bool r22614 = r22598 <= r22613;
        float r22615 = cbrt(r22593);
        float r22616 = r22615 * r22615;
        float r22617 = r22615 * r22594;
        float r22618 = r22616 * r22617;
        float r22619 = r22589 * r22582;
        float r22620 = r22585 * r22591;
        float r22621 = r22619 - r22620;
        float r22622 = r22621 * r22607;
        float r22623 = r22618 - r22622;
        float r22624 = fma(r22581, r22588, r22623);
        float r22625 = r22614 ? r22624 : r22612;
        float r22626 = r22600 ? r22612 : r22625;
        return r22626;
}

double f_od(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
        double r22627 = j;
        double r22628 = c;
        double r22629 = t;
        double r22630 = r22628 * r22629;
        double r22631 = i;
        double r22632 = y;
        double r22633 = r22631 * r22632;
        double r22634 = r22630 - r22633;
        double r22635 = z;
        double r22636 = r22635 * r22632;
        double r22637 = a;
        double r22638 = r22637 * r22629;
        double r22639 = r22636 - r22638;
        double r22640 = x;
        double r22641 = r22639 * r22640;
        double r22642 = 0;
        double r22643 = r22641 - r22642;
        double r22644 = fma(r22627, r22634, r22643);
        double r22645 = -8.689672231024969e+290;
        bool r22646 = r22644 <= r22645;
        double r22647 = r22629 * r22628;
        double r22648 = r22632 * r22631;
        double r22649 = r22647 - r22648;
        double r22650 = r22637 * r22631;
        double r22651 = r22628 * r22635;
        double r22652 = r22650 - r22651;
        double r22653 = b;
        double r22654 = r22652 * r22653;
        double r22655 = r22637 * r22640;
        double r22656 = r22655 * r22629;
        double r22657 = r22654 - r22656;
        double r22658 = fma(r22627, r22649, r22657);
        double r22659 = 1.2513342757769092e+305;
        bool r22660 = r22644 <= r22659;
        double r22661 = cbrt(r22639);
        double r22662 = r22661 * r22661;
        double r22663 = r22661 * r22640;
        double r22664 = r22662 * r22663;
        double r22665 = r22635 * r22628;
        double r22666 = r22631 * r22637;
        double r22667 = r22665 - r22666;
        double r22668 = r22667 * r22653;
        double r22669 = r22664 - r22668;
        double r22670 = fma(r22627, r22634, r22669);
        double r22671 = r22660 ? r22670 : r22658;
        double r22672 = r22646 ? r22658 : r22671;
        return r22672;
}

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 r22673, r22674, r22675, r22676, r22677, r22678, r22679, r22680, r22681, r22682, r22683, r22684, r22685, r22686, r22687, r22688, r22689, r22690, r22691, r22692, r22693, r22694, r22695;

void setup_mpfr_f_im() {
        mpfr_set_default_prec(400);
        mpfr_init(r22673);
        mpfr_init(r22674);
        mpfr_init(r22675);
        mpfr_init(r22676);
        mpfr_init(r22677);
        mpfr_init(r22678);
        mpfr_init(r22679);
        mpfr_init(r22680);
        mpfr_init(r22681);
        mpfr_init(r22682);
        mpfr_init(r22683);
        mpfr_init(r22684);
        mpfr_init(r22685);
        mpfr_init(r22686);
        mpfr_init(r22687);
        mpfr_init(r22688);
        mpfr_init(r22689);
        mpfr_init(r22690);
        mpfr_init(r22691);
        mpfr_init(r22692);
        mpfr_init(r22693);
        mpfr_init(r22694);
        mpfr_init(r22695);
}

double f_im(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
        mpfr_set_d(r22673, x, MPFR_RNDN);
        mpfr_set_d(r22674, y, MPFR_RNDN);
        mpfr_set_d(r22675, z, MPFR_RNDN);
        mpfr_mul(r22676, r22674, r22675, MPFR_RNDN);
        mpfr_set_d(r22677, t, MPFR_RNDN);
        mpfr_set_d(r22678, a, MPFR_RNDN);
        mpfr_mul(r22679, r22677, r22678, MPFR_RNDN);
        mpfr_sub(r22680, r22676, r22679, MPFR_RNDN);
        mpfr_mul(r22681, r22673, r22680, MPFR_RNDN);
        mpfr_set_d(r22682, b, MPFR_RNDN);
        mpfr_set_d(r22683, c, MPFR_RNDN);
        mpfr_mul(r22684, r22683, r22675, MPFR_RNDN);
        mpfr_set_d(r22685, i, MPFR_RNDN);
        mpfr_mul(r22686, r22685, r22678, MPFR_RNDN);
        mpfr_sub(r22687, r22684, r22686, MPFR_RNDN);
        mpfr_mul(r22688, r22682, r22687, MPFR_RNDN);
        mpfr_sub(r22689, r22681, r22688, MPFR_RNDN);
        mpfr_set_d(r22690, j, MPFR_RNDN);
        mpfr_mul(r22691, r22683, r22677, MPFR_RNDN);
        mpfr_mul(r22692, r22685, r22674, MPFR_RNDN);
        mpfr_sub(r22693, r22691, r22692, MPFR_RNDN);
        mpfr_mul(r22694, r22690, r22693, MPFR_RNDN);
        mpfr_add(r22695, r22689, r22694, MPFR_RNDN);
        return mpfr_get_d(r22695, MPFR_RNDN);
}

static mpfr_t r22696, r22697, r22698, r22699, r22700, r22701, r22702, r22703, r22704, r22705, r22706, r22707, r22708, r22709, r22710, r22711, r22712, r22713, r22714, r22715, r22716, r22717, r22718, r22719, r22720, r22721, r22722, r22723, r22724, r22725, r22726, r22727, r22728, r22729, r22730, r22731, r22732, r22733, r22734, r22735, r22736, r22737, r22738, r22739, r22740, r22741;

void setup_mpfr_f_fm() {
        mpfr_set_default_prec(400);
        mpfr_init(r22696);
        mpfr_init(r22697);
        mpfr_init(r22698);
        mpfr_init(r22699);
        mpfr_init(r22700);
        mpfr_init(r22701);
        mpfr_init(r22702);
        mpfr_init(r22703);
        mpfr_init(r22704);
        mpfr_init(r22705);
        mpfr_init(r22706);
        mpfr_init(r22707);
        mpfr_init(r22708);
        mpfr_init(r22709);
        mpfr_init(r22710);
        mpfr_init_set_str(r22711, "0", 10, MPFR_RNDN);
        mpfr_init(r22712);
        mpfr_init(r22713);
        mpfr_init_set_str(r22714, "-8.689672231024969e+290", 10, MPFR_RNDN);
        mpfr_init(r22715);
        mpfr_init(r22716);
        mpfr_init(r22717);
        mpfr_init(r22718);
        mpfr_init(r22719);
        mpfr_init(r22720);
        mpfr_init(r22721);
        mpfr_init(r22722);
        mpfr_init(r22723);
        mpfr_init(r22724);
        mpfr_init(r22725);
        mpfr_init(r22726);
        mpfr_init(r22727);
        mpfr_init_set_str(r22728, "1.2513342757769092e+305", 10, MPFR_RNDN);
        mpfr_init(r22729);
        mpfr_init(r22730);
        mpfr_init(r22731);
        mpfr_init(r22732);
        mpfr_init(r22733);
        mpfr_init(r22734);
        mpfr_init(r22735);
        mpfr_init(r22736);
        mpfr_init(r22737);
        mpfr_init(r22738);
        mpfr_init(r22739);
        mpfr_init(r22740);
        mpfr_init(r22741);
}

double f_fm(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
        mpfr_set_d(r22696, j, MPFR_RNDN);
        mpfr_set_d(r22697, c, MPFR_RNDN);
        mpfr_set_d(r22698, t, MPFR_RNDN);
        mpfr_mul(r22699, r22697, r22698, MPFR_RNDN);
        mpfr_set_d(r22700, i, MPFR_RNDN);
        mpfr_set_d(r22701, y, MPFR_RNDN);
        mpfr_mul(r22702, r22700, r22701, MPFR_RNDN);
        mpfr_sub(r22703, r22699, r22702, MPFR_RNDN);
        mpfr_set_d(r22704, z, MPFR_RNDN);
        mpfr_mul(r22705, r22704, r22701, MPFR_RNDN);
        mpfr_set_d(r22706, a, MPFR_RNDN);
        mpfr_mul(r22707, r22706, r22698, MPFR_RNDN);
        mpfr_sub(r22708, r22705, r22707, MPFR_RNDN);
        mpfr_set_d(r22709, x, MPFR_RNDN);
        mpfr_mul(r22710, r22708, r22709, MPFR_RNDN);
        ;
        mpfr_sub(r22712, r22710, r22711, MPFR_RNDN);
        mpfr_fma(r22713, r22696, r22703, r22712, MPFR_RNDN);
        ;
        mpfr_set_si(r22715, mpfr_cmp(r22713, r22714) <= 0, MPFR_RNDN);
        mpfr_mul(r22716, r22698, r22697, MPFR_RNDN);
        mpfr_mul(r22717, r22701, r22700, MPFR_RNDN);
        mpfr_sub(r22718, r22716, r22717, MPFR_RNDN);
        mpfr_mul(r22719, r22706, r22700, MPFR_RNDN);
        mpfr_mul(r22720, r22697, r22704, MPFR_RNDN);
        mpfr_sub(r22721, r22719, r22720, MPFR_RNDN);
        mpfr_set_d(r22722, b, MPFR_RNDN);
        mpfr_mul(r22723, r22721, r22722, MPFR_RNDN);
        mpfr_mul(r22724, r22706, r22709, MPFR_RNDN);
        mpfr_mul(r22725, r22724, r22698, MPFR_RNDN);
        mpfr_sub(r22726, r22723, r22725, MPFR_RNDN);
        mpfr_fma(r22727, r22696, r22718, r22726, MPFR_RNDN);
        ;
        mpfr_set_si(r22729, mpfr_cmp(r22713, r22728) <= 0, MPFR_RNDN);
        mpfr_cbrt(r22730, r22708, MPFR_RNDN);
        mpfr_mul(r22731, r22730, r22730, MPFR_RNDN);
        mpfr_mul(r22732, r22730, r22709, MPFR_RNDN);
        mpfr_mul(r22733, r22731, r22732, MPFR_RNDN);
        mpfr_mul(r22734, r22704, r22697, MPFR_RNDN);
        mpfr_mul(r22735, r22700, r22706, MPFR_RNDN);
        mpfr_sub(r22736, r22734, r22735, MPFR_RNDN);
        mpfr_mul(r22737, r22736, r22722, MPFR_RNDN);
        mpfr_sub(r22738, r22733, r22737, MPFR_RNDN);
        mpfr_fma(r22739, r22696, r22703, r22738, MPFR_RNDN);
        if (mpfr_get_si(r22729, MPFR_RNDN)) { mpfr_set(r22740, r22739, MPFR_RNDN); } else { mpfr_set(r22740, r22727, MPFR_RNDN); };
        if (mpfr_get_si(r22715, MPFR_RNDN)) { mpfr_set(r22741, r22727, MPFR_RNDN); } else { mpfr_set(r22741, r22740, MPFR_RNDN); };
        return mpfr_get_d(r22741, MPFR_RNDN);
}

static mpfr_t r22742, r22743, r22744, r22745, r22746, r22747, r22748, r22749, r22750, r22751, r22752, r22753, r22754, r22755, r22756, r22757, r22758, r22759, r22760, r22761, r22762, r22763, r22764, r22765, r22766, r22767, r22768, r22769, r22770, r22771, r22772, r22773, r22774, r22775, r22776, r22777, r22778, r22779, r22780, r22781, r22782, r22783, r22784, r22785, r22786, r22787;

void setup_mpfr_f_dm() {
        mpfr_set_default_prec(400);
        mpfr_init(r22742);
        mpfr_init(r22743);
        mpfr_init(r22744);
        mpfr_init(r22745);
        mpfr_init(r22746);
        mpfr_init(r22747);
        mpfr_init(r22748);
        mpfr_init(r22749);
        mpfr_init(r22750);
        mpfr_init(r22751);
        mpfr_init(r22752);
        mpfr_init(r22753);
        mpfr_init(r22754);
        mpfr_init(r22755);
        mpfr_init(r22756);
        mpfr_init_set_str(r22757, "0", 10, MPFR_RNDN);
        mpfr_init(r22758);
        mpfr_init(r22759);
        mpfr_init_set_str(r22760, "-8.689672231024969e+290", 10, MPFR_RNDN);
        mpfr_init(r22761);
        mpfr_init(r22762);
        mpfr_init(r22763);
        mpfr_init(r22764);
        mpfr_init(r22765);
        mpfr_init(r22766);
        mpfr_init(r22767);
        mpfr_init(r22768);
        mpfr_init(r22769);
        mpfr_init(r22770);
        mpfr_init(r22771);
        mpfr_init(r22772);
        mpfr_init(r22773);
        mpfr_init_set_str(r22774, "1.2513342757769092e+305", 10, MPFR_RNDN);
        mpfr_init(r22775);
        mpfr_init(r22776);
        mpfr_init(r22777);
        mpfr_init(r22778);
        mpfr_init(r22779);
        mpfr_init(r22780);
        mpfr_init(r22781);
        mpfr_init(r22782);
        mpfr_init(r22783);
        mpfr_init(r22784);
        mpfr_init(r22785);
        mpfr_init(r22786);
        mpfr_init(r22787);
}

double f_dm(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
        mpfr_set_d(r22742, j, MPFR_RNDN);
        mpfr_set_d(r22743, c, MPFR_RNDN);
        mpfr_set_d(r22744, t, MPFR_RNDN);
        mpfr_mul(r22745, r22743, r22744, MPFR_RNDN);
        mpfr_set_d(r22746, i, MPFR_RNDN);
        mpfr_set_d(r22747, y, MPFR_RNDN);
        mpfr_mul(r22748, r22746, r22747, MPFR_RNDN);
        mpfr_sub(r22749, r22745, r22748, MPFR_RNDN);
        mpfr_set_d(r22750, z, MPFR_RNDN);
        mpfr_mul(r22751, r22750, r22747, MPFR_RNDN);
        mpfr_set_d(r22752, a, MPFR_RNDN);
        mpfr_mul(r22753, r22752, r22744, MPFR_RNDN);
        mpfr_sub(r22754, r22751, r22753, MPFR_RNDN);
        mpfr_set_d(r22755, x, MPFR_RNDN);
        mpfr_mul(r22756, r22754, r22755, MPFR_RNDN);
        ;
        mpfr_sub(r22758, r22756, r22757, MPFR_RNDN);
        mpfr_fma(r22759, r22742, r22749, r22758, MPFR_RNDN);
        ;
        mpfr_set_si(r22761, mpfr_cmp(r22759, r22760) <= 0, MPFR_RNDN);
        mpfr_mul(r22762, r22744, r22743, MPFR_RNDN);
        mpfr_mul(r22763, r22747, r22746, MPFR_RNDN);
        mpfr_sub(r22764, r22762, r22763, MPFR_RNDN);
        mpfr_mul(r22765, r22752, r22746, MPFR_RNDN);
        mpfr_mul(r22766, r22743, r22750, MPFR_RNDN);
        mpfr_sub(r22767, r22765, r22766, MPFR_RNDN);
        mpfr_set_d(r22768, b, MPFR_RNDN);
        mpfr_mul(r22769, r22767, r22768, MPFR_RNDN);
        mpfr_mul(r22770, r22752, r22755, MPFR_RNDN);
        mpfr_mul(r22771, r22770, r22744, MPFR_RNDN);
        mpfr_sub(r22772, r22769, r22771, MPFR_RNDN);
        mpfr_fma(r22773, r22742, r22764, r22772, MPFR_RNDN);
        ;
        mpfr_set_si(r22775, mpfr_cmp(r22759, r22774) <= 0, MPFR_RNDN);
        mpfr_cbrt(r22776, r22754, MPFR_RNDN);
        mpfr_mul(r22777, r22776, r22776, MPFR_RNDN);
        mpfr_mul(r22778, r22776, r22755, MPFR_RNDN);
        mpfr_mul(r22779, r22777, r22778, MPFR_RNDN);
        mpfr_mul(r22780, r22750, r22743, MPFR_RNDN);
        mpfr_mul(r22781, r22746, r22752, MPFR_RNDN);
        mpfr_sub(r22782, r22780, r22781, MPFR_RNDN);
        mpfr_mul(r22783, r22782, r22768, MPFR_RNDN);
        mpfr_sub(r22784, r22779, r22783, MPFR_RNDN);
        mpfr_fma(r22785, r22742, r22749, r22784, MPFR_RNDN);
        if (mpfr_get_si(r22775, MPFR_RNDN)) { mpfr_set(r22786, r22785, MPFR_RNDN); } else { mpfr_set(r22786, r22773, MPFR_RNDN); };
        if (mpfr_get_si(r22761, MPFR_RNDN)) { mpfr_set(r22787, r22773, MPFR_RNDN); } else { mpfr_set(r22787, r22786, MPFR_RNDN); };
        return mpfr_get_d(r22787, MPFR_RNDN);
}

