



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
Simplified0.0
Final simplification0.0
herbie shell --seed 2019002 +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: 34.1s)Debug log
1 calls. Slowest were:
| 244.0ms | (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)) |
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:
| 8.0ms | (* d1 (- (+ d2 d4) (+ d3 d1))) |
1 calls. Slowest were:
| 42.0ms | (* d1 (- (+ d2 d4) (+ d3 d1))) |
38 calls. Slowest were:
| 595.0ms | (* (+ (* d2 d2) (- (* d4 d4) (* d2 d4))) (+ (* d3 d3) (- (* d1 d1) (* d3 d1)))) |
| 382.0ms | (* (fma (- (+ d3 d1)) 1 (* (+ d3 d1) 1)) d1) |
| 341.0ms | (* d1 (fma (- (+ d3 d1)) 1 (* (+ d3 d1) 1))) |
2 alts after pruning (1 fresh and 1 done)
Merged error: 0.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:
| 65.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:
| 43.0ms | (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1)) |
| 38.0ms | (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) |
| 36.0ms | (- (* d1 d2) (* d1 d3)) |
36 calls. Slowest were:
| 694.0ms | (fma (sqrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (sqrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (- (* d1 d1))) |
| 381.0ms | (/ (* (exp (- (* d1 d2) (* d1 d3))) (exp (* d4 d1))) (exp (* d1 d1))) |
| 370.0ms | (fma (* (cbrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (cbrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)))) (cbrt (+ (- (* d1 d2) (* d1 d3)) (* d4 d1))) (- (* d1 d1))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 23.5b | (/ (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) (+ (* d1 d2) (* d1 d3))) |
| 2.1b | (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) |
| 0.2b | (* (* d1 d3) (* d1 d3)) |
| 0.2b | (* (* d1 d2) (* d1 d2)) |
4 calls. Slowest were:
| 19.0ms | (/ (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) (+ (* d1 d2) (* d1 d3))) |
| 14.0ms | (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) |
| 11.0ms | (* (* d1 d2) (* d1 d2)) |
4 calls. Slowest were:
| 70.0ms | (/ (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) (+ (* d1 d2) (* d1 d3))) |
| 47.0ms | (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3))) |
| 25.0ms | (* (* d1 d2) (* d1 d2)) |
| 18.0ms | (* (* d1 d3) (* d1 d3)) |
76 calls. Slowest were:
| 1.1s | (/ (* (* d1 d2) (* d1 d2)) (+ (* d1 d2) (* d1 d3))) |
| 585.0ms | (/ (exp (* (* d1 d2) (* d1 d2))) (exp (* (* d1 d3) (* d1 d3)))) |
| 557.0ms | (- (log (- (* (* d1 d2) (* d1 d2)) (* (* d1 d3) (* d1 d3)))) (log (+ (* d1 d2) (* d1 d3)))) |
4 alts after pruning (1 fresh and 3 done)
Merged error: 0b
Found 4 expressions with local error:
| 19.2b | (* (* d2 d2) (/ d1 (+ d2 d3))) |
| 14.6b | (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3))) |
| 0.2b | (* (* d1 d3) (* d1 d3)) |
| 0.0b | (+ (- (* (* d2 d2) (/ d1 (+ d2 d3))) (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3)))) (* d4 d1)) |
4 calls. Slowest were:
| 41.0ms | (+ (- (* (* d2 d2) (/ d1 (+ d2 d3))) (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3)))) (* d4 d1)) |
| 8.0ms | (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3))) |
| 4.0ms | (* (* d2 d2) (/ d1 (+ d2 d3))) |
4 calls. Slowest were:
| 50.0ms | (+ (- (* (* d2 d2) (/ d1 (+ d2 d3))) (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3)))) (* d4 d1)) |
| 36.0ms | (/ (* (* d1 d3) (* d1 d3)) (+ (* d1 d2) (* d1 d3))) |
| 28.0ms | (* (* d2 d2) (/ d1 (+ d2 d3))) |
| 16.0ms | (* (* d1 d3) (* d1 d3)) |
64 calls. Slowest were:
| 553.0ms | (fma (* d2 d2) (/ d1 (+ d2 d3)) (- (* (/ (* d1 d3) (+ (* d1 d2) (* d1 d3))) (/ (* d1 d3) 1)))) |
| 493.0ms | (fma (* d2 d2) (/ d1 (+ d2 d3)) (- (* (/ 1 (+ (* d1 d2) (* d1 d3))) (* (* d1 d3) (* d1 d3))))) |
| 474.0ms | (* (* (* (* d1 d3) (* d1 d3)) (* d1 d3)) (* (* (* d1 d3) (* d1 d3)) (* d1 d3))) |
4 alts after pruning (0 fresh and 4 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b