


Bits error versus x



Bits error versus cos



Bits error versus sin
Results
if (pow cos 2) < 1.5034798266949682e-306 or 1.5266182343325565e+96 < (pow cos 2) Initial program 31.1
rmApplied unpow231.1
Applied associate-*r*27.1
rmApplied unpow227.1
Applied associate-*l*19.1
rmApplied associate-*r*15.2
rmApplied associate-*r*8.6
if 1.5034798266949682e-306 < (pow cos 2) < 1.5266182343325565e+96Initial program 21.3
rmApplied unpow221.3
Applied associate-*r*10.8
rmApplied associate-*l*6.6
Final simplification8.0
herbie shell --seed 2019002
(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: 17.1s)Debug log
1 calls. Slowest were:
| 225.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 29.0b
Found 4 expressions with local error:
| 19.8b | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 7.3b | (* x (pow sin 2)) |
| 4.7b | (* (* x (pow sin 2)) x) |
| 0.5b | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
4 calls. Slowest were:
| 15.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 12.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
| 6.0ms | (* (* x (pow sin 2)) x) |
4 calls. Slowest were:
| 51.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* x (pow sin 2)) x))) |
| 37.0ms | (* (pow cos 2) (* (* x (pow sin 2)) x)) |
| 16.0ms | (* (* x (pow sin 2)) x) |
| 16.0ms | (* x (pow sin 2)) |
35 calls. Slowest were:
| 542.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))) |
| 305.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))))) |
| 294.0ms | (- (log (cos (* 2 x))) (log (* (pow cos 2) (* (* x (pow sin 2)) x)))) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 10.7b
Found 4 expressions with local error:
| 19.8b | (* (pow cos 2) (* (* (* x sin) sin) x)) |
| 4.7b | (* (* (* x sin) sin) x) |
| 0.5b | (/ (cos (* 2 x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
| 0.2b | (* (* x sin) sin) |
4 calls. Slowest were:
| 13.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (* (* x sin) sin) x))) |
| 12.0ms | (* (pow cos 2) (* (* (* x sin) sin) x)) |
| 5.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)) |
| 17.0ms | (* (* (* x sin) sin) x) |
| 15.0ms | (* (* x sin) sin) |
33 calls. Slowest were:
| 493.0ms | (- (log (cos (* 2 x))) (+ (* (log cos) 2) (log (* (* (* x sin) sin) x)))) |
| 308.0ms | (- (log (cos (* 2 x))) (+ (log (pow cos 2)) (log (* (* (* x sin) sin) x)))) |
| 226.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
11 alts after pruning (11 fresh and 0 done)
Merged error: 7.6b
Found 4 expressions with local error:
| 9.1b | (* cos (* (* (* x sin) sin) x)) |
| 4.7b | (* (* (* x sin) sin) x) |
| 4.0b | (* cos (* cos (* (* (* x sin) sin) x))) |
| 0.5b | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
4 calls. Slowest were:
| 12.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 12.0ms | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 6.0ms | (* cos (* (* (* x sin) sin) x)) |
4 calls. Slowest were:
| 50.0ms | (/ (cos (* 2 x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
| 36.0ms | (* cos (* (* (* x sin) sin) x)) |
| 32.0ms | (* cos (* cos (* (* (* x sin) sin) x))) |
| 16.0ms | (* (* (* x sin) sin) x) |
26 calls. Slowest were:
| 192.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))))) |
| 184.0ms | (/ (* (* (cos (* 2 x)) (cos (* 2 x))) (cos (* 2 x))) (* (* (* cos (* cos (* (* (* x sin) sin) x))) (* cos (* cos (* (* (* x sin) sin) x)))) (* cos (* cos (* (* (* x sin) sin) x))))) |
| 179.0ms | (/ (* (cos x) (cos x)) (* cos (* cos (* (* (* x sin) sin) x)))) |
12 alts after pruning (12 fresh and 0 done)
Merged error: 3.2b
Found 4 expressions with local error:
| 7.4b | (* cos (* (* x sin) sin)) |
| 4.2b | (* (* cos (* (* x sin) sin)) x) |
| 4.0b | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 0.5b | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
4 calls. Slowest were:
| 11.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 11.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 6.0ms | (* (* cos (* (* x sin) sin)) x) |
4 calls. Slowest were:
| 48.0ms | (/ (cos (* 2 x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 35.0ms | (* (* cos (* (* x sin) sin)) x) |
| 32.0ms | (* cos (* (* cos (* (* x sin) sin)) x)) |
| 31.0ms | (* cos (* (* x sin) sin)) |
24 calls. Slowest were:
| 244.0ms | (/ (* (cos x) (cos x)) (* cos (* (* cos (* (* x sin) sin)) x))) |
| 184.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))))) |
| 159.0ms | (/ (cos (* 2 x)) (* (pow cos 2) (* (pow x 2) (pow sin 2)))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 2.2b
7% (4.2b remaining)
Error of 8.0b against oracle of 3.8b and baseline of 8.3b