\frac{x + \frac{y \cdot z}{t}}{\left(a + 1.0\right) + \frac{y \cdot b}{t}}\begin{array}{l}
\mathbf{if}\;t \le -9.025020228721649 \cdot 10^{+17}:\\
\;\;\;\;\frac{x + \frac{z}{t} \cdot y}{\frac{y}{\sqrt[3]{t} \cdot \sqrt[3]{t}} \cdot \frac{b}{\sqrt[3]{t}} + \left(1.0 + a\right)}\\
\mathbf{elif}\;t \le 0.00018452693517560944:\\
\;\;\;\;\frac{1}{\frac{\frac{b \cdot y}{t} + \left(1.0 + a\right)}{\frac{y \cdot z}{t} + x}}\\
\mathbf{else}:\\
\;\;\;\;\frac{x + \left(\frac{z}{\sqrt[3]{t}} \cdot \frac{\sqrt[3]{y}}{\sqrt[3]{t}}\right) \cdot \frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{t}}}{\frac{y}{\sqrt[3]{t} \cdot \sqrt[3]{t}} \cdot \frac{b}{\sqrt[3]{t}} + \left(1.0 + a\right)}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r39106007 = x;
double r39106008 = y;
double r39106009 = z;
double r39106010 = r39106008 * r39106009;
double r39106011 = t;
double r39106012 = r39106010 / r39106011;
double r39106013 = r39106007 + r39106012;
double r39106014 = a;
double r39106015 = 1.0;
double r39106016 = r39106014 + r39106015;
double r39106017 = b;
double r39106018 = r39106008 * r39106017;
double r39106019 = r39106018 / r39106011;
double r39106020 = r39106016 + r39106019;
double r39106021 = r39106013 / r39106020;
return r39106021;
}
double f(double x, double y, double z, double t, double a, double b) {
double r39106022 = t;
double r39106023 = -9.025020228721649e+17;
bool r39106024 = r39106022 <= r39106023;
double r39106025 = x;
double r39106026 = z;
double r39106027 = r39106026 / r39106022;
double r39106028 = y;
double r39106029 = r39106027 * r39106028;
double r39106030 = r39106025 + r39106029;
double r39106031 = cbrt(r39106022);
double r39106032 = r39106031 * r39106031;
double r39106033 = r39106028 / r39106032;
double r39106034 = b;
double r39106035 = r39106034 / r39106031;
double r39106036 = r39106033 * r39106035;
double r39106037 = 1.0;
double r39106038 = a;
double r39106039 = r39106037 + r39106038;
double r39106040 = r39106036 + r39106039;
double r39106041 = r39106030 / r39106040;
double r39106042 = 0.00018452693517560944;
bool r39106043 = r39106022 <= r39106042;
double r39106044 = 1.0;
double r39106045 = r39106034 * r39106028;
double r39106046 = r39106045 / r39106022;
double r39106047 = r39106046 + r39106039;
double r39106048 = r39106028 * r39106026;
double r39106049 = r39106048 / r39106022;
double r39106050 = r39106049 + r39106025;
double r39106051 = r39106047 / r39106050;
double r39106052 = r39106044 / r39106051;
double r39106053 = r39106026 / r39106031;
double r39106054 = cbrt(r39106028);
double r39106055 = r39106054 / r39106031;
double r39106056 = r39106053 * r39106055;
double r39106057 = r39106054 * r39106054;
double r39106058 = r39106057 / r39106031;
double r39106059 = r39106056 * r39106058;
double r39106060 = r39106025 + r39106059;
double r39106061 = r39106060 / r39106040;
double r39106062 = r39106043 ? r39106052 : r39106061;
double r39106063 = r39106024 ? r39106041 : r39106062;
return r39106063;
}




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.4 |
| Herbie | 12.6 |
if t < -9.025020228721649e+17Initial program 11.9
rmApplied add-cube-cbrt12.0
Applied times-frac9.0
rmApplied add-cube-cbrt9.1
Applied times-frac3.8
rmApplied *-un-lft-identity3.8
Applied associate-/r*3.8
Simplified3.6
if -9.025020228721649e+17 < t < 0.00018452693517560944Initial program 21.2
rmApplied clear-num21.4
if 0.00018452693517560944 < t Initial program 11.7
rmApplied add-cube-cbrt11.8
Applied times-frac8.6
rmApplied add-cube-cbrt8.7
Applied times-frac4.5
rmApplied add-cube-cbrt4.6
Applied times-frac4.6
Applied associate-*l*4.3
Final simplification12.6
herbie shell --seed 2019168
(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))))