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 r423375 = x;
double r423376 = y;
double r423377 = z;
double r423378 = r423376 - r423377;
double r423379 = t;
double r423380 = r423379 - r423375;
double r423381 = r423378 * r423380;
double r423382 = a;
double r423383 = r423382 - r423377;
double r423384 = r423381 / r423383;
double r423385 = r423375 + r423384;
return r423385;
}
double f(double x, double y, double z, double t, double a) {
double r423386 = a;
double r423387 = -6.14323213192593e-28;
bool r423388 = r423386 <= r423387;
double r423389 = x;
double r423390 = y;
double r423391 = z;
double r423392 = r423390 - r423391;
double r423393 = r423386 - r423391;
double r423394 = cbrt(r423393);
double r423395 = r423394 * r423394;
double r423396 = r423392 / r423395;
double r423397 = cbrt(r423394);
double r423398 = r423397 * r423397;
double r423399 = r423396 / r423398;
double r423400 = t;
double r423401 = r423400 - r423389;
double r423402 = r423401 / r423397;
double r423403 = r423399 * r423402;
double r423404 = r423389 + r423403;
double r423405 = 1.9876705662071354e-115;
bool r423406 = r423386 <= r423405;
double r423407 = r423389 / r423391;
double r423408 = r423400 / r423391;
double r423409 = r423407 - r423408;
double r423410 = r423390 * r423409;
double r423411 = r423400 + r423410;
double r423412 = cbrt(r423392);
double r423413 = cbrt(r423395);
double r423414 = r423412 / r423413;
double r423415 = r423412 / r423397;
double r423416 = r423412 / r423394;
double r423417 = r423401 / r423394;
double r423418 = r423416 * r423417;
double r423419 = r423415 * r423418;
double r423420 = r423414 * r423419;
double r423421 = r423389 + r423420;
double r423422 = r423406 ? r423411 : r423421;
double r423423 = r423388 ? r423404 : r423422;
return r423423;
}




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))))