\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.93589564103634151 \cdot 10^{37} \lor \neg \left(x \le 5.82893129968314749\right):\\
\;\;\;\;\frac{1}{x \cdot e^{y}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left({\left(\left|\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right|\right)}^{\left(2 \cdot \frac{x}{2}\right)} \cdot {\left(\left|\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right|\right)}^{\left(2 \cdot \frac{x}{2}\right)}\right) \cdot {\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\end{array}double code(double x, double y) {
return (exp((x * log((x / (x + y))))) / x);
}
double code(double x, double y) {
double temp;
if (((x <= -1.9358956410363415e+37) || !(x <= 5.8289312996831475))) {
temp = (1.0 / (x * exp(y)));
} else {
temp = (((pow(fabs((cbrt(x) / cbrt((x + y)))), (2.0 * (x / 2.0))) * pow(fabs((cbrt(x) / cbrt((x + y)))), (2.0 * (x / 2.0)))) * pow((cbrt(x) / cbrt((x + y))), x)) / x);
}
return temp;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.0 |
|---|---|
| Target | 8.3 |
| Herbie | 0.1 |
if x < -1.9358956410363415e+37 or 5.8289312996831475 < x Initial program 11.5
Simplified11.5
Taylor expanded around inf 0.0
Simplified0.0
rmApplied clear-num0.0
Simplified0.0
if -1.9358956410363415e+37 < x < 5.8289312996831475Initial program 10.4
Simplified10.4
rmApplied add-cube-cbrt12.3
Applied add-cube-cbrt10.4
Applied times-frac10.4
Applied unpow-prod-down2.2
rmApplied add-sqr-sqrt2.2
Applied unpow-prod-down2.2
Simplified2.2
Simplified0.1
Final simplification0.1
herbie shell --seed 2020056 +o rules:numerics
(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))