


Bits error versus x1



Bits error versus x2
Initial program 0.5
Simplified0.5
rmApplied *-un-lft-identity0.5
Applied *-un-lft-identity0.5
Applied *-un-lft-identity0.5
Applied distribute-lft-out--0.5
Applied times-frac0.5
Simplified0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2019007 +o rules:numerics
(FPCore (x1 x2)
:name "Rosa's FloatVsDoubleBenchmark"
(+ x1 (+ (+ (+ (+ (* (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) (+ (* x1 x1) 1)) (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)))) (* (* x1 x1) x1)) x1) (* 3 (/ (- (- (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))))))
Time bar (total: 3.5m)Debug log
1 calls. Slowest were:
| 458.0ms | (+ x1 (+ (+ (+ (+ (* (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) (+ (* x1 x1) 1)) (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)))) (* (* x1 x1) x1)) x1) (* 3 (/ (- (- (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))))) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.5b
Found 4 expressions with local error:
| 7.1b | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1)))))) |
| 5.3b | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
| 2.6b | (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) |
| 1.0b | (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1))))) |
4 calls. Slowest were:
| 59.0ms | (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1))))) |
| 24.0ms | (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) |
| 4.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
4 calls. Slowest were:
| 178.0ms | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1)))))) |
| 161.0ms | (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1))))) |
| 50.0ms | (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) |
| 47.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
307 calls. Slowest were:
| 648.0ms | (- (* (fma x1 (* 3 x1) (* x2 2)) (- (/ x1 (fma x1 x1 1)) 3)) (* (fma x1 x1 1) (- (* (/ x1 (fma x1 x1 1)) (/ x1 (fma x1 x1 1))) (* 3 3)))) |
| 562.0ms | (/ (+ (/ (sqrt (fma x1 (* 3 x1) (* x2 2))) (sqrt (fma x1 x1 1))) (sqrt (+ (/ x1 (fma x1 x1 1)) 3))) (* (cbrt (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1))))) (cbrt (/ (fma x1 x1 1) (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1))))))) |
| 559.0ms | (/ (- (/ (fma x1 (* 3 x1) (* x2 2)) (fma x1 x1 1)) (+ (/ x1 (fma x1 x1 1)) 3)) (/ (fma x1 x1 1) (sqrt (fma (fma x1 (* 3 x1) (* x2 2)) (* x1 2) (* (* x1 2) (- x1)))))) |
8 alts after pruning (8 fresh and 0 done)
Merged error: 0.4b
Found 4 expressions with local error:
| 7.4b | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (* 1 (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (/ (fma x1 x1 1) (* 2 x1)) (fma x1 (* x1 3) (- (* x2 2) x1)))))) |
| 5.3b | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
| 2.6b | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 1.0b | (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (/ (fma x1 x1 1) (* 2 x1)) (fma x1 (* x1 3) (- (* x2 2) x1)))) |
4 calls. Slowest were:
| 35.0ms | (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (/ (fma x1 x1 1) (* 2 x1)) (fma x1 (* x1 3) (- (* x2 2) x1)))) |
| 13.0ms | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 7.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
4 calls. Slowest were:
| 213.0ms | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (* 1 (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (/ (fma x1 x1 1) (* 2 x1)) (fma x1 (* x1 3) (- (* x2 2) x1)))))) |
| 145.0ms | (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (/ (fma x1 x1 1) (* 2 x1)) (fma x1 (* x1 3) (- (* x2 2) x1)))) |
| 45.0ms | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 34.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
466 calls. Slowest were:
| 651.0ms | (/ (+ (/ (sqrt (fma x1 (* x1 3) (* x2 2))) (sqrt (fma x1 x1 1))) (sqrt (+ 3 (/ x1 (fma x1 x1 1))))) (/ (/ (* (cbrt (fma x1 x1 1)) (cbrt (fma x1 x1 1))) 2) (* (cbrt (fma x1 (* x1 3) (- (* x2 2) x1))) (cbrt (fma x1 (* x1 3) (- (* x2 2) x1)))))) |
| 563.0ms | (fma (- (+ 3 (/ x1 (fma x1 x1 1)))) 1 (* (+ 3 (/ x1 (fma x1 x1 1))) 1)) |
| 549.0ms | (fma (- (+ 3 (/ x1 (fma x1 x1 1)))) 1 (* (+ 3 (/ x1 (fma x1 x1 1))) 1)) |
8 alts after pruning (7 fresh and 1 done)
Merged error: 0.4b
Found 4 expressions with local error:
| 7.6b | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (* 1 (/ (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (fma x1 x1 1) (* 2 x1))) (/ 1 (fma x1 (* x1 3) (- (* x2 2) x1)))))) |
| 5.3b | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
| 2.6b | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 0.6b | (/ 3 (/ (fma x1 x1 1) (* x1 x1))) |
4 calls. Slowest were:
| 22.0ms | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 8.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
| 1.0ms | (/ 3 (/ (fma x1 x1 1) (* x1 x1))) |
4 calls. Slowest were:
| 196.0ms | (fma (fma 4 (/ (fma 3 (* x1 x1) (- (* x2 2) x1)) (fma x1 x1 1)) -6) (* x1 x1) (* 1 (/ (/ (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) (/ (fma x1 x1 1) (* 2 x1))) (/ 1 (fma x1 (* x1 3) (- (* x2 2) x1)))))) |
| 53.0ms | (- (/ (fma x1 (* x1 3) (* x2 2)) (fma x1 x1 1)) (+ 3 (/ x1 (fma x1 x1 1)))) |
| 37.0ms | (/ 3 (/ (fma x1 x1 1) (* x1 x1))) |
| 37.0ms | (* (/ 3 (/ (fma x1 x1 1) (* x1 x1))) (fma 3 (* x1 x1) (- (* x2 2) x1))) |
133 calls. Slowest were:
| 553.0ms | (fma (- (+ 3 (/ x1 (fma x1 x1 1)))) 1 (* (+ 3 (/ x1 (fma x1 x1 1))) 1)) |
| 520.0ms | (fma (- (+ 3 (/ x1 (fma x1 x1 1)))) 1 (* (+ 3 (/ x1 (fma x1 x1 1))) 1)) |
| 482.0ms | (fma (- (+ 3 (/ x1 (fma x1 x1 1)))) 1 (* (+ 3 (/ x1 (fma x1 x1 1))) 1)) |
8 alts after pruning (6 fresh and 2 done)
Merged error: 0.4b
Found 4 expressions with local error:
| 5.3b | (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) |
| 5.3b | (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6)) |
| 3.8b | (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) |
| 2.6b | (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3) |
4 calls. Slowest were:
| 120.0ms | (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) |
| 83.0ms | (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3) |
| 46.0ms | (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) |
4 calls. Slowest were:
| 160.0ms | (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) |
| 42.0ms | (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3) |
| 41.0ms | (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6)) |
| 29.0ms | (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) |
91 calls. Slowest were:
| 650.0ms | (+ (* (* (* (* 2 x1) (- (+ (* (* 3 x1) x1) (* 2 x2)) x1)) (- (pow (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3) (pow 3 3))) (+ (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6)) (* (* (+ (* x1 x1) 1) (+ (* (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (+ (* 3 3) (* (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)))) (* (* x1 x1) (- (* (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)))) (* 6 6))))) |
| 642.0ms | (+ (* (* (* (* 2 x1) (- (+ (* (* 3 x1) x1) (* 2 x2)) x1)) (- (* (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (* 3 3))) (+ (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6)) (* (* (+ (* x1 x1) 1) (+ (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)))) (* 6 6))))) |
| 621.0ms | (+ (log (* x1 x1)) (log (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) |
8 alts after pruning (6 fresh and 2 done)
Merged error: 0.3b
0% (0.1b remaining)
Error of 0.5b against oracle of 0.4b and baseline of 0.5b