\frac{x + \frac{y \cdot z}{t}}{\left(a + 1.0\right) + \frac{y \cdot b}{t}}\begin{array}{l}
\mathbf{if}\;t \le -6.197177724958254 \cdot 10^{+148}:\\
\;\;\;\;\frac{x + \frac{y}{t} \cdot z}{\left(\frac{b}{t} \cdot y + a\right) + 1.0}\\
\mathbf{elif}\;t \le 2.3781837166761447 \cdot 10^{-60}:\\
\;\;\;\;\frac{\frac{y \cdot z}{t} + x}{\frac{y \cdot b}{t} + \left(a + 1.0\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{x + \frac{y}{t} \cdot z}{\left(\frac{b}{t} \cdot y + a\right) + 1.0}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r29433806 = x;
double r29433807 = y;
double r29433808 = z;
double r29433809 = r29433807 * r29433808;
double r29433810 = t;
double r29433811 = r29433809 / r29433810;
double r29433812 = r29433806 + r29433811;
double r29433813 = a;
double r29433814 = 1.0;
double r29433815 = r29433813 + r29433814;
double r29433816 = b;
double r29433817 = r29433807 * r29433816;
double r29433818 = r29433817 / r29433810;
double r29433819 = r29433815 + r29433818;
double r29433820 = r29433812 / r29433819;
return r29433820;
}
double f(double x, double y, double z, double t, double a, double b) {
double r29433821 = t;
double r29433822 = -6.197177724958254e+148;
bool r29433823 = r29433821 <= r29433822;
double r29433824 = x;
double r29433825 = y;
double r29433826 = r29433825 / r29433821;
double r29433827 = z;
double r29433828 = r29433826 * r29433827;
double r29433829 = r29433824 + r29433828;
double r29433830 = b;
double r29433831 = r29433830 / r29433821;
double r29433832 = r29433831 * r29433825;
double r29433833 = a;
double r29433834 = r29433832 + r29433833;
double r29433835 = 1.0;
double r29433836 = r29433834 + r29433835;
double r29433837 = r29433829 / r29433836;
double r29433838 = 2.3781837166761447e-60;
bool r29433839 = r29433821 <= r29433838;
double r29433840 = r29433825 * r29433827;
double r29433841 = r29433840 / r29433821;
double r29433842 = r29433841 + r29433824;
double r29433843 = r29433825 * r29433830;
double r29433844 = r29433843 / r29433821;
double r29433845 = r29433833 + r29433835;
double r29433846 = r29433844 + r29433845;
double r29433847 = r29433842 / r29433846;
double r29433848 = r29433839 ? r29433847 : r29433837;
double r29433849 = r29433823 ? r29433837 : r29433848;
return r29433849;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
Results
| Original | 16.5 |
|---|---|
| Target | 13.1 |
| Herbie | 13.0 |
if t < -6.197177724958254e+148 or 2.3781837166761447e-60 < t Initial program 12.1
Simplified4.3
rmApplied div-inv4.3
Applied associate-*l*4.4
Simplified4.4
if -6.197177724958254e+148 < t < 2.3781837166761447e-60Initial program 19.9
Final simplification13.0
herbie shell --seed 2019165
(FPCore (x y z t a b)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, B"
:herbie-target
(if (< t -1.3659085366310088e-271) (* 1 (* (+ x (* (/ y t) z)) (/ 1 (+ (+ a 1.0) (* (/ y t) b))))) (if (< t 3.036967103737246e-130) (/ z b) (* 1 (* (+ x (* (/ y t) z)) (/ 1 (+ (+ a 1.0) (* (/ y t) b)))))))
(/ (+ x (/ (* y z) t)) (+ (+ a 1.0) (/ (* y b) t))))