


Bits error versus x



Bits error versus cos



Bits error versus sin
Results
Initial program 27.7
rmApplied unpow227.7
Applied associate-*r*21.3
rmApplied unpow221.3
Applied associate-*l*15.9
rmApplied associate-*r*13.2
rmApplied associate-*r*8.2
Final simplification8.2
herbie shell --seed 2019008 +o rules:numerics
(FPCore (x cos sin)
:name "cos(2*x)/(cos^2(x)*sin^2(x))"
(/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))))
Time bar (total: 20.2s)Debug log
1 calls. Slowest were:
| 172.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 27.2b
Found 4 expressions with local error:
| 18.1b | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 8.5b | (* x (pow sin 2)) |
| 4.1b | (* (* x (pow sin 2)) x) |
| 0.7b | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
4 calls. Slowest were:
| 11.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
| 9.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 4.0ms | (* (* x (pow sin 2)) x) |
4 calls. Slowest were:
| 49.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
| 36.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 16.0ms | (* (* x (pow sin 2)) x) |
| 15.0ms | (* x (pow sin 2)) |
35 calls. Slowest were:
| 388.0ms | (* (* (* (pow cos 2) (pow cos 2)) (pow cos 2)) (* (* (* (* x (pow sin 2)) x) (* (* x (pow sin 2)) x)) (* (* x (pow sin 2)) x))) |
| 249.0ms | (- (log (cos (* 2 x))) (log (* (pow cos 2) (* (* x (pow sin 2)) x)))) |
| 204.0ms | (- (+ (/ 1 (* (pow x 2) (* (pow sin 2) (pow cos 2)))) (* 2/3 (/ (pow x 2) (* (pow sin 2) (pow cos 2))))) (* 2 (/ 1 (* (pow sin 2) (pow cos 2))))) |
14 alts after pruning (14 fresh and 0 done)
Merged error: 8.7b
Found 4 expressions with local error:
| 18.1b | (* (pow cos 2) (* (* (* x sin) sin) x)) |
| 4.1b | (* (* (* x sin) sin) x) |
| 0.7b | (/ (cos (* 2 x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
| 0.2b | (cos (* 2 x)) |
4 calls. Slowest were:
| 14.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
| 13.0ms | (* (pow cos 2) (* (* (* x sin) sin) x)) |
| 7.0ms | (* (* (* x sin) sin) x) |
4 calls. Slowest were:
| 50.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
| 32.0ms | (* (pow cos 2) (* (* (* x sin) sin) x)) |
| 16.0ms | (* (* (* x sin) sin) x) |
| 7.0ms | (cos (* 2 x)) |
34 calls. Slowest were:
| 280.0ms | (- (log (cos (* 2 x))) (+ (log (pow cos 2)) (log (* (* (* x sin) sin) x)))) |
| 267.0ms | (- (+ (/ 1 (* (pow x 2) (* (pow sin 2) (pow cos 2)))) (* 2/3 (/ (pow x 2) (* (pow sin 2) (pow cos 2))))) (* 2 (/ 1 (* (pow sin 2) (pow cos 2))))) |
| 257.0ms | (/ (* (cos x) (cos x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
17 alts after pruning (17 fresh and 0 done)
Merged error: 6.1b
Found 4 expressions with local error:
| 6.5b | (* cos (* (* (* x sin) sin) x)) |
| 5.3b | (* cos (* cos (* (* (* x sin) sin) x))) |
| 4.1b | (* (* (* x sin) sin) x) |
| 0.7b | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
4 calls. Slowest were:
| 17.0ms | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 15.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 7.0ms | (* cos (* (* (* x sin) sin) x)) |
4 calls. Slowest were:
| 72.0ms | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 60.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 59.0ms | (* cos (* (* (* x sin) sin) x)) |
| 29.0ms | (* (* (* x sin) sin) x) |
26 calls. Slowest were:
| 285.0ms | (- (+ (/ 1 (* (pow x 2) (* (pow sin 2) (pow cos 2)))) (* 2/3 (/ (pow x 2) (* (pow sin 2) (pow cos 2))))) (* 2 (/ 1 (* (pow sin 2) (pow cos 2))))) |
| 250.0ms | (/ (* (cos x) (cos x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 227.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 4.3b
Found 4 expressions with local error:
| 6.2b | (* cos (* (* x sin) sin)) |
| 5.3b | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 3.9b | (* (* cos (* (* x sin) sin)) x) |
| 0.7b | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
4 calls. Slowest were:
| 24.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 14.0ms | (* (* cos (* (* x sin) sin)) x) |
| 13.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
4 calls. Slowest were:
| 69.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 49.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 37.0ms | (* (* cos (* (* x sin) sin)) x) |
| 36.0ms | (* cos (* (* x sin) sin)) |
24 calls. Slowest were:
| 409.0ms | (/ (* (cos x) (cos x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 283.0ms | (- (+ (/ 1 (* (pow x 2) (* (pow sin 2) (pow cos 2)))) (* 2/3 (/ (pow x 2) (* (pow sin 2) (pow cos 2))))) (* 2 (/ 1 (* (pow sin 2) (pow cos 2))))) |
| 227.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 3.2b
0% (4.6b remaining)
Error of 8.2b against oracle of 3.6b and baseline of 8.2b