\frac{x \cdot y}{z}x \cdot \frac{y}{z}double f(double x, double y, double z) {
double r490055 = x;
double r490056 = y;
double r490057 = r490055 * r490056;
double r490058 = z;
double r490059 = r490057 / r490058;
return r490059;
}
double f(double x, double y, double z) {
double r490060 = x;
double r490061 = y;
double r490062 = z;
double r490063 = r490061 / r490062;
double r490064 = r490060 * r490063;
return r490064;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.2 |
|---|---|
| Target | 6.3 |
| Herbie | 6.2 |
if (* x y) < -inf.0 or -9.822128397102382e-148 < (* x y) < 2.0432590348299073e-242Initial program 14.3
rmApplied *-un-lft-identity14.3
Applied times-frac0.6
Simplified0.6
if -inf.0 < (* x y) < -9.822128397102382e-148 or 2.0432590348299073e-242 < (* x y) < 3.183191360702753e+226Initial program 0.2
if 3.183191360702753e+226 < (* x y) Initial program 32.6
rmApplied associate-/l*1.1
Final simplification6.2
herbie shell --seed 2019304
(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.70421306606504721e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))