\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -5.899145090483621243407591608868938844895 \cdot 10^{275}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\mathbf{elif}\;x \cdot y \le -4.740188247183417662311772579191743839341 \cdot 10^{-201}:\\
\;\;\;\;\frac{1}{z} \cdot \left(x \cdot y\right)\\
\mathbf{elif}\;x \cdot y \le 2.796489205112816623953257005668039638224 \cdot 10^{-171}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\mathbf{elif}\;x \cdot y \le 2.345913877288735097014094340963252524817 \cdot 10^{180}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\end{array}double f(double x, double y, double z) {
double r47938628 = x;
double r47938629 = y;
double r47938630 = r47938628 * r47938629;
double r47938631 = z;
double r47938632 = r47938630 / r47938631;
return r47938632;
}
double f(double x, double y, double z) {
double r47938633 = x;
double r47938634 = y;
double r47938635 = r47938633 * r47938634;
double r47938636 = -5.899145090483621e+275;
bool r47938637 = r47938635 <= r47938636;
double r47938638 = z;
double r47938639 = r47938634 / r47938638;
double r47938640 = r47938633 * r47938639;
double r47938641 = -4.740188247183418e-201;
bool r47938642 = r47938635 <= r47938641;
double r47938643 = 1.0;
double r47938644 = r47938643 / r47938638;
double r47938645 = r47938644 * r47938635;
double r47938646 = 2.7964892051128166e-171;
bool r47938647 = r47938635 <= r47938646;
double r47938648 = r47938638 / r47938634;
double r47938649 = r47938633 / r47938648;
double r47938650 = 2.345913877288735e+180;
bool r47938651 = r47938635 <= r47938650;
double r47938652 = r47938635 / r47938638;
double r47938653 = r47938651 ? r47938652 : r47938649;
double r47938654 = r47938647 ? r47938649 : r47938653;
double r47938655 = r47938642 ? r47938645 : r47938654;
double r47938656 = r47938637 ? r47938640 : r47938655;
return r47938656;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.2 |
|---|---|
| Target | 6.3 |
| Herbie | 0.5 |
if (* x y) < -5.899145090483621e+275Initial program 49.2
rmApplied *-un-lft-identity49.2
Applied times-frac0.4
Simplified0.4
if -5.899145090483621e+275 < (* x y) < -4.740188247183418e-201Initial program 0.3
rmApplied div-inv0.3
if -4.740188247183418e-201 < (* x y) < 2.7964892051128166e-171 or 2.345913877288735e+180 < (* x y) Initial program 11.6
rmApplied associate-/l*0.8
if 2.7964892051128166e-171 < (* x y) < 2.345913877288735e+180Initial program 0.3
Final simplification0.5
herbie shell --seed 2019171
(FPCore (x y z)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, A"
:herbie-target
(if (< z -4.262230790519429e-138) (/ (* x y) z) (if (< z 1.7042130660650472e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))