


Bits error versus x
Results
Initial program 38.7
Simplified0.0
Final simplification0.0
herbie shell --seed 2019008 +o rules:numerics
(FPCore (x)
:name "Expanding a square"
(- (* (+ x 1) (+ x 1)) 1))
Time bar (total: 12.2s)Debug log
1 calls. Slowest were:
| 434.0ms | (- (* (+ x 1) (+ x 1)) 1) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 0.0b | (* (+ 2 x) x) |
1 calls. Slowest were:
| 4.0ms | (* (+ 2 x) x) |
1 calls. Slowest were:
| 24.0ms | (* (+ 2 x) x) |
7 calls. Slowest were:
| 210.0ms | (* (- (* 2 2) (* x x)) x) |
| 15.0ms | (* (+ (pow 2 3) (pow x 3)) x) |
| 6.0ms | (+ (* 2 x) (pow x 2)) |
3 alts after pruning (2 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.9b | (cbrt (+ 2 x)) |
| 0.9b | (cbrt (+ 2 x)) |
| 0.9b | (cbrt (+ 2 x)) |
| 0.4b | (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (* (cbrt (+ 2 x)) x)) |
4 calls. Slowest were:
| 18.0ms | (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (* (cbrt (+ 2 x)) x)) |
| 1.0ms | (cbrt (+ 2 x)) |
| 1.0ms | (cbrt (+ 2 x)) |
4 calls. Slowest were:
| 34.0ms | (cbrt (+ 2 x)) |
| 32.0ms | (cbrt (+ 2 x)) |
| 32.0ms | (cbrt (+ 2 x)) |
| 17.0ms | (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (* (cbrt (+ 2 x)) x)) |
76 calls. Slowest were:
| 297.0ms | (* (* (+ 2 x) (+ 2 x)) (* (* (* (cbrt (+ 2 x)) x) (* (cbrt (+ 2 x)) x)) (* (cbrt (+ 2 x)) x))) |
| 283.0ms | (- (+ (* 1/6 (* x (pow 2 1/3))) (pow 2 1/3)) (* 1/36 (* (pow x 2) (pow 2 1/3)))) |
| 283.0ms | (- (+ (* 1/6 (* x (pow 2 1/3))) (pow 2 1/3)) (* 1/36 (* (pow x 2) (pow 2 1/3)))) |
4 alts after pruning (3 fresh and 1 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.9b | (cbrt (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (cbrt (+ 2 x)))) |
| 0.9b | (cbrt (+ 2 x)) |
| 0.9b | (cbrt (+ 2 x)) |
| 0.9b | (cbrt (+ 2 x)) |
4 calls. Slowest were:
| 9.0ms | (cbrt (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (cbrt (+ 2 x)))) |
| 1.0ms | (cbrt (+ 2 x)) |
| 1.0ms | (cbrt (+ 2 x)) |
4 calls. Slowest were:
| 31.0ms | (cbrt (+ 2 x)) |
| 31.0ms | (cbrt (* (* (cbrt (+ 2 x)) (cbrt (+ 2 x))) (cbrt (+ 2 x)))) |
| 30.0ms | (cbrt (+ 2 x)) |
| 30.0ms | (cbrt (+ 2 x)) |
55 calls. Slowest were:
| 281.0ms | (- (+ (* 1/6 (* x (pow 2 1/3))) (pow 2 1/3)) (* 1/36 (* (pow x 2) (pow 2 1/3)))) |
| 279.0ms | (- (+ (* 1/6 (* x (pow 2 1/3))) (pow 2 1/3)) (* 1/36 (* (pow x 2) (pow 2 1/3)))) |
| 279.0ms | (- (+ (* 1/6 (* x (pow 2 1/3))) (pow 2 1/3)) (* 1/36 (* (pow x 2) (pow 2 1/3)))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0.0b
Found 2 expressions with local error:
| 5.8b | (/ (* x (- 4 (* x x))) (- 2 x)) |
| 0.1b | (* x (- 4 (* x x))) |
2 calls. Slowest were:
| 4.0ms | (/ (* x (- 4 (* x x))) (- 2 x)) |
| 1.0ms | (* x (- 4 (* x x))) |
2 calls. Slowest were:
| 43.0ms | (/ (* x (- 4 (* x x))) (- 2 x)) |
| 27.0ms | (* x (- 4 (* x x))) |
30 calls. Slowest were:
| 117.0ms | (* x (- (* 4 4) (* (* x x) (* x x)))) |
| 62.0ms | (/ (* (* (* x (- 4 (* x x))) (* x (- 4 (* x x)))) (* x (- 4 (* x x)))) (* (* (- 2 x) (- 2 x)) (- 2 x))) |
| 57.0ms | (* x (- (pow 4 3) (pow (* x x) 3))) |
4 alts after pruning (2 fresh and 2 done)
Merged error: 0b
0% (0.0b remaining)
Error of 0.0b against oracle of 0.0b and baseline of 0.0b