\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.0215350936667226 \cdot 10^{149}:\\
\;\;\;\;\frac{1}{x \cdot e^{y}}\\
\mathbf{elif}\;x \le 6.2316967628408393 \cdot 10^{-6}:\\
\;\;\;\;\left({\left(\frac{\sqrt[3]{x} \cdot \sqrt[3]{\sqrt[3]{x} \cdot \sqrt[3]{x}}}{\sqrt[3]{x + y} \cdot \sqrt[3]{\sqrt[3]{x + y} \cdot \sqrt[3]{x + y}}}\right)}^{x} \cdot {\left(\frac{\sqrt[3]{\sqrt[3]{x}}}{\sqrt[3]{\sqrt[3]{x + y}}}\right)}^{x}\right) \cdot \frac{{\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\mathbf{else}:\\
\;\;\;\;e^{-1 \cdot y} \cdot \frac{1}{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.0215350936667226e+149)) {
temp = (1.0 / (x * exp(y)));
} else {
double temp_1;
if ((x <= 6.231696762840839e-06)) {
temp_1 = ((pow(((cbrt(x) * cbrt((cbrt(x) * cbrt(x)))) / (cbrt((x + y)) * cbrt((cbrt((x + y)) * cbrt((x + y)))))), x) * pow((cbrt(cbrt(x)) / cbrt(cbrt((x + y)))), x)) * (pow((cbrt(x) / cbrt((x + y))), x) / x));
} else {
temp_1 = (exp((-1.0 * y)) * (1.0 / x));
}
temp = temp_1;
}
return temp;
}




Bits error versus x




Bits error versus y
Results
| Original | 10.2 |
|---|---|
| Target | 7.4 |
| Herbie | 0.7 |
if x < -1.0215350936667226e+149Initial program 15.6
Simplified15.6
Taylor expanded around inf 0.0
Simplified0.0
rmApplied clear-num0.0
Simplified0.0
if -1.0215350936667226e+149 < x < 6.231696762840839e-06Initial program 9.5
Simplified9.5
rmApplied *-un-lft-identity9.5
Applied add-cube-cbrt17.1
Applied add-cube-cbrt9.5
Applied times-frac9.5
Applied unpow-prod-down2.6
Applied times-frac2.6
Simplified2.6
rmApplied add-cube-cbrt5.2
Applied cbrt-prod8.2
Applied associate-*r*8.7
Applied add-cube-cbrt9.1
Applied cbrt-prod5.8
Applied associate-*r*2.6
Applied times-frac2.6
Applied unpow-prod-down1.1
if 6.231696762840839e-06 < x Initial program 9.1
Simplified9.1
Taylor expanded around inf 0.3
Simplified0.3
rmApplied div-inv0.3
Final simplification0.7
herbie shell --seed 2020066 +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))