\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -2.930752839587006 \cdot 10^{86} \lor \neg \left(x \le 2.56432330242902842 \cdot 10^{-23}\right):\\
\;\;\;\;\frac{e^{-1 \cdot y}}{x}\\
\mathbf{else}:\\
\;\;\;\;e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)\right) \cdot x} \cdot \frac{{\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\end{array}double f(double x, double y) {
double r488832 = x;
double r488833 = y;
double r488834 = r488832 + r488833;
double r488835 = r488832 / r488834;
double r488836 = log(r488835);
double r488837 = r488832 * r488836;
double r488838 = exp(r488837);
double r488839 = r488838 / r488832;
return r488839;
}
double f(double x, double y) {
double r488840 = x;
double r488841 = -2.930752839587006e+86;
bool r488842 = r488840 <= r488841;
double r488843 = 2.5643233024290284e-23;
bool r488844 = r488840 <= r488843;
double r488845 = !r488844;
bool r488846 = r488842 || r488845;
double r488847 = -1.0;
double r488848 = y;
double r488849 = r488847 * r488848;
double r488850 = exp(r488849);
double r488851 = r488850 / r488840;
double r488852 = 2.0;
double r488853 = cbrt(r488840);
double r488854 = r488840 + r488848;
double r488855 = cbrt(r488854);
double r488856 = r488853 / r488855;
double r488857 = log(r488856);
double r488858 = r488852 * r488857;
double r488859 = r488858 * r488840;
double r488860 = exp(r488859);
double r488861 = pow(r488856, r488840);
double r488862 = r488861 / r488840;
double r488863 = r488860 * r488862;
double r488864 = r488846 ? r488851 : r488863;
return r488864;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.4 |
|---|---|
| Target | 8.0 |
| Herbie | 0.7 |
if x < -2.930752839587006e+86 or 2.5643233024290284e-23 < x Initial program 11.4
Simplified11.4
Taylor expanded around inf 0.8
Simplified0.8
if -2.930752839587006e+86 < x < 2.5643233024290284e-23Initial program 11.4
Simplified11.4
rmApplied *-un-lft-identity11.4
Applied add-cube-cbrt16.2
Applied add-cube-cbrt11.4
Applied times-frac11.4
Applied unpow-prod-down2.8
Applied times-frac2.8
Simplified2.8
rmApplied add-exp-log38.4
Applied add-exp-log38.4
Applied prod-exp38.4
Applied add-exp-log38.4
Applied add-exp-log38.4
Applied prod-exp38.4
Applied div-exp38.4
Applied pow-exp37.3
Simplified0.5
Final simplification0.7
herbie shell --seed 2020065
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, F"
:precision binary64
:herbie-target
(if (< y -3.7311844206647956e+94) (/ (exp (/ -1 y)) x) (if (< y 2.817959242728288e+37) (/ (pow (/ x (+ y x)) x) x) (if (< y 2.347387415166998e+178) (log (exp (/ (pow (/ x (+ y x)) x) x))) (/ (exp (/ -1 y)) x))))
(/ (exp (* x (log (/ x (+ x y))))) x))