


Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t
Results
if (/ y z) < -9.569205628693954e+253 or 4.83810691466513e+250 < (/ y z) Initial program 46.0
Simplified0.4
if -9.569205628693954e+253 < (/ y z) < -1.5935633578943175e-185 or 1.616385694453041e-132 < (/ y z) < 4.83810691466513e+250Initial program 8.1
Simplified9.0
Taylor expanded around inf 10.0
rmApplied associate-/l*0.3
if -1.5935633578943175e-185 < (/ y z) < 1.616385694453041e-132Initial program 17.1
Simplified1.0
rmApplied div-inv1.0
Applied associate-*r*1.3
Final simplification0.6
herbie shell --seed 2019004 +o rules:numerics
(FPCore (x y z t)
:name "Graphics.Rendering.Chart.Backend.Diagrams:calcFontMetrics from Chart-diagrams-1.5.1"
(* x (/ (* (/ y z) t) t)))
Time bar (total: 4.4s)Debug log
1 calls. Slowest were:
| 260.0ms | (* x (/ (* (/ y z) t) t)) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 0.8b
Found 1 expressions with local error:
| 5.9b | (* y (/ x z)) |
1 calls. Slowest were:
| 1.0ms | (* y (/ x z)) |
1 calls. Slowest were:
| 25.0ms | (* y (/ x z)) |
7 calls. Slowest were:
| 6.0ms | (/ (* x y) z) |
| 6.0ms | (/ (* x y) z) |
| 6.0ms | (/ (* x y) z) |
6 alts after pruning (5 fresh and 1 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 6.6b | (/ (* x y) z) |
1 calls. Slowest were:
| 5.0ms | (/ (* x y) z) |
1 calls. Slowest were:
| 29.0ms | (/ (* x y) z) |
3 calls. Slowest were:
| 7.0ms | (/ (* x y) z) |
| 6.0ms | (/ (* x y) z) |
| 6.0ms | (/ (* x y) z) |
5 alts after pruning (4 fresh and 1 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 6.5b | (/ x (/ z y)) |
1 calls. Slowest were:
| 1.0ms | (/ x (/ z y)) |
1 calls. Slowest were:
| 24.0ms | (/ x (/ z y)) |
7 calls. Slowest were:
| 11.0ms | (/ (* x y) z) |
| 11.0ms | (/ (* x y) z) |
| 11.0ms | (/ (* x y) z) |
6 alts after pruning (4 fresh and 2 done)
Merged error: 0.0b
Found 1 expressions with local error:
| 6.7b | (* (* y x) (/ 1 z)) |
1 calls. Slowest were:
| 6.0ms | (* (* y x) (/ 1 z)) |
1 calls. Slowest were:
| 13.0ms | (* (* y x) (/ 1 z)) |
10 calls. Slowest were:
| 440.0ms | (* (* (* (* y x) (* y x)) (* y x)) (* (* (/ 1 z) (/ 1 z)) (/ 1 z))) |
| 60.0ms | (+ (log (* y x)) (log (/ 1 z))) |
| 17.0ms | (* (* y x) (/ 1 z)) |
7 alts after pruning (4 fresh and 3 done)
Merged error: 0b
89.2% (0.6b remaining)
Error of 0.6b against oracle of 0.0b and baseline of 5.7b