\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -1.479973884495300604070714800261381475132 \cdot 10^{167}:\\
\;\;\;\;y \cdot \frac{x}{z}\\
\mathbf{elif}\;x \cdot y \le -1.416209028111420696434446461734804676286 \cdot 10^{-165} \lor \neg \left(x \cdot y \le 6.735758574504119133242399316181506457656 \cdot 10^{-122}\right):\\
\;\;\;\;\frac{1}{z} \cdot \left(x \cdot y\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\end{array}double f(double x, double y, double z) {
double r466518 = x;
double r466519 = y;
double r466520 = r466518 * r466519;
double r466521 = z;
double r466522 = r466520 / r466521;
return r466522;
}
double f(double x, double y, double z) {
double r466523 = x;
double r466524 = y;
double r466525 = r466523 * r466524;
double r466526 = -1.4799738844953006e+167;
bool r466527 = r466525 <= r466526;
double r466528 = z;
double r466529 = r466523 / r466528;
double r466530 = r466524 * r466529;
double r466531 = -1.4162090281114207e-165;
bool r466532 = r466525 <= r466531;
double r466533 = 6.735758574504119e-122;
bool r466534 = r466525 <= r466533;
double r466535 = !r466534;
bool r466536 = r466532 || r466535;
double r466537 = 1.0;
double r466538 = r466537 / r466528;
double r466539 = r466538 * r466525;
double r466540 = r466528 / r466524;
double r466541 = r466523 / r466540;
double r466542 = r466536 ? r466539 : r466541;
double r466543 = r466527 ? r466530 : r466542;
return r466543;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.3 |
|---|---|
| Target | 6.3 |
| Herbie | 2.7 |
if (* x y) < -1.4799738844953006e+167Initial program 19.6
rmApplied associate-/l*1.7
rmApplied clear-num1.7
Taylor expanded around 0 19.6
Simplified2.4
if -1.4799738844953006e+167 < (* x y) < -1.4162090281114207e-165 or 6.735758574504119e-122 < (* x y) Initial program 3.2
rmApplied associate-/l*9.9
rmApplied div-inv10.0
Applied *-un-lft-identity10.0
Applied times-frac3.4
Simplified3.3
if -1.4162090281114207e-165 < (* x y) < 6.735758574504119e-122Initial program 8.6
rmApplied associate-/l*1.6
Final simplification2.7
herbie shell --seed 2019323
(FPCore (x y z)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, A"
:precision binary64
:herbie-target
(if (< z -4.262230790519429e-138) (/ (* x y) z) (if (< z 1.7042130660650472e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))