


Bits error versus kx



Bits error versus ky



Bits error versus th
Results
Initial program 13.1
Simplified11.7
rmApplied associate-/l*9.3
Taylor expanded around inf 13.2
Simplified9.3
Final simplification9.3
herbie shell --seed 2019010 +o rules:numerics
(FPCore (kx ky th)
:name "Toniolo and Linder, Equation (3b), real"
(* (/ (sin ky) (sqrt (+ (pow (sin kx) 2) (pow (sin ky) 2)))) (sin th)))
Time bar (total: 34.6s)Debug log
| 17.0ms | (* (/ (sin ky) (sqrt (+ (pow (sin kx) 2) (pow (sin ky) 2)))) (sin th)) |
2 alts after pruning (2 fresh and 0 done)
Merged error: 12.2b
Found 3 expressions with local error:
| 2.7b | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 0.3b | (* (sin th) (sin ky)) |
| 0.1b | (hypot (sin kx) (sin ky)) |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 5× | pow1 |
| 3× | add-log-exp |
| 3× | log1p-expm1-u |
| 3× | associate-*l* |
| 3× | associate-*r* |
| 3× | times-frac |
| 3× | associate-/r* |
| 3× | expm1-log1p-u |
| 2× | sin-mult |
| 2× | cbrt-unprod |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | cbrt-undiv |
| 1× | associate-/l/ |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | *-commutative |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | hypot-udef |
| 8.0ms | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 4.0ms | (* (sin th) (sin ky)) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 339.0ms | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 171.0ms | (hypot (sin kx) (sin ky)) |
| 75.0ms | (* (sin th) (sin ky)) |
| 621.0ms | (/ (* (* (* (sin th) (sin ky)) (* (sin th) (sin ky))) (* (sin th) (sin ky))) (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky)))) |
| 511.0ms | (/ (* (* (* (sin th) (sin th)) (sin th)) (* (* (sin ky) (sin ky)) (sin ky))) (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky)))) |
| 434.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 82.0ms | (* (* (* (sin th) (sin th)) (sin th)) (* (* (sin ky) (sin ky)) (sin ky))) |
| 37.0ms | (- (log (* (sin th) (sin ky))) (log (hypot (sin kx) (sin ky)))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 10.9b
Found 3 expressions with local error:
| 0.2b | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 0.1b | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 0.1b | (hypot (sin kx) (sin ky)) |
| 84× | times-frac |
| 53× | add-cube-cbrt |
| 53× | *-un-lft-identity |
| 53× | add-sqr-sqrt |
| 16× | associate-/r* |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 6× | associate-/l* |
| 6× | div-inv |
| 4× | div-exp |
| 4× | cbrt-undiv |
| 3× | add-log-exp |
| 3× | log1p-expm1-u |
| 3× | pow1 |
| 3× | expm1-log1p-u |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | associate-/r/ |
| 1× | hypot-udef |
| 10.0ms | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 8.0ms | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 265.0ms | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 201.0ms | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 125.0ms | (hypot (sin kx) (sin ky)) |
| 424.0ms | (/ (* (* (sin th) (sin th)) (sin th)) (/ (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky))) (* (* (sin ky) (sin ky)) (sin ky)))) |
| 375.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ (* (cbrt (hypot (sin kx) (sin ky))) (cbrt (hypot (sin kx) (sin ky)))) (* (cbrt (sin ky)) (cbrt (sin ky))))) |
| 350.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 330.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ 1 (* (cbrt (sin ky)) (cbrt (sin ky))))) |
| 293.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ (* (cbrt (hypot (sin kx) (sin ky))) (cbrt (hypot (sin kx) (sin ky)))) 1)) |
23 alts after pruning (23 fresh and 0 done)
Merged error: 10.8b
Found 3 expressions with local error:
| 0.2b | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 0.1b | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 0.1b | (hypot (sin kx) (sin ky)) |
| 84× | times-frac |
| 53× | add-cube-cbrt |
| 53× | *-un-lft-identity |
| 53× | add-sqr-sqrt |
| 16× | associate-/r* |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 6× | associate-/l* |
| 6× | div-inv |
| 4× | div-exp |
| 4× | cbrt-undiv |
| 3× | add-log-exp |
| 3× | log1p-expm1-u |
| 3× | pow1 |
| 3× | expm1-log1p-u |
| 2× | frac-2neg |
| 2× | clear-num |
| 1× | associate-/r/ |
| 1× | hypot-udef |
| 5.0ms | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 3.0ms | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 225.0ms | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 196.0ms | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 145.0ms | (hypot (sin kx) (sin ky)) |
| 420.0ms | (/ (* (* (sin th) (sin th)) (sin th)) (/ (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky))) (* (* (sin ky) (sin ky)) (sin ky)))) |
| 408.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 389.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ (* (cbrt (hypot (sin kx) (sin ky))) (cbrt (hypot (sin kx) (sin ky)))) (* (cbrt (sin ky)) (cbrt (sin ky))))) |
| 367.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ 1 (* (cbrt (sin ky)) (cbrt (sin ky))))) |
| 331.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ (* (cbrt (hypot (sin kx) (sin ky))) (cbrt (hypot (sin kx) (sin ky)))) 1)) |
23 alts after pruning (22 fresh and 1 done)
Merged error: 10.8b
Found 3 expressions with local error:
| 0.3b | (* (/ (sin th) (hypot (sin kx) (sin ky))) (sin ky)) |
| 0.2b | (/ (sin th) (hypot (sin kx) (sin ky))) |
| 0.1b | (hypot (sin kx) (sin ky)) |
| 19× | add-cube-cbrt |
| 19× | *-un-lft-identity |
| 19× | add-sqr-sqrt |
| 18× | times-frac |
| 13× | associate-*l* |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 5× | pow1 |
| 3× | add-log-exp |
| 3× | associate-/l* |
| 3× | log1p-expm1-u |
| 3× | associate-*r* |
| 3× | associate-/r* |
| 3× | expm1-log1p-u |
| 2× | div-inv |
| 2× | cbrt-unprod |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | cbrt-undiv |
| 1× | *-commutative |
| 1× | associate-*l/ |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | hypot-udef |
| 6.0ms | (* (/ (sin th) (hypot (sin kx) (sin ky))) (sin ky)) |
| 3.0ms | (/ (sin th) (hypot (sin kx) (sin ky))) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 251.0ms | (/ (sin th) (hypot (sin kx) (sin ky))) |
| 220.0ms | (* (/ (sin th) (hypot (sin kx) (sin ky))) (sin ky)) |
| 137.0ms | (hypot (sin kx) (sin ky)) |
| 487.0ms | (* (/ (* (* (sin th) (sin th)) (sin th)) (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky)))) (* (* (sin ky) (sin ky)) (sin ky))) |
| 368.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 177.0ms | (/ (* (* (sin th) (sin th)) (sin th)) (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky)))) |
| 146.0ms | (* (* (* (/ (sin th) (hypot (sin kx) (sin ky))) (/ (sin th) (hypot (sin kx) (sin ky)))) (/ (sin th) (hypot (sin kx) (sin ky)))) (* (* (sin ky) (sin ky)) (sin ky))) |
| 65.0ms | (+ (- (log (sin th)) (log (hypot (sin kx) (sin ky)))) (log (sin ky))) |
24 alts after pruning (22 fresh and 2 done)
Merged error: 10.8b
0% (0.1b remaining)
Error of 9.3b against oracle of 9.2b and baseline of 9.3b