\frac{x}{y - z \cdot t}\begin{array}{l}
\mathbf{if}\;z \cdot t = -\infty:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{\frac{\frac{z}{\sqrt[3]{\sqrt[3]{x}}}}{\sqrt[3]{\sqrt[3]{x}}}}{\sqrt[3]{\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}}} \cdot \frac{t}{\sqrt[3]{\sqrt[3]{\sqrt[3]{x}}}}}\\
\mathbf{elif}\;z \cdot t \le 3.982214551187210407512533577328782205679 \cdot 10^{305}:\\
\;\;\;\;\frac{x}{y - z \cdot t}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{y}{\sqrt[3]{x}} - \frac{\sqrt[3]{z} \cdot \sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \left(\frac{\sqrt[3]{z}}{\sqrt[3]{\sqrt[3]{x}}} \cdot \frac{t}{\sqrt[3]{\sqrt[3]{x}}}\right)}\\
\end{array}double f(double x, double y, double z, double t) {
double r430211 = x;
double r430212 = y;
double r430213 = z;
double r430214 = t;
double r430215 = r430213 * r430214;
double r430216 = r430212 - r430215;
double r430217 = r430211 / r430216;
return r430217;
}
double f(double x, double y, double z, double t) {
double r430218 = z;
double r430219 = t;
double r430220 = r430218 * r430219;
double r430221 = -inf.0;
bool r430222 = r430220 <= r430221;
double r430223 = x;
double r430224 = cbrt(r430223);
double r430225 = r430224 * r430224;
double r430226 = y;
double r430227 = r430226 / r430224;
double r430228 = cbrt(r430224);
double r430229 = r430218 / r430228;
double r430230 = r430229 / r430228;
double r430231 = r430228 * r430228;
double r430232 = cbrt(r430231);
double r430233 = r430230 / r430232;
double r430234 = cbrt(r430228);
double r430235 = r430219 / r430234;
double r430236 = r430233 * r430235;
double r430237 = r430227 - r430236;
double r430238 = r430225 / r430237;
double r430239 = 3.9822145511872104e+305;
bool r430240 = r430220 <= r430239;
double r430241 = r430226 - r430220;
double r430242 = r430223 / r430241;
double r430243 = cbrt(r430218);
double r430244 = r430243 * r430243;
double r430245 = r430244 / r430228;
double r430246 = r430243 / r430228;
double r430247 = r430219 / r430228;
double r430248 = r430246 * r430247;
double r430249 = r430245 * r430248;
double r430250 = r430227 - r430249;
double r430251 = r430225 / r430250;
double r430252 = r430240 ? r430242 : r430251;
double r430253 = r430222 ? r430238 : r430252;
return r430253;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.7 |
|---|---|
| Target | 1.9 |
| Herbie | 1.8 |
if (* z t) < -inf.0Initial program 18.0
rmApplied add-cube-cbrt18.0
Applied associate-/l*18.0
rmApplied div-sub19.5
rmApplied add-cube-cbrt19.5
Applied times-frac11.5
rmApplied add-cube-cbrt11.5
Applied cbrt-prod11.5
Applied *-un-lft-identity11.5
Applied times-frac11.5
Applied associate-*r*11.5
Simplified11.5
if -inf.0 < (* z t) < 3.9822145511872104e+305Initial program 0.1
if 3.9822145511872104e+305 < (* z t) Initial program 21.7
rmApplied add-cube-cbrt21.7
Applied associate-/l*21.7
rmApplied div-sub23.2
rmApplied add-cube-cbrt23.2
Applied times-frac14.5
rmApplied add-cube-cbrt14.5
Applied times-frac14.5
Applied associate-*l*14.5
Final simplification1.8
herbie shell --seed 2019325
(FPCore (x y z t)
:name "Diagrams.Solve.Tridiagonal:solveTriDiagonal from diagrams-solve-0.1, B"
:precision binary64
:herbie-target
(if (< x -1.618195973607049e+50) (/ 1 (- (/ y x) (* (/ z x) t))) (if (< x 2.1378306434876444e+131) (/ x (- y (* z t))) (/ 1 (- (/ y x) (* (/ z x) t)))))
(/ x (- y (* z t))))