\frac{x - y \cdot z}{t - a \cdot z}\left(x - y \cdot z\right) \cdot \frac{1}{t - a \cdot z}double f(double x, double y, double z, double t, double a) {
double r878881 = x;
double r878882 = y;
double r878883 = z;
double r878884 = r878882 * r878883;
double r878885 = r878881 - r878884;
double r878886 = t;
double r878887 = a;
double r878888 = r878887 * r878883;
double r878889 = r878886 - r878888;
double r878890 = r878885 / r878889;
return r878890;
}
double f(double x, double y, double z, double t, double a) {
double r878891 = x;
double r878892 = y;
double r878893 = z;
double r878894 = r878892 * r878893;
double r878895 = r878891 - r878894;
double r878896 = 1.0;
double r878897 = t;
double r878898 = a;
double r878899 = r878898 * r878893;
double r878900 = r878897 - r878899;
double r878901 = r878896 / r878900;
double r878902 = r878895 * r878901;
return r878902;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 10.2 |
|---|---|
| Target | 1.6 |
| Herbie | 10.3 |
Initial program 10.2
rmApplied div-inv10.3
Final simplification10.3
herbie shell --seed 2019362
(FPCore (x y z t a)
:name "Diagrams.Solve.Tridiagonal:solveTriDiagonal from diagrams-solve-0.1, A"
:precision binary64
:herbie-target
(if (< z -32113435955957344) (- (/ x (- t (* a z))) (/ y (- (/ t z) a))) (if (< z 3.5139522372978296e-86) (* (- x (* y z)) (/ 1 (- t (* a z)))) (- (/ x (- t (* a z))) (/ y (- (/ t z) a)))))
(/ (- x (* y z)) (- t (* a z))))