\frac{x}{y - z \cdot t}\begin{array}{l}
\mathbf{if}\;z \cdot t = -\infty:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{z}{\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}} \cdot \frac{t}{\sqrt[3]{\left(\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}\right) \cdot \sqrt[3]{\sqrt[3]{x}}}}}\\
\mathbf{elif}\;z \cdot t \le 3.982214551187210407512533577328782205679 \cdot 10^{305}:\\
\;\;\;\;\frac{x}{y - z \cdot t}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \left(\frac{\sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \frac{t}{\sqrt[3]{\sqrt[3]{x}}}\right)}\\
\end{array}double f(double x, double y, double z, double t) {
double r406614 = x;
double r406615 = y;
double r406616 = z;
double r406617 = t;
double r406618 = r406616 * r406617;
double r406619 = r406615 - r406618;
double r406620 = r406614 / r406619;
return r406620;
}
double f(double x, double y, double z, double t) {
double r406621 = z;
double r406622 = t;
double r406623 = r406621 * r406622;
double r406624 = -inf.0;
bool r406625 = r406623 <= r406624;
double r406626 = x;
double r406627 = cbrt(r406626);
double r406628 = r406627 * r406627;
double r406629 = y;
double r406630 = r406629 / r406627;
double r406631 = cbrt(r406627);
double r406632 = r406631 * r406631;
double r406633 = r406621 / r406632;
double r406634 = r406632 * r406631;
double r406635 = cbrt(r406634);
double r406636 = r406622 / r406635;
double r406637 = r406633 * r406636;
double r406638 = r406630 - r406637;
double r406639 = r406628 / r406638;
double r406640 = 3.9822145511872104e+305;
bool r406641 = r406623 <= r406640;
double r406642 = r406629 - r406623;
double r406643 = r406626 / r406642;
double r406644 = cbrt(r406621);
double r406645 = r406644 * r406644;
double r406646 = r406645 / r406631;
double r406647 = r406644 / r406631;
double r406648 = r406622 / r406631;
double r406649 = r406647 * r406648;
double r406650 = r406646 * r406649;
double r406651 = r406630 - r406650;
double r406652 = r406628 / r406651;
double r406653 = r406641 ? r406643 : r406652;
double r406654 = r406625 ? r406639 : r406653;
return r406654;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.7 |
|---|---|
| Target | 1.9 |
| Herbie | 1.8 |
if (* z t) < -inf.0Initial program 18.0
rmApplied add-cube-cbrt18.0
Applied associate-/l*18.0
rmApplied div-sub19.5
rmApplied add-cube-cbrt19.5
Applied times-frac11.5
rmApplied add-cube-cbrt11.5
if -inf.0 < (* z t) < 3.9822145511872104e+305Initial program 0.1
if 3.9822145511872104e+305 < (* z t) Initial program 21.7
rmApplied add-cube-cbrt21.7
Applied associate-/l*21.7
rmApplied div-sub23.2
rmApplied add-cube-cbrt23.2
Applied times-frac14.5
rmApplied add-cube-cbrt14.5
Applied times-frac14.5
Applied associate-*l*14.5
Final simplification1.8
herbie shell --seed 2019325 +o rules:numerics
(FPCore (x y z t)
:name "Diagrams.Solve.Tridiagonal:solveTriDiagonal from diagrams-solve-0.1, B"
:precision binary64
:herbie-target
(if (< x -1.618195973607049e+50) (/ 1 (- (/ y x) (* (/ z x) t))) (if (< x 2.1378306434876444e+131) (/ x (- y (* z t))) (/ 1 (- (/ y x) (* (/ z x) t)))))
(/ x (- y (* z t))))