\frac{\varepsilon \cdot \left(e^{\left(a + b\right) \cdot \varepsilon} - 1\right)}{\left(e^{a \cdot \varepsilon} - 1\right) \cdot \left(e^{b \cdot \varepsilon} - 1\right)}\begin{array}{l}
\mathbf{if}\;b \le -2.1403574947999459 \cdot 10^{116} \lor \neg \left(b \le 7.604732750432952 \cdot 10^{-35}\right):\\
\;\;\;\;\frac{\varepsilon \cdot \left(e^{\left(a + b\right) \cdot \varepsilon} - 1\right)}{\mathsf{fma}\left(\frac{1}{6}, {\left(\varepsilon \cdot a\right)}^{3}, \mathsf{fma}\left(\frac{1}{2}, \left({a}^{2} \cdot {\left(\sqrt[3]{\varepsilon} \cdot \sqrt[3]{\varepsilon}\right)}^{2}\right) \cdot {\left(\sqrt[3]{\varepsilon}\right)}^{2}, a \cdot \varepsilon\right)\right) \cdot \left(\left(\sqrt[3]{e^{b \cdot \varepsilon} - 1} \cdot \sqrt[3]{e^{b \cdot \varepsilon} - 1}\right) \cdot \sqrt[3]{e^{b \cdot \varepsilon} - 1}\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\varepsilon \cdot \left(e^{\left(a + b\right) \cdot \varepsilon} - 1\right)}{\left(e^{a \cdot \varepsilon} - 1\right) \cdot \mathsf{fma}\left(\frac{1}{6}, {\varepsilon}^{3} \cdot {b}^{3}, \mathsf{fma}\left(\frac{1}{2}, {\varepsilon}^{2} \cdot {b}^{2}, \varepsilon \cdot b\right)\right)}\\
\end{array}double f(double a, double b, double eps) {
double r137160 = eps;
double r137161 = a;
double r137162 = b;
double r137163 = r137161 + r137162;
double r137164 = r137163 * r137160;
double r137165 = exp(r137164);
double r137166 = 1.0;
double r137167 = r137165 - r137166;
double r137168 = r137160 * r137167;
double r137169 = r137161 * r137160;
double r137170 = exp(r137169);
double r137171 = r137170 - r137166;
double r137172 = r137162 * r137160;
double r137173 = exp(r137172);
double r137174 = r137173 - r137166;
double r137175 = r137171 * r137174;
double r137176 = r137168 / r137175;
return r137176;
}
double f(double a, double b, double eps) {
double r137177 = b;
double r137178 = -2.140357494799946e+116;
bool r137179 = r137177 <= r137178;
double r137180 = 7.604732750432952e-35;
bool r137181 = r137177 <= r137180;
double r137182 = !r137181;
bool r137183 = r137179 || r137182;
double r137184 = eps;
double r137185 = a;
double r137186 = r137185 + r137177;
double r137187 = r137186 * r137184;
double r137188 = exp(r137187);
double r137189 = 1.0;
double r137190 = r137188 - r137189;
double r137191 = r137184 * r137190;
double r137192 = 0.16666666666666666;
double r137193 = r137184 * r137185;
double r137194 = 3.0;
double r137195 = pow(r137193, r137194);
double r137196 = 0.5;
double r137197 = 2.0;
double r137198 = pow(r137185, r137197);
double r137199 = cbrt(r137184);
double r137200 = r137199 * r137199;
double r137201 = pow(r137200, r137197);
double r137202 = r137198 * r137201;
double r137203 = pow(r137199, r137197);
double r137204 = r137202 * r137203;
double r137205 = r137185 * r137184;
double r137206 = fma(r137196, r137204, r137205);
double r137207 = fma(r137192, r137195, r137206);
double r137208 = r137177 * r137184;
double r137209 = exp(r137208);
double r137210 = r137209 - r137189;
double r137211 = cbrt(r137210);
double r137212 = r137211 * r137211;
double r137213 = r137212 * r137211;
double r137214 = r137207 * r137213;
double r137215 = r137191 / r137214;
double r137216 = exp(r137205);
double r137217 = r137216 - r137189;
double r137218 = pow(r137184, r137194);
double r137219 = pow(r137177, r137194);
double r137220 = r137218 * r137219;
double r137221 = pow(r137184, r137197);
double r137222 = pow(r137177, r137197);
double r137223 = r137221 * r137222;
double r137224 = r137184 * r137177;
double r137225 = fma(r137196, r137223, r137224);
double r137226 = fma(r137192, r137220, r137225);
double r137227 = r137217 * r137226;
double r137228 = r137191 / r137227;
double r137229 = r137183 ? r137215 : r137228;
return r137229;
}




Bits error versus a




Bits error versus b




Bits error versus eps
| Original | 60.3 |
|---|---|
| Target | 15.5 |
| Herbie | 53.3 |
if b < -2.140357494799946e+116 or 7.604732750432952e-35 < b Initial program 55.5
Taylor expanded around 0 49.2
Simplified49.2
rmApplied pow-prod-down47.8
Simplified47.8
rmApplied add-cube-cbrt47.8
Applied unpow-prod-down47.8
Applied associate-*r*47.5
rmApplied add-cube-cbrt47.6
if -2.140357494799946e+116 < b < 7.604732750432952e-35Initial program 63.2
Taylor expanded around 0 56.8
Simplified56.8
Final simplification53.3
herbie shell --seed 2020036 +o rules:numerics
(FPCore (a b eps)
:name "expq3 (problem 3.4.2)"
:precision binary64
:pre (and (< -1 eps) (< eps 1))
:herbie-target
(/ (+ a b) (* a b))
(/ (* eps (- (exp (* (+ a b) eps)) 1)) (* (- (exp (* a eps)) 1) (- (exp (* b eps)) 1))))