\frac{4 \cdot \left(\left(x - y\right) - z \cdot 0.5\right)}{z}4 \cdot \left(\left(\frac{x}{z} - \frac{y}{z}\right) - 0.5\right)(FPCore (x y z) :precision binary64 (/ (* 4.0 (- (- x y) (* z 0.5))) z))
(FPCore (x y z) :precision binary64 (* 4.0 (- (- (/ x z) (/ y z)) 0.5)))
double code(double x, double y, double z) {
return (((double) (4.0 * ((double) (((double) (x - y)) - ((double) (z * 0.5)))))) / z);
}
double code(double x, double y, double z) {
return ((double) (4.0 * ((double) (((double) ((x / z) - (y / z))) - 0.5))));
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 0.1 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program Error: 0.1 bits
SimplifiedError: 0.0 bits
rmApplied div-subError: 0.0 bits
Final simplificationError: 0.0 bits
herbie shell --seed 2020204
(FPCore (x y z)
:name "Data.Array.Repa.Algorithms.ColorRamp:rampColorHotToCold from repa-algorithms-3.4.0.1, B"
:precision binary64
:herbie-target
(- (* 4.0 (/ x z)) (+ 2.0 (* 4.0 (/ y z))))
(/ (* 4.0 (- (- x y) (* z 0.5))) z))