


Bits error versus t
Results
Initial program 0.1
rmApplied add-log-exp0.1
Final simplification0.1
herbie shell --seed 2018362 +o rules:numerics
(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.4m)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:
| 23.0ms | (/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 13.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 12.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
4 calls. Slowest were:
| 34.0ms | (/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 12.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 12.0ms | (/ (* 2 t) (+ 1 t)) |
| 12.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
120 calls. Slowest were:
| 919.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)))))) |
| 769.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)))) |
| 756.0ms | (- (+ (* 2 t) (* 2 (pow t 3))) (* 2 (pow t 2))) |
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:
| 9.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:
| 23.0ms | (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) |
| 19.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 17.0ms | (log (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) |
| 12.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
87 calls. Slowest were:
| 850.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)))) |
| 725.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)))) |
| 653.0ms | (log (* (cbrt (exp (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))) (cbrt (exp (* (/ (* 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 | (/ (* t 2) (+ 1 t)) |
| 0.0b | (/ (* 2 t) (+ 1 t)) |
4 calls. Slowest were:
| 14.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 7.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 6.0ms | (/ (* 2 t) (+ 1 t)) |
4 calls. Slowest were:
| 27.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 21.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 18.0ms | (/ (* t 2) (+ 1 t)) |
| 12.0ms | (/ (* 2 t) (+ 1 t)) |
104 calls. Slowest were:
| 857.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)))) |
| 771.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)))) |
| 703.0ms | (* (* (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) (/ (* 2 t) (+ 1 t))) (/ (* (* (* 2 t) (* 2 t)) (* 2 t)) (* (* (+ 1 t) (+ 1 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)))) |
| 14.0ms | (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t))) |
| 14.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
4 calls. Slowest were:
| 40.0ms | (/ (* 2 t) (sqrt (+ 1 t))) |
| 21.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t)))) |
| 20.0ms | (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))) |
| 18.0ms | (/ (/ (* 2 t) (sqrt (+ 1 t))) (sqrt (+ 1 t))) |
338 calls. Slowest were:
| 1.5s | (/ (* (* (/ (* 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)) (* (* (+ 1 t) (+ 1 t)) (+ 1 t))) (/ (* (* (/ (* 2 t) (sqrt (+ 1 t))) (/ (* 2 t) (sqrt (+ 1 t)))) (/ (* 2 t) (sqrt (+ 1 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