\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)}\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)}double code(double eps, double a, double b) {
return ((double) (((double) (eps * ((double) (((double) exp(((double) (((double) (a + b)) * eps)))) - 1.0)))) / ((double) (((double) (((double) exp(((double) (a * eps)))) - 1.0)) * ((double) (((double) exp(((double) (b * eps)))) - 1.0))))));
}
double code(double eps, double a, double b) {
return ((double) (((double) (eps * ((double) (((double) exp(((double) (((double) (a + b)) * eps)))) - 1.0)))) / ((double) (((double) (((double) exp(((double) (a * eps)))) - 1.0)) * ((double) (((double) exp(((double) (b * eps)))) - 1.0))))));
}



Bits error versus eps



Bits error versus a



Bits error versus b
Results
Initial program 47.5
Final simplification47.5
herbie shell --seed 2020152
(FPCore (eps a b)
:name "(/ (* eps (- (exp (* (+ a b) eps)) 1)) (* (- (exp (* a eps)) 1) (- (exp (* b eps)) 1)))"
:precision binary64
(/ (* eps (- (exp (* (+ a b) eps)) 1.0)) (* (- (exp (* a eps)) 1.0) (- (exp (* b eps)) 1.0))))