\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)}{\left(\frac{1}{6} \cdot {\left(\varepsilon \cdot a\right)}^{3} + \left(\frac{1}{2} \cdot \left(\left({a}^{2} \cdot {\left(\sqrt[3]{\varepsilon} \cdot \sqrt[3]{\varepsilon}\right)}^{2}\right) \cdot {\left(\sqrt[3]{\varepsilon}\right)}^{2}\right) + 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 \left(\frac{1}{6} \cdot \left({\varepsilon}^{3} \cdot {b}^{3}\right) + \left(\frac{1}{2} \cdot \left({\varepsilon}^{2} \cdot {b}^{2}\right) + \varepsilon \cdot b\right)\right)}\\
\end{array}double f(double a, double b, double eps) {
double r117031 = eps;
double r117032 = a;
double r117033 = b;
double r117034 = r117032 + r117033;
double r117035 = r117034 * r117031;
double r117036 = exp(r117035);
double r117037 = 1.0;
double r117038 = r117036 - r117037;
double r117039 = r117031 * r117038;
double r117040 = r117032 * r117031;
double r117041 = exp(r117040);
double r117042 = r117041 - r117037;
double r117043 = r117033 * r117031;
double r117044 = exp(r117043);
double r117045 = r117044 - r117037;
double r117046 = r117042 * r117045;
double r117047 = r117039 / r117046;
return r117047;
}
double f(double a, double b, double eps) {
double r117048 = b;
double r117049 = -2.140357494799946e+116;
bool r117050 = r117048 <= r117049;
double r117051 = 7.604732750432952e-35;
bool r117052 = r117048 <= r117051;
double r117053 = !r117052;
bool r117054 = r117050 || r117053;
double r117055 = eps;
double r117056 = a;
double r117057 = r117056 + r117048;
double r117058 = r117057 * r117055;
double r117059 = exp(r117058);
double r117060 = 1.0;
double r117061 = r117059 - r117060;
double r117062 = r117055 * r117061;
double r117063 = 0.16666666666666666;
double r117064 = r117055 * r117056;
double r117065 = 3.0;
double r117066 = pow(r117064, r117065);
double r117067 = r117063 * r117066;
double r117068 = 0.5;
double r117069 = 2.0;
double r117070 = pow(r117056, r117069);
double r117071 = cbrt(r117055);
double r117072 = r117071 * r117071;
double r117073 = pow(r117072, r117069);
double r117074 = r117070 * r117073;
double r117075 = pow(r117071, r117069);
double r117076 = r117074 * r117075;
double r117077 = r117068 * r117076;
double r117078 = r117056 * r117055;
double r117079 = r117077 + r117078;
double r117080 = r117067 + r117079;
double r117081 = r117048 * r117055;
double r117082 = exp(r117081);
double r117083 = r117082 - r117060;
double r117084 = cbrt(r117083);
double r117085 = r117084 * r117084;
double r117086 = r117085 * r117084;
double r117087 = r117080 * r117086;
double r117088 = r117062 / r117087;
double r117089 = exp(r117078);
double r117090 = r117089 - r117060;
double r117091 = pow(r117055, r117065);
double r117092 = pow(r117048, r117065);
double r117093 = r117091 * r117092;
double r117094 = r117063 * r117093;
double r117095 = pow(r117055, r117069);
double r117096 = pow(r117048, r117069);
double r117097 = r117095 * r117096;
double r117098 = r117068 * r117097;
double r117099 = r117055 * r117048;
double r117100 = r117098 + r117099;
double r117101 = r117094 + r117100;
double r117102 = r117090 * r117101;
double r117103 = r117062 / r117102;
double r117104 = r117054 ? r117088 : r117103;
return r117104;
}




Bits error versus a




Bits error versus b




Bits error versus eps
Results
| 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
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
Final simplification53.3
herbie shell --seed 2020036
(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))))