1 - \log \left(1 - \frac{x - y}{1 - y}\right)\begin{array}{l}
\mathbf{if}\;y \le -199754789.0343833863735198974609375 \lor \neg \left(y \le 32910417.669902421534061431884765625\right):\\
\;\;\;\;\log \left(\frac{e^{1}}{\mathsf{fma}\left(1, \frac{x}{{y}^{2}} - \frac{1}{y}, \frac{x}{y}\right)}\right)\\
\mathbf{else}:\\
\;\;\;\;\log \left(\frac{e^{1}}{1 - \frac{x - y}{1 - y}}\right)\\
\end{array}double f(double x, double y) {
double r371766 = 1.0;
double r371767 = x;
double r371768 = y;
double r371769 = r371767 - r371768;
double r371770 = r371766 - r371768;
double r371771 = r371769 / r371770;
double r371772 = r371766 - r371771;
double r371773 = log(r371772);
double r371774 = r371766 - r371773;
return r371774;
}
double f(double x, double y) {
double r371775 = y;
double r371776 = -199754789.0343834;
bool r371777 = r371775 <= r371776;
double r371778 = 32910417.66990242;
bool r371779 = r371775 <= r371778;
double r371780 = !r371779;
bool r371781 = r371777 || r371780;
double r371782 = 1.0;
double r371783 = exp(r371782);
double r371784 = x;
double r371785 = 2.0;
double r371786 = pow(r371775, r371785);
double r371787 = r371784 / r371786;
double r371788 = 1.0;
double r371789 = r371788 / r371775;
double r371790 = r371787 - r371789;
double r371791 = r371784 / r371775;
double r371792 = fma(r371782, r371790, r371791);
double r371793 = r371783 / r371792;
double r371794 = log(r371793);
double r371795 = r371784 - r371775;
double r371796 = r371782 - r371775;
double r371797 = r371795 / r371796;
double r371798 = r371782 - r371797;
double r371799 = r371783 / r371798;
double r371800 = log(r371799);
double r371801 = r371781 ? r371794 : r371800;
return r371801;
}




Bits error versus x




Bits error versus y
| Original | 18.3 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
if y < -199754789.0343834 or 32910417.66990242 < y Initial program 46.8
rmApplied add-log-exp46.8
Applied diff-log46.8
Taylor expanded around inf 0.1
Simplified0.1
if -199754789.0343834 < y < 32910417.66990242Initial program 0.1
rmApplied add-log-exp0.1
Applied diff-log0.1
Final simplification0.1
herbie shell --seed 2019353 +o rules:numerics
(FPCore (x y)
:name "Numeric.SpecFunctions:invIncompleteGamma from math-functions-0.1.5.2, B"
:precision binary64
:herbie-target
(if (< y -81284752.61947241) (- 1 (log (- (/ x (* y y)) (- (/ 1 y) (/ x y))))) (if (< y 3.0094271212461764e+25) (log (/ (exp 1) (- 1 (/ (- x y) (- 1 y))))) (- 1 (log (- (/ x (* y y)) (- (/ 1 y) (/ x y)))))))
(- 1 (log (- 1 (/ (- x y) (- 1 y))))))