e^{a \cdot x} - 1\begin{array}{l}
\mathbf{if}\;a \cdot x \le -1.45020641556337332 \cdot 10^{-5}:\\
\;\;\;\;\frac{{\left(e^{a \cdot x}\right)}^{3} - {1}^{3}}{e^{a \cdot x} \cdot \left(e^{a \cdot x} + 1\right) + 1 \cdot 1}\\
\mathbf{else}:\\
\;\;\;\;x \cdot a\\
\end{array}double f(double a, double x) {
double r105342 = a;
double r105343 = x;
double r105344 = r105342 * r105343;
double r105345 = exp(r105344);
double r105346 = 1.0;
double r105347 = r105345 - r105346;
return r105347;
}
double f(double a, double x) {
double r105348 = a;
double r105349 = x;
double r105350 = r105348 * r105349;
double r105351 = -1.4502064155633733e-05;
bool r105352 = r105350 <= r105351;
double r105353 = exp(r105350);
double r105354 = 3.0;
double r105355 = pow(r105353, r105354);
double r105356 = 1.0;
double r105357 = pow(r105356, r105354);
double r105358 = r105355 - r105357;
double r105359 = r105353 + r105356;
double r105360 = r105353 * r105359;
double r105361 = r105356 * r105356;
double r105362 = r105360 + r105361;
double r105363 = r105358 / r105362;
double r105364 = r105349 * r105348;
double r105365 = r105352 ? r105363 : r105364;
return r105365;
}




Bits error versus a




Bits error versus x
Results
| Original | 29.8 |
|---|---|
| Target | 0.2 |
| Herbie | 0.8 |
if (* a x) < -1.4502064155633733e-05Initial program 0.1
rmApplied flip3--0.1
Simplified0.1
if -1.4502064155633733e-05 < (* a x) Initial program 44.9
Taylor expanded around 0 13.6
Simplified13.6
Taylor expanded around 0 8.1
Simplified4.5
Taylor expanded around 0 1.2
Simplified1.2
Final simplification0.8
herbie shell --seed 2020027
(FPCore (a x)
:name "expax (section 3.5)"
:precision binary64
:herbie-expected 14
:herbie-target
(if (< (fabs (* a x)) 0.1) (* (* a x) (+ 1 (+ (/ (* a x) 2) (/ (pow (* a x) 2) 6)))) (- (exp (* a x)) 1))
(- (exp (* a x)) 1))