


Bits error versus t
Results
Initial program 0.1
rmApplied add-log-exp0.1
Final simplification0.1
herbie shell --seed 2018362
(FPCore (t)
:name "Kahan p13 Example 1"
(/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))))
Time bar (total: 1.3m)Debug log
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 0.0b | (/ (* 2 t) (+ 1 t)) |
4 calls. Slowest were:
| 22.0ms | (/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 15.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 15.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
4 calls. Slowest were:
| 32.0ms | (/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 26.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 18.0ms | (/ (* 2 t) (+ 1 t)) |
| 15.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
120 calls. Slowest were:
| 710.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
| 668.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
| 660.0ms | (+ (* 2 2) (- (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (* 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))))) |
3 alts after pruning (3 fresh and 0 done)
Merged error: 0b
Found 4 expressions with local error:
| 1.7b | (log (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) |
4 calls. Slowest were:
| 10.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 7.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 3.0ms | (log (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
4 calls. Slowest were:
| 25.0ms | (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) |
| 18.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 13.0ms | (log (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 13.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
87 calls. Slowest were:
| 734.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
| 692.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 687.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (/ (* 2 t) (+ 1 t)) |
4 calls. Slowest were:
| 14.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 14.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 14.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
4 calls. Slowest were:
| 21.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 20.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 12.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 11.0ms | (/ (* 2 t) (+ 1 t)) |
124 calls. Slowest were:
| 781.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
| 723.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
| 704.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t)))) |
3 alts after pruning (1 fresh and 2 done)
Merged error: 0b
Found 4 expressions with local error:
| 0.1b | (/ (* 2 t) (sqrt (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 0.0b | (* (/ (* 2 t) (+ 1 t)) (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
| 0.0b | (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t))) |
4 calls. Slowest were:
| 21.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
| 12.0ms | (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t))) |
| 7.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
4 calls. Slowest were:
| 44.0ms | (/ (* 2 t) (sqrt (+ 1 t))) |
| 22.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
| 21.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 18.0ms | (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t))) |
338 calls. Slowest were:
| 1.4s | (/ (* (* (/ (* 2 t) (sqrt (+ 1 t))) (/ (* 2 t) (sqrt (+ 1 t)))) (/ (* 2 t) (sqrt (+ 1 t)))) (* (* (sqrt (+ 1 t)) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
| 1.1s | (* (/ (* (* (* 2 t) (* 2 t)) (* 2 t)) (* (* (+ 1 t) (+ 1 t)) (+ 1 t))) (/ (/ (* (* (* 2 t) (* 2 t)) (* 2 t)) (* (* (sqrt (+ 1 t)) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) (* (* (sqrt (+ 1 t)) (sqrt (+ 1 t))) (sqrt (+ 1 t))))) |
| 849.0ms | (/ (* (* (* 2 t) (* 2 t)) (* 2 t)) (* (* (sqrt (+ 1 t)) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
3 alts after pruning (0 fresh and 3 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.1b against oracle of 0.1b and baseline of 0.1b