x + \frac{e^{y \cdot \log \left(\frac{y}{z + y}\right)}}{y}\begin{array}{l}
\mathbf{if}\;y \le 4.6364166897926171 \cdot 10^{-20}:\\
\;\;\;\;x + \frac{e^{y \cdot \left(2 \cdot \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right) + \log \left(\frac{\sqrt[3]{y}}{\sqrt[3]{z + y}}\right)\right)}}{y}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{e^{-1 \cdot z}}{y}\\
\end{array}double f(double x, double y, double z) {
double r492020 = x;
double r492021 = y;
double r492022 = z;
double r492023 = r492022 + r492021;
double r492024 = r492021 / r492023;
double r492025 = log(r492024);
double r492026 = r492021 * r492025;
double r492027 = exp(r492026);
double r492028 = r492027 / r492021;
double r492029 = r492020 + r492028;
return r492029;
}
double f(double x, double y, double z) {
double r492030 = y;
double r492031 = 4.636416689792617e-20;
bool r492032 = r492030 <= r492031;
double r492033 = x;
double r492034 = 2.0;
double r492035 = cbrt(r492030);
double r492036 = z;
double r492037 = r492036 + r492030;
double r492038 = cbrt(r492037);
double r492039 = r492035 / r492038;
double r492040 = log(r492039);
double r492041 = r492034 * r492040;
double r492042 = r492041 + r492040;
double r492043 = r492030 * r492042;
double r492044 = exp(r492043);
double r492045 = r492044 / r492030;
double r492046 = r492033 + r492045;
double r492047 = -1.0;
double r492048 = r492047 * r492036;
double r492049 = exp(r492048);
double r492050 = r492049 / r492030;
double r492051 = r492033 + r492050;
double r492052 = r492032 ? r492046 : r492051;
return r492052;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.2 |
|---|---|
| Target | 1.2 |
| Herbie | 0.8 |
if y < 4.636416689792617e-20Initial program 7.9
rmApplied add-cube-cbrt19.0
Applied add-cube-cbrt7.9
Applied times-frac7.9
Applied log-prod2.3
Simplified0.7
if 4.636416689792617e-20 < y Initial program 2.1
Taylor expanded around inf 0.8
Final simplification0.8
herbie shell --seed 2020100
(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)))