\frac{x \cdot y}{z}\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{y} \cdot \sqrt[3]{y}}} \cdot \frac{\sqrt[3]{x}}{\frac{\sqrt[3]{z}}{\sqrt[3]{y}}}double f(double x, double y, double z) {
double r672425 = x;
double r672426 = y;
double r672427 = r672425 * r672426;
double r672428 = z;
double r672429 = r672427 / r672428;
return r672429;
}
double f(double x, double y, double z) {
double r672430 = x;
double r672431 = cbrt(r672430);
double r672432 = r672431 * r672431;
double r672433 = z;
double r672434 = cbrt(r672433);
double r672435 = r672434 * r672434;
double r672436 = y;
double r672437 = cbrt(r672436);
double r672438 = r672437 * r672437;
double r672439 = r672435 / r672438;
double r672440 = r672432 / r672439;
double r672441 = r672434 / r672437;
double r672442 = r672431 / r672441;
double r672443 = r672440 * r672442;
return r672443;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.5 |
|---|---|
| Target | 6.0 |
| Herbie | 2.1 |
Initial program 6.5
rmApplied associate-/l*6.0
rmApplied add-cube-cbrt6.8
Applied add-cube-cbrt7.0
Applied times-frac7.0
Applied add-cube-cbrt7.1
Applied times-frac2.1
Final simplification2.1
herbie shell --seed 2020047 +o rules:numerics
(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))