double code(double x, double y) {
return ((double) (((double) (x * ((double) (((double) (x / y)) + 1.0)))) / ((double) (x + 1.0))));
}
double code(double x, double y) {
return ((double) (((double) cbrt(((double) (((double) (((double) (x / y)) + 1.0)) / ((double) (x + 1.0)))))) * ((double) (x * ((double) (((double) cbrt(((double) (((double) (((double) (x / y)) + 1.0)) / ((double) (x + 1.0)))))) * ((double) cbrt(((double) (((double) (((double) (x / y)) + 1.0)) / ((double) (x + 1.0))))))))))));
}




Bits error versus x




Bits error versus y
Results
| Original | 9.3 |
|---|---|
| Target | 0.1 |
| Herbie | 0.9 |
Initial program 9.3
Simplified0.1
rmApplied add-cube-cbrt0.9
Applied associate-*r*0.9
Final simplification0.9
herbie shell --seed 2020191
(FPCore (x y)
:name "Codec.Picture.Types:toneMapping from JuicyPixels-3.2.6.1"
:precision binary64
:herbie-target
(* (/ x 1.0) (/ (+ (/ x y) 1.0) (+ x 1.0)))
(/ (* x (+ (/ x y) 1.0)) (+ x 1.0)))