\frac{e^{x \cdot \log \left(\frac{x}{x + y}\right)}}{x}\begin{array}{l}
\mathbf{if}\;x \le -7.0366427384808783 \cdot 10^{48} \lor \neg \left(x \le 9.41291569922092328 \cdot 10^{-13}\right):\\
\;\;\;\;\frac{e^{-1 \cdot y}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)\right) \cdot x} \cdot {\left(\frac{\sqrt[3]{x}}{\sqrt[3]{x + y}}\right)}^{x}}{x}\\
\end{array}double f(double x, double y) {
double r484499 = x;
double r484500 = y;
double r484501 = r484499 + r484500;
double r484502 = r484499 / r484501;
double r484503 = log(r484502);
double r484504 = r484499 * r484503;
double r484505 = exp(r484504);
double r484506 = r484505 / r484499;
return r484506;
}
double f(double x, double y) {
double r484507 = x;
double r484508 = -7.036642738480878e+48;
bool r484509 = r484507 <= r484508;
double r484510 = 9.412915699220923e-13;
bool r484511 = r484507 <= r484510;
double r484512 = !r484511;
bool r484513 = r484509 || r484512;
double r484514 = -1.0;
double r484515 = y;
double r484516 = r484514 * r484515;
double r484517 = exp(r484516);
double r484518 = r484517 / r484507;
double r484519 = 2.0;
double r484520 = cbrt(r484507);
double r484521 = r484507 + r484515;
double r484522 = cbrt(r484521);
double r484523 = r484520 / r484522;
double r484524 = log(r484523);
double r484525 = r484519 * r484524;
double r484526 = r484525 * r484507;
double r484527 = exp(r484526);
double r484528 = pow(r484523, r484507);
double r484529 = r484527 * r484528;
double r484530 = r484529 / r484507;
double r484531 = r484513 ? r484518 : r484530;
return r484531;
}




Bits error versus x




Bits error versus y
Results
| Original | 11.1 |
|---|---|
| Target | 8.0 |
| Herbie | 0.4 |
if x < -7.036642738480878e+48 or 9.412915699220923e-13 < x Initial program 11.4
Simplified11.4
Taylor expanded around inf 0.5
Simplified0.5
if -7.036642738480878e+48 < x < 9.412915699220923e-13Initial program 10.9
Simplified10.9
rmApplied add-cube-cbrt13.6
Applied add-cube-cbrt10.9
Applied times-frac10.9
Applied unpow-prod-down2.4
rmApplied add-exp-log36.0
Applied add-exp-log36.0
Applied prod-exp36.0
Applied add-exp-log36.0
Applied add-exp-log36.0
Applied prod-exp36.0
Applied div-exp36.0
Applied pow-exp34.9
Simplified0.2
Final simplification0.4
herbie shell --seed 2020057
(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))