


Bits error versus kx



Bits error versus ky



Bits error versus th
Results
Initial program 12.6
Simplified11.2
rmApplied associate-/l*9.0
rmApplied div-inv9.0
Final simplification9.0
herbie shell --seed 2019022 +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: 29.4s)Debug log
| 220.0ms | 92× | body | 1280 | valid |
| 113.0ms | 48× | body | 640 | valid |
| 27.0ms | 79× | body | 80 | valid |
| 25.0ms | 28× | body | 320 | valid |
| 5.0ms | 9× | body | 160 | valid |
| 14.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: 8.7b
Found 3 expressions with local error:
| 2.0b | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 0.1b | (* (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 |
| 14.0ms | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 7.0ms | (* (sin th) (sin ky)) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 294.0ms | (/ (* (sin th) (sin ky)) (hypot (sin kx) (sin ky))) |
| 135.0ms | (hypot (sin kx) (sin ky)) |
| 51.0ms | (* (sin th) (sin ky)) |
| 564.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)))) |
| 491.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)))) |
| 380.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 71.0ms | (* (* (* (sin th) (sin th)) (sin th)) (* (* (sin ky) (sin ky)) (sin ky))) |
| 36.0ms | (- (log (* (sin th) (sin ky))) (log (hypot (sin kx) (sin ky)))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 7.3b
Found 3 expressions with local error:
| 0.2b | (/ (sin ky) (hypot (sin kx) (sin ky))) |
| 0.2b | (* (sin th) (/ (sin ky) (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-*r* |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 5× | pow1 |
| 3× | add-log-exp |
| 3× | associate-/l* |
| 3× | log1p-expm1-u |
| 3× | associate-*l* |
| 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-*r/ |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | hypot-udef |
| 10.0ms | (* (sin th) (/ (sin ky) (hypot (sin kx) (sin ky)))) |
| 7.0ms | (/ (sin ky) (hypot (sin kx) (sin ky))) |
| 0.0ms | (hypot (sin kx) (sin ky)) |
| 301.0ms | (* (sin th) (/ (sin ky) (hypot (sin kx) (sin ky)))) |
| 179.0ms | (/ (sin ky) (hypot (sin kx) (sin ky))) |
| 119.0ms | (hypot (sin kx) (sin ky)) |
| 512.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))))) |
| 408.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 195.0ms | (- (+ (* 1/6 (* kx ky)) (* 7/360 (* (pow kx 3) ky))) (* 71/720 (* kx (pow ky 3)))) |
| 148.0ms | (* (* (* (sin th) (sin th)) (sin th)) (* (* (/ (sin ky) (hypot (sin kx) (sin ky))) (/ (sin ky) (hypot (sin kx) (sin ky)))) (/ (sin ky) (hypot (sin kx) (sin ky))))) |
| 116.0ms | (/ (* (* (sin ky) (sin ky)) (sin ky)) (* (* (hypot (sin kx) (sin ky)) (hypot (sin kx) (sin ky))) (hypot (sin kx) (sin ky)))) |
21 alts after pruning (21 fresh and 0 done)
Merged error: 7.3b
Found 3 expressions with local error:
| 0.2b | (/ (sin ky) (hypot (sin ky) (sin kx))) |
| 0.2b | (* (sin th) (/ (sin ky) (hypot (sin ky) (sin kx)))) |
| 0.1b | (hypot (sin ky) (sin kx)) |
| 19× | add-cube-cbrt |
| 19× | *-un-lft-identity |
| 19× | add-sqr-sqrt |
| 18× | times-frac |
| 13× | associate-*r* |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 5× | pow1 |
| 3× | add-log-exp |
| 3× | associate-/l* |
| 3× | log1p-expm1-u |
| 3× | associate-*l* |
| 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-*r/ |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | hypot-udef |
| 11.0ms | (* (sin th) (/ (sin ky) (hypot (sin ky) (sin kx)))) |
| 7.0ms | (/ (sin ky) (hypot (sin ky) (sin kx))) |
| 0.0ms | (hypot (sin ky) (sin kx)) |
| 261.0ms | (* (sin th) (/ (sin ky) (hypot (sin ky) (sin kx)))) |
| 193.0ms | (/ (sin ky) (hypot (sin ky) (sin kx))) |
| 136.0ms | (hypot (sin ky) (sin kx)) |
| 534.0ms | (* (* (* (sin th) (sin th)) (sin th)) (/ (* (* (sin ky) (sin ky)) (sin ky)) (* (* (hypot (sin ky) (sin kx)) (hypot (sin ky) (sin kx))) (hypot (sin ky) (sin kx))))) |
| 312.0ms | (- (+ (* 1/12 (* kx (pow ky 2))) kx) (* 1/6 (pow kx 3))) |
| 175.0ms | (- (+ (* 1/6 (* kx ky)) (* 7/360 (* (pow kx 3) ky))) (* 71/720 (* kx (pow ky 3)))) |
| 129.0ms | (* (* (* (sin th) (sin th)) (sin th)) (* (* (/ (sin ky) (hypot (sin ky) (sin kx))) (/ (sin ky) (hypot (sin ky) (sin kx)))) (/ (sin ky) (hypot (sin ky) (sin kx))))) |
| 117.0ms | (/ (* (* (sin ky) (sin ky)) (sin ky)) (* (* (hypot (sin ky) (sin kx)) (hypot (sin ky) (sin kx))) (hypot (sin ky) (sin kx)))) |
21 alts after pruning (20 fresh and 1 done)
Merged error: 7.3b
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)) |
| 260.0ms | (/ (sin th) (/ (hypot (sin kx) (sin ky)) (sin ky))) |
| 185.0ms | (/ (hypot (sin kx) (sin ky)) (sin ky)) |
| 126.0ms | (hypot (sin kx) (sin ky)) |
| 390.0ms | (- (+ (* 1/12 (* (pow kx 2) ky)) ky) (* 1/6 (pow ky 3))) |
| 341.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)))) |
| 324.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ 1 (* (cbrt (sin ky)) (cbrt (sin ky))))) |
| 299.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))))) |
| 247.0ms | (/ (* (cbrt (sin th)) (cbrt (sin th))) (/ (* (cbrt (hypot (sin kx) (sin ky))) (cbrt (hypot (sin kx) (sin ky)))) 1)) |
21 alts after pruning (21 fresh and 0 done)
Merged error: 7.3b
0% (0.2b remaining)
Error of 9.0b against oracle of 8.8b and baseline of 9.0b
| 7.8s | 2733× | body | 1280 | valid |
| 2.5s | 1845× | body | 640 | valid |
| 731.0ms | 2323× | body | 80 | valid |
| 696.0ms | 778× | body | 320 | valid |
| 176.0ms | 321× | body | 160 | valid |