


Bits error versus x



Bits error versus cos



Bits error versus sin
Results
if x < -61357.354317215366 or -9.238259325850402e-152 < x Initial program 28.3
rmApplied unpow228.3
Applied associate-*l*23.8
rmApplied unpow223.8
Applied associate-*r*15.9
rmApplied associate-*r*13.1
rmApplied associate-*r*8.3
if -61357.354317215366 < x < -9.238259325850402e-152Initial program 27.4
rmApplied unpow227.4
Applied associate-*l*23.8
rmApplied unpow223.8
Applied associate-*r*21.0
Taylor expanded around 0 27.7
Simplified9.9
Final simplification8.4
herbie shell --seed 2019004
(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: 19.1s)Debug log
1 calls. Slowest were:
| 180.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 26.9b
Found 4 expressions with local error:
| 20.1b | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 5.9b | (* x (pow sin 2)) |
| 3.4b | (* (* x (pow sin 2)) x) |
| 0.9b | (/ (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))) |
| 10.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 4.0ms | (* (* x (pow sin 2)) x) |
4 calls. Slowest were:
| 52.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
| 37.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 17.0ms | (* (* x (pow sin 2)) x) |
| 16.0ms | (* x (pow sin 2)) |
35 calls. Slowest were:
| 434.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))) |
| 252.0ms | (- (log (cos (* 2 x))) (log (* (pow cos 2) (* (* x (pow sin 2)) x)))) |
| 201.0ms | (/ (* (* (cos (* 2 x)) (cos (* 2 x))) (cos (* 2 x))) (* (* (* (pow cos 2) (* (* x (pow sin 2)) x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) (* (pow cos 2) (* (* x (pow sin 2)) x)))) |
11 alts after pruning (11 fresh and 0 done)
Merged error: 12.5b
Found 4 expressions with local error:
| 7.7b | (* cos (* cos (* (* x (pow sin 2)) x))) |
| 5.9b | (* x (pow sin 2)) |
| 5.1b | (* cos (* (* x (pow sin 2)) x)) |
| 3.4b | (* (* x (pow sin 2)) x) |
4 calls. Slowest were:
| 10.0ms | (* cos (* cos (* (* x (pow sin 2)) x))) |
| 9.0ms | (* cos (* (* x (pow sin 2)) x)) |
| 7.0ms | (* (* x (pow sin 2)) x) |
4 calls. Slowest were:
| 41.0ms | (* cos (* (* x (pow sin 2)) x)) |
| 37.0ms | (* cos (* cos (* (* x (pow sin 2)) x))) |
| 25.0ms | (* x (pow sin 2)) |
| 17.0ms | (* (* x (pow sin 2)) x) |
16 calls. Slowest were:
| 134.0ms | (* (pow x 2) (* (pow sin 2) (pow cos 2))) |
| 105.0ms | (* (pow x 2) (* (pow sin 2) (pow cos 2))) |
| 103.0ms | (* (pow x 2) (* (pow sin 2) (pow cos 2))) |
12 alts after pruning (12 fresh and 0 done)
Merged error: 9.1b
Found 4 expressions with local error:
| 7.7b | (* cos (* cos (* (* (* x sin) sin) x))) |
| 5.1b | (* cos (* (* (* x sin) sin) x)) |
| 3.4b | (* (* (* x sin) sin) x) |
| 0.9b | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
4 calls. Slowest were:
| 26.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 21.0ms | (/ (cos (* 2 x)) (* 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)))) |
| 62.0ms | (* cos (* (* (* x sin) sin) x)) |
| 40.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 30.0ms | (* (* (* x sin) sin) x) |
26 calls. Slowest were:
| 248.0ms | (/ (* (cos x) (cos x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 233.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
| 233.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 7.0b
Found 4 expressions with local error:
| 7.7b | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 7.1b | (* cos (* (* x sin) sin)) |
| 3.4b | (* (* cos (* (* x sin) sin)) x) |
| 0.9b | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
4 calls. Slowest were:
| 28.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 25.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 14.0ms | (* (* cos (* (* x sin) sin)) x) |
4 calls. Slowest were:
| 87.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 59.0ms | (* (* cos (* (* x sin) sin)) x) |
| 38.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 34.0ms | (* cos (* (* x sin) sin)) |
24 calls. Slowest were:
| 332.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))))) |
| 328.0ms | (/ (* (cos x) (cos x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 239.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
14 alts after pruning (14 fresh and 0 done)
Merged error: 5.8b
-4.2% (4.5b remaining)
Error of 8.4b against oracle of 3.9b and baseline of 8.3b