



Bits error versus d1




Bits error versus d2




Bits error versus d3




Bits error versus d4
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.0
Initial simplification0.0
Final simplification0.0
herbie shell --seed 2018360 +o rules:numerics
(FPCore (d1 d2 d3 d4)
:name "FastMath dist4"
:herbie-target
(* d1 (- (+ (- d2 d3) d4) d1))
(- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)))
Time bar (total: 51.6s)Debug log
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 0.0b | (* d1 (- (+ d2 d4) (+ d3 d1))) |
1 calls. Slowest were:
| 12.0ms | (* d1 (- (+ d2 d4) (+ d3 d1))) |
1 calls. Slowest were:
| 35.0ms | (* d1 (- (+ d2 d4) (+ d3 d1))) |
38 calls. Slowest were:
| 719.0ms | (* d1 (fma (- (+ d3 d1)) 1 (* (+ d3 d1) 1))) |
| 698.0ms | (* (fma (- (+ d3 d1)) 1 (* (+ d3 d1) 1)) d1) |
| 611.0ms | (* d1 (fma (- (+ d3 d1)) 1 (* (+ d3 d1) 1))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0b
Found 3 expressions with local error:
| 0.0b | (- (* d1 d2) (* d1 d3)) |
| 0.0b | (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) |
| 0.0b | (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)) |
3 calls. Slowest were:
| 97.0ms | (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)) |
| 17.0ms | (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) |
| 2.0ms | (- (* d1 d2) (* d1 d3)) |
3 calls. Slowest were:
| 49.0ms | (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)) |
| 35.0ms | (- (* d1 d2) (* d1 d3)) |
| 25.0ms | (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) |
36 calls. Slowest were:
| 692.0ms | (fma (sqrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (sqrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (- (* d1 d1))) |
| 380.0ms | (fma 1 (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (- (* d1 d1))) |
| 294.0ms | (/ (* (exp (- (* d1 d2) (* d1 d3))) (exp (* d4 d1))) (exp (* d1 d1))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.1b | (* (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) (- (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 0.1b | (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 0.0b | (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1))) |
| 0.0b | (sqrt (+ d2 d4)) |
4 calls. Slowest were:
| 33.0ms | (* (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) (- (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 16.0ms | (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 10.0ms | (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1))) |
4 calls. Slowest were:
| 196.0ms | (* (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) (- (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 96.0ms | (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1))) |
| 79.0ms | (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 23.0ms | (sqrt (+ d2 d4)) |
220 calls. Slowest were:
| 632.0ms | (* (* d1 (+ (* (sqrt (+ (pow d2 3) (pow d4 3))) (sqrt (+ (* d3 d3) (- (* d1 d1) (* d3 d1))))) (* (sqrt (+ (* d2 d2) (- (* d4 d4) (* d2 d4)))) (sqrt (+ (pow d3 3) (pow d1 3)))))) (- (* (sqrt (+ (pow d2 3) (pow d4 3))) (sqrt (+ (* d3 d3) (- (* d1 d1) (* d3 d1))))) (* (sqrt (+ (* d2 d2) (- (* d4 d4) (* d2 d4)))) (sqrt (+ (pow d3 3) (pow d1 3)))))) |
| 536.0ms | (* (* d1 (- (* (sqrt (+ d2 d4)) (sqrt (+ d2 d4))) (* (sqrt (+ d3 d1)) (sqrt (+ d3 d1))))) (- (sqrt (+ d2 d4)) (sqrt (+ d3 d1)))) |
| 511.0ms | (* (fma (- (sqrt (+ d3 d1))) 1 (* (sqrt (+ d3 d1)) 1)) (* d1 (+ (sqrt (+ d2 d4)) (sqrt (+ d3 d1))))) |
3 alts after pruning (0 fresh and 3 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b