x + \frac{\left(y - z\right) \cdot \left(t - x\right)}{a - z}\begin{array}{l}
\mathbf{if}\;a \le -6.143232131925929682871142551410290774749 \cdot 10^{-28}:\\
\;\;\;\;x + \frac{\frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}}{\sqrt[3]{\sqrt[3]{a - z}} \cdot \sqrt[3]{\sqrt[3]{a - z}}} \cdot \frac{t - x}{\sqrt[3]{\sqrt[3]{a - z}}}\\
\mathbf{elif}\;a \le 1.987670566207135403433863883298285206393 \cdot 10^{-115}:\\
\;\;\;\;t + y \cdot \left(\frac{x}{z} - \frac{t}{z}\right)\\
\mathbf{else}:\\
\;\;\;\;x + \frac{\sqrt[3]{y - z}}{\sqrt[3]{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}}} \cdot \left(\frac{\sqrt[3]{y - z}}{\sqrt[3]{\sqrt[3]{a - z}}} \cdot \left(\frac{\sqrt[3]{y - z}}{\sqrt[3]{a - z}} \cdot \frac{t - x}{\sqrt[3]{a - z}}\right)\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r444422 = x;
double r444423 = y;
double r444424 = z;
double r444425 = r444423 - r444424;
double r444426 = t;
double r444427 = r444426 - r444422;
double r444428 = r444425 * r444427;
double r444429 = a;
double r444430 = r444429 - r444424;
double r444431 = r444428 / r444430;
double r444432 = r444422 + r444431;
return r444432;
}
double f(double x, double y, double z, double t, double a) {
double r444433 = a;
double r444434 = -6.14323213192593e-28;
bool r444435 = r444433 <= r444434;
double r444436 = x;
double r444437 = y;
double r444438 = z;
double r444439 = r444437 - r444438;
double r444440 = r444433 - r444438;
double r444441 = cbrt(r444440);
double r444442 = r444441 * r444441;
double r444443 = r444439 / r444442;
double r444444 = cbrt(r444441);
double r444445 = r444444 * r444444;
double r444446 = r444443 / r444445;
double r444447 = t;
double r444448 = r444447 - r444436;
double r444449 = r444448 / r444444;
double r444450 = r444446 * r444449;
double r444451 = r444436 + r444450;
double r444452 = 1.9876705662071354e-115;
bool r444453 = r444433 <= r444452;
double r444454 = r444436 / r444438;
double r444455 = r444447 / r444438;
double r444456 = r444454 - r444455;
double r444457 = r444437 * r444456;
double r444458 = r444447 + r444457;
double r444459 = cbrt(r444439);
double r444460 = cbrt(r444442);
double r444461 = r444459 / r444460;
double r444462 = r444459 / r444444;
double r444463 = r444459 / r444441;
double r444464 = r444448 / r444441;
double r444465 = r444463 * r444464;
double r444466 = r444462 * r444465;
double r444467 = r444461 * r444466;
double r444468 = r444436 + r444467;
double r444469 = r444453 ? r444458 : r444468;
double r444470 = r444435 ? r444451 : r444469;
return r444470;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.3 |
|---|---|
| Target | 11.7 |
| Herbie | 10.9 |
if a < -6.14323213192593e-28Initial program 22.7
rmApplied add-cube-cbrt23.0
Applied times-frac7.7
rmApplied add-cube-cbrt7.9
Applied *-un-lft-identity7.9
Applied times-frac7.9
Applied associate-*r*7.9
Simplified7.9
if -6.14323213192593e-28 < a < 1.9876705662071354e-115Initial program 27.7
rmApplied add-cube-cbrt28.4
Applied times-frac20.7
rmApplied add-cube-cbrt20.4
Applied times-frac20.4
Applied associate-*l*20.0
Taylor expanded around inf 17.2
Simplified15.4
if 1.9876705662071354e-115 < a Initial program 22.3
rmApplied add-cube-cbrt22.7
Applied times-frac9.2
rmApplied add-cube-cbrt9.1
Applied times-frac9.1
Applied associate-*l*9.0
rmApplied add-cube-cbrt9.0
Applied cbrt-prod9.1
Applied times-frac9.1
Applied associate-*l*9.1
Final simplification10.9
herbie shell --seed 2019325
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:invLinMap from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< z -1.2536131056095036e+188) (- t (* (/ y z) (- t x))) (if (< z 4.446702369113811e+64) (+ x (/ (- y z) (/ (- a z) (- t x)))) (- t (* (/ y z) (- t x)))))
(+ x (/ (* (- y z) (- t x)) (- a z))))