\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 r457673 = x;
double r457674 = y;
double r457675 = z;
double r457676 = t;
double r457677 = r457675 * r457676;
double r457678 = r457674 - r457677;
double r457679 = r457673 / r457678;
return r457679;
}
double f(double x, double y, double z, double t) {
double r457680 = z;
double r457681 = t;
double r457682 = r457680 * r457681;
double r457683 = -inf.0;
bool r457684 = r457682 <= r457683;
double r457685 = x;
double r457686 = cbrt(r457685);
double r457687 = r457686 * r457686;
double r457688 = y;
double r457689 = r457688 / r457686;
double r457690 = cbrt(r457686);
double r457691 = r457690 * r457690;
double r457692 = r457680 / r457691;
double r457693 = r457691 * r457690;
double r457694 = cbrt(r457693);
double r457695 = r457681 / r457694;
double r457696 = r457692 * r457695;
double r457697 = r457689 - r457696;
double r457698 = r457687 / r457697;
double r457699 = 3.9822145511872104e+305;
bool r457700 = r457682 <= r457699;
double r457701 = r457688 - r457682;
double r457702 = r457685 / r457701;
double r457703 = cbrt(r457680);
double r457704 = r457703 * r457703;
double r457705 = r457704 / r457690;
double r457706 = r457703 / r457690;
double r457707 = r457681 / r457690;
double r457708 = r457706 * r457707;
double r457709 = r457705 * r457708;
double r457710 = r457689 - r457709;
double r457711 = r457687 / r457710;
double r457712 = r457700 ? r457702 : r457711;
double r457713 = r457684 ? r457698 : r457712;
return r457713;
}




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
(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))))