wj - \frac{wj \cdot e^{wj} - x}{e^{wj} + wj \cdot e^{wj}}\begin{array}{l}
\mathbf{if}\;wj - \frac{wj \cdot e^{wj} - x}{e^{wj} + wj \cdot e^{wj}} \le 6.58110533664 \cdot 10^{-12}:\\
\;\;\;\;\mathsf{fma}\left(x, \frac{5}{2} \cdot {wj}^{2} - 2 \cdot wj, x\right) + \mathsf{fma}\left(wj, wj, {wj}^{4} - {wj}^{3}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{x}{wj + 1}}{e^{wj}} + \frac{wj \cdot wj - \frac{wj}{wj + 1} \cdot \frac{wj}{wj + 1}}{wj + \frac{wj}{wj + 1}}\\
\end{array}double code(double wj, double x) {
return (wj - (((wj * exp(wj)) - x) / (exp(wj) + (wj * exp(wj)))));
}
double code(double wj, double x) {
double VAR;
if (((wj - (((wj * exp(wj)) - x) / (exp(wj) + (wj * exp(wj))))) <= 6.581105336643539e-12)) {
VAR = (fma(x, ((2.5 * pow(wj, 2.0)) - (2.0 * wj)), x) + fma(wj, wj, (pow(wj, 4.0) - pow(wj, 3.0))));
} else {
VAR = (((x / (wj + 1.0)) / exp(wj)) + (((wj * wj) - ((wj / (wj + 1.0)) * (wj / (wj + 1.0)))) / (wj + (wj / (wj + 1.0)))));
}
return VAR;
}




Bits error versus wj




Bits error versus x
Results
| Original | 13.9 |
|---|---|
| Target | 13.3 |
| Herbie | 0.5 |
if (- wj (/ (- (* wj (exp wj)) x) (+ (exp wj) (* wj (exp wj))))) < 6.581105336643539e-12Initial program 18.4
Simplified18.4
rmApplied associate--l+10.0
Taylor expanded around 0 0.2
Simplified0.2
Taylor expanded around 0 0.5
Simplified0.5
if 6.581105336643539e-12 < (- wj (/ (- (* wj (exp wj)) x) (+ (exp wj) (* wj (exp wj))))) Initial program 2.3
Simplified0.3
rmApplied associate--l+0.3
rmApplied flip--0.3
Final simplification0.5
herbie shell --seed 2020071 +o rules:numerics
(FPCore (wj x)
:name "Jmat.Real.lambertw, newton loop step"
:precision binary64
:herbie-target
(- wj (- (/ wj (+ wj 1)) (/ x (+ (exp wj) (* wj (exp wj))))))
(- wj (/ (- (* wj (exp wj)) x) (+ (exp wj) (* wj (exp wj))))))