x + \frac{e^{y \cdot \log \left(\frac{y}{z + y}\right)}}{y}\begin{array}{l}
\mathbf{if}\;y \le -7.547170526470774 \lor \neg \left(y \le 3.711281227157836 \cdot 10^{-137}\right):\\
\;\;\;\;x + \frac{e^{-z}}{y}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{{\left(\frac{1}{\sqrt[3]{z + y} \cdot \sqrt[3]{z + y}}\right)}^{y} \cdot {\left(\frac{y}{\sqrt[3]{z + y}}\right)}^{y}}{y}\\
\end{array}double f(double x, double y, double z) {
double r444530 = x;
double r444531 = y;
double r444532 = z;
double r444533 = r444532 + r444531;
double r444534 = r444531 / r444533;
double r444535 = log(r444534);
double r444536 = r444531 * r444535;
double r444537 = exp(r444536);
double r444538 = r444537 / r444531;
double r444539 = r444530 + r444538;
return r444539;
}
double f(double x, double y, double z) {
double r444540 = y;
double r444541 = -7.547170526470774;
bool r444542 = r444540 <= r444541;
double r444543 = 3.711281227157836e-137;
bool r444544 = r444540 <= r444543;
double r444545 = !r444544;
bool r444546 = r444542 || r444545;
double r444547 = x;
double r444548 = z;
double r444549 = -r444548;
double r444550 = exp(r444549);
double r444551 = r444550 / r444540;
double r444552 = r444547 + r444551;
double r444553 = 1.0;
double r444554 = r444548 + r444540;
double r444555 = cbrt(r444554);
double r444556 = r444555 * r444555;
double r444557 = r444553 / r444556;
double r444558 = pow(r444557, r444540);
double r444559 = r444540 / r444555;
double r444560 = pow(r444559, r444540);
double r444561 = r444558 * r444560;
double r444562 = r444561 / r444540;
double r444563 = r444547 + r444562;
double r444564 = r444546 ? r444552 : r444563;
return r444564;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.0 |
|---|---|
| Target | 1.1 |
| Herbie | 2.9 |
if y < -7.547170526470774 or 3.711281227157836e-137 < y Initial program 2.1
Simplified2.1
Taylor expanded around inf 2.2
if -7.547170526470774 < y < 3.711281227157836e-137Initial program 13.0
Simplified13.0
rmApplied add-cube-cbrt13.0
Applied *-un-lft-identity13.0
Applied times-frac13.0
Applied unpow-prod-down4.1
Final simplification2.9
herbie shell --seed 2020043
(FPCore (x y z)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, G"
:precision binary64
:herbie-target
(if (< (/ y (+ z y)) 7.1154157597908e-315) (+ x (/ (exp (/ -1 z)) y)) (+ x (/ (exp (log (pow (/ y (+ y z)) y))) y)))
(+ x (/ (exp (* y (log (/ y (+ z y))))) y)))