\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)
\begin{array}{l}
\mathbf{if}\;x \le -4.732618327639122542554636862127635323692 \cdot 10^{-237}:\\
\;\;\;\;\left(\left(\mathsf{fma}\left(-a, t, a \cdot t\right) \cdot x + \mathsf{fma}\left(y, z, \left(-a\right) \cdot t\right) \cdot x\right) - b \cdot \left(c \cdot z - a \cdot i\right)\right) + \left(\sqrt[3]{j} \cdot \sqrt[3]{j}\right) \cdot \left(\left(t \cdot c - y \cdot i\right) \cdot \sqrt[3]{j}\right)\\
\mathbf{elif}\;x \le 2.714727205484543614860096252924453206473 \cdot 10^{-192}:\\
\;\;\;\;\left(c \cdot z - a \cdot i\right) \cdot \left(-b\right) + j \cdot \left(t \cdot c - y \cdot i\right)\\
\mathbf{else}:\\
\;\;\;\;j \cdot \left(t \cdot c - y \cdot i\right) + \left(\sqrt{x} \cdot \left(\left(y \cdot z - a \cdot t\right) \cdot \sqrt{x}\right) - b \cdot \left(c \cdot z - a \cdot i\right)\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r20706801 = x;
double r20706802 = y;
double r20706803 = z;
double r20706804 = r20706802 * r20706803;
double r20706805 = t;
double r20706806 = a;
double r20706807 = r20706805 * r20706806;
double r20706808 = r20706804 - r20706807;
double r20706809 = r20706801 * r20706808;
double r20706810 = b;
double r20706811 = c;
double r20706812 = r20706811 * r20706803;
double r20706813 = i;
double r20706814 = r20706813 * r20706806;
double r20706815 = r20706812 - r20706814;
double r20706816 = r20706810 * r20706815;
double r20706817 = r20706809 - r20706816;
double r20706818 = j;
double r20706819 = r20706811 * r20706805;
double r20706820 = r20706813 * r20706802;
double r20706821 = r20706819 - r20706820;
double r20706822 = r20706818 * r20706821;
double r20706823 = r20706817 + r20706822;
return r20706823;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r20706824 = x;
double r20706825 = -4.7326183276391225e-237;
bool r20706826 = r20706824 <= r20706825;
double r20706827 = a;
double r20706828 = -r20706827;
double r20706829 = t;
double r20706830 = r20706827 * r20706829;
double r20706831 = fma(r20706828, r20706829, r20706830);
double r20706832 = r20706831 * r20706824;
double r20706833 = y;
double r20706834 = z;
double r20706835 = r20706828 * r20706829;
double r20706836 = fma(r20706833, r20706834, r20706835);
double r20706837 = r20706836 * r20706824;
double r20706838 = r20706832 + r20706837;
double r20706839 = b;
double r20706840 = c;
double r20706841 = r20706840 * r20706834;
double r20706842 = i;
double r20706843 = r20706827 * r20706842;
double r20706844 = r20706841 - r20706843;
double r20706845 = r20706839 * r20706844;
double r20706846 = r20706838 - r20706845;
double r20706847 = j;
double r20706848 = cbrt(r20706847);
double r20706849 = r20706848 * r20706848;
double r20706850 = r20706829 * r20706840;
double r20706851 = r20706833 * r20706842;
double r20706852 = r20706850 - r20706851;
double r20706853 = r20706852 * r20706848;
double r20706854 = r20706849 * r20706853;
double r20706855 = r20706846 + r20706854;
double r20706856 = 2.7147272054845436e-192;
bool r20706857 = r20706824 <= r20706856;
double r20706858 = -r20706839;
double r20706859 = r20706844 * r20706858;
double r20706860 = r20706847 * r20706852;
double r20706861 = r20706859 + r20706860;
double r20706862 = sqrt(r20706824);
double r20706863 = r20706833 * r20706834;
double r20706864 = r20706863 - r20706830;
double r20706865 = r20706864 * r20706862;
double r20706866 = r20706862 * r20706865;
double r20706867 = r20706866 - r20706845;
double r20706868 = r20706860 + r20706867;
double r20706869 = r20706857 ? r20706861 : r20706868;
double r20706870 = r20706826 ? r20706855 : r20706869;
return r20706870;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus i




Bits error versus j
| Original | 12.2 |
|---|---|
| Target | 16.3 |
| Herbie | 12.2 |
if x < -4.7326183276391225e-237Initial program 11.1
rmApplied prod-diff11.1
Applied distribute-rgt-in11.1
rmApplied add-cube-cbrt11.4
Applied associate-*l*11.4
if -4.7326183276391225e-237 < x < 2.7147272054845436e-192Initial program 17.4
Taylor expanded around 0 16.8
if 2.7147272054845436e-192 < x Initial program 10.6
rmApplied add-sqr-sqrt10.7
Applied associate-*l*10.7
Final simplification12.2
herbie shell --seed 2019174 +o rules:numerics
(FPCore (x y z t a b c i j)
:name "Linear.Matrix:det33 from linear-1.19.1.3"
:herbie-target
(if (< t -8.120978919195912e-33) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t -4.712553818218485e-169) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2.0) (pow (* i y) 2.0))) (+ (* c t) (* i y)))) (if (< t -7.633533346031584e-308) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t 1.0535888557455487e-139) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2.0) (pow (* i y) 2.0))) (+ (* c t) (* i y)))) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j)))))))
(+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))))