\frac{x \cdot \left(\frac{x}{y} + 1\right)}{x + 1}\frac{x}{\frac{x + 1}{\frac{x}{y} + 1}}double f(double x, double y) {
double r553756 = x;
double r553757 = y;
double r553758 = r553756 / r553757;
double r553759 = 1.0;
double r553760 = r553758 + r553759;
double r553761 = r553756 * r553760;
double r553762 = r553756 + r553759;
double r553763 = r553761 / r553762;
return r553763;
}
double f(double x, double y) {
double r553764 = x;
double r553765 = 1.0;
double r553766 = r553764 + r553765;
double r553767 = y;
double r553768 = r553764 / r553767;
double r553769 = r553768 + r553765;
double r553770 = r553766 / r553769;
double r553771 = r553764 / r553770;
return r553771;
}




Bits error versus x




Bits error versus y
Results
| Original | 9.2 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 9.2
rmApplied associate-/l*0.1
Final simplification0.1
herbie shell --seed 2020042 +o rules:numerics
(FPCore (x y)
:name "Codec.Picture.Types:toneMapping from JuicyPixels-3.2.6.1"
:precision binary64
:herbie-target
(* (/ x 1) (/ (+ (/ x y) 1) (+ x 1)))
(/ (* x (+ (/ x y) 1)) (+ x 1)))