


Bits error versus r



Bits error versus a



Bits error versus b
Results
Initial program 14.9
rmApplied cos-sum0.3
rmApplied div-inv0.4
rmApplied un-div-inv0.3
Applied associate-*r/0.3
rmApplied log1p-expm1-u0.4
Final simplification0.4
herbie shell --seed 2019022 +o rules:numerics
(FPCore (r a b)
:name "r*sin(b)/cos(a+b), B"
(* r (/ (sin b) (cos (+ a b)))))
Time bar (total: 22.1s)Debug log
| 107.0ms | 95× | body | 1280 | valid |
| 94.0ms | 52× | body | 640 | valid |
| 17.0ms | 28× | body | 320 | valid |
| 17.0ms | 73× | body | 80 | valid |
| 3.0ms | 8× | body | 160 | valid |
| 83.0ms | (* r (/ (sin b) (cos (+ a b)))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 13.0b
Found 3 expressions with local error:
| 2.8b | (cos (+ a b)) |
| 0.3b | (/ (sin b) (cos (+ a b))) |
| 0.2b | (* r (/ (sin b) (cos (+ a b)))) |
| 18× | add-cube-cbrt |
| 18× | times-frac |
| 18× | *-un-lft-identity |
| 18× | add-sqr-sqrt |
| 13× | associate-*r* |
| 5× | add-exp-log |
| 5× | add-cbrt-cube |
| 3× | add-log-exp |
| 3× | associate-/l* |
| 3× | log1p-expm1-u |
| 3× | associate-/r* |
| 3× | pow1 |
| 3× | expm1-log1p-u |
| 2× | div-inv |
| 1× | *-commutative |
| 1× | associate-*r/ |
| 1× | div-exp |
| 1× | frac-2neg |
| 1× | clear-num |
| 1× | cos-sum |
| 1× | cbrt-undiv |
| 8.0ms | (/ (sin b) (cos (+ a b))) |
| 6.0ms | (cos (+ a b)) |
| 5.0ms | (* r (/ (sin b) (cos (+ a b)))) |
| 103.0ms | (* r (/ (sin b) (cos (+ a b)))) |
| 57.0ms | (/ (sin b) (cos (+ a b))) |
| 49.0ms | (cos (+ a b)) |
| 203.0ms | (+ (* a (* r (pow b 2))) (+ (* 1/3 (* r (pow b 3))) (* r b))) |
| 130.0ms | (+ b (+ (* 1/3 (pow b 3)) (* a (pow b 2)))) |
| 118.0ms | (/ (* (* (sin b) (sin b)) (sin b)) (* (* (cos (+ a b)) (cos (+ a b))) (cos (+ a b)))) |
| 111.0ms | (- 1 (+ (* 1/2 (pow a 2)) (* a b))) |
| 32.0ms | (/ (* (cbrt (sin b)) (cbrt (sin b))) (* (cbrt (cos (+ a b))) (cbrt (cos (+ a b))))) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 0.2b
Found 4 expressions with local error:
| 0.2b | (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 0.2b | (* r (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 0.1b | (* (sin a) (sin b)) |
| 0.1b | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 21× | add-cube-cbrt |
| 21× | *-un-lft-identity |
| 21× | add-sqr-sqrt |
| 20× | associate-*r* |
| 18× | times-frac |
| 8× | associate-/r/ |
| 8× | add-exp-log |
| 8× | add-cbrt-cube |
| 7× | sin-mult |
| 6× | add-log-exp |
| 6× | cos-mult |
| 6× | pow1 |
| 4× | log1p-expm1-u |
| 4× | expm1-log1p-u |
| 3× | sub-div |
| 3× | associate-/l* |
| 3× | flip-- |
| 3× | frac-sub |
| 3× | associate-*l* |
| 3× | flip3-- |
| 3× | associate-/r* |
| 2× | div-inv |
| 2× | *-commutative |
| 1× | cbrt-unprod |
| 1× | associate-*r/ |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | prod-diff |
| 1× | div-exp |
| 1× | diff-log |
| 1× | fma-neg |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 14.0ms | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 12.0ms | (* r (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 11.0ms | (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 7.0ms | (* (sin a) (sin b)) |
| 237.0ms | (* r (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 147.0ms | (/ (sin b) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 113.0ms | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 48.0ms | (* (sin a) (sin b)) |
| 348.0ms | (- (* (+ (cos (+ a b)) (cos (- a b))) 2) (* 2 (- (cos (- a b)) (cos (+ a b))))) |
| 282.0ms | (- (+ (cos (+ a b)) (cos (- a b))) (- (cos (- a b)) (cos (+ a b)))) |
| 254.0ms | (+ (* a (* r (pow b 2))) (+ (* 1/3 (* r (pow b 3))) (* r b))) |
| 217.0ms | (+ (* (* (cos a) (cos b)) (* (cos a) (cos b))) (+ (* (* (sin a) (sin b)) (* (sin a) (sin b))) (* (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 194.0ms | (/ (* (* (sin b) (sin b)) (sin b)) (* (* (- (* (cos a) (cos b)) (* (sin a) (sin b))) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.3b | (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 0.2b | (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 0.2b | (* r (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))))) |
| 0.1b | (* (sin a) (sin b)) |
| 12× | associate-*r* |
| 11× | add-exp-log |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 9× | pow1 |
| 9× | add-sqr-sqrt |
| 8× | associate-/r/ |
| 8× | add-cbrt-cube |
| 6× | associate-*l* |
| 5× | sin-mult |
| 4× | add-log-exp |
| 4× | log1p-expm1-u |
| 4× | cos-mult |
| 4× | associate-*r/ |
| 4× | expm1-log1p-u |
| 3× | *-commutative |
| 3× | prod-exp |
| 3× | associate-/r* |
| 2× | sub-div |
| 2× | flip-- |
| 2× | div-inv |
| 2× | cbrt-unprod |
| 2× | frac-sub |
| 2× | un-div-inv |
| 2× | pow-prod-down |
| 2× | flip3-- |
| 2× | rec-exp |
| 1× | inv-pow |
| 1× | pow-flip |
| 1× | frac-2neg |
| 1× | clear-num |
| 19.0ms | (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 18.0ms | (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 7.0ms | (* (sin a) (sin b)) |
| 7.0ms | (* r (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))))) |
| 243.0ms | (* r (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))))) |
| 125.0ms | (* (sin b) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 105.0ms | (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 71.0ms | (* (sin a) (sin b)) |
| 342.0ms | (+ (* a (* r (pow b 2))) (+ (* 1/3 (* r (pow b 3))) (* r b))) |
| 256.0ms | (+ (* (* (cos a) (cos b)) (* (cos a) (cos b))) (+ (* (* (sin a) (sin b)) (* (sin a) (sin b))) (* (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 222.0ms | (+ (* (* (cos a) (cos b)) (* (cos a) (cos b))) (+ (* (* (sin a) (sin b)) (* (sin a) (sin b))) (* (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 211.0ms | (* (* (* (sin b) (sin b)) (sin b)) (* (* (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b))))) (/ 1 (- (* (cos a) (cos b)) (* (sin a) (sin b)))))) |
| 194.0ms | (+ b (+ (* 1/3 (pow b 3)) (* a (pow b 2)))) |
12 alts after pruning (12 fresh and 0 done)
Merged error: 0.0b
Found 4 expressions with local error:
| 0.2b | (/ (* r (sin b)) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 0.1b | (* (sin a) (sin b)) |
| 0.1b | (* r (sin b)) |
| 0.1b | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 9× | add-cube-cbrt |
| 9× | *-un-lft-identity |
| 9× | add-sqr-sqrt |
| 8× | add-exp-log |
| 8× | add-cbrt-cube |
| 6× | add-log-exp |
| 6× | associate-*r* |
| 6× | pow1 |
| 5× | sin-mult |
| 4× | log1p-expm1-u |
| 4× | cos-mult |
| 4× | associate-/r/ |
| 4× | expm1-log1p-u |
| 3× | associate-*l* |
| 3× | times-frac |
| 3× | associate-/r* |
| 2× | sub-div |
| 2× | flip-- |
| 2× | frac-sub |
| 2× | *-commutative |
| 2× | flip3-- |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | cbrt-unprod |
| 1× | prod-exp |
| 1× | pow-prod-down |
| 1× | prod-diff |
| 1× | div-exp |
| 1× | diff-log |
| 1× | fma-neg |
| 1× | frac-2neg |
| 1× | sub-neg |
| 1× | clear-num |
| 1× | cbrt-undiv |
| 20.0ms | (/ (* r (sin b)) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 7.0ms | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 7.0ms | (* (sin a) (sin b)) |
| 2.0ms | (* r (sin b)) |
| 212.0ms | (/ (* r (sin b)) (- (* (cos a) (cos b)) (* (sin a) (sin b)))) |
| 112.0ms | (- (* (cos a) (cos b)) (* (sin a) (sin b))) |
| 52.0ms | (* (sin a) (sin b)) |
| 34.0ms | (* r (sin b)) |
| 356.0ms | (- (* (+ (cos (+ a b)) (cos (- a b))) 2) (* 2 (- (cos (- a b)) (cos (+ a b))))) |
| 315.0ms | (- (+ (cos (+ a b)) (cos (- a b))) (- (cos (- a b)) (cos (+ a b)))) |
| 253.0ms | (+ (* a (* r (pow b 2))) (+ (* 1/3 (* r (pow b 3))) (* r b))) |
| 252.0ms | (+ (* (* (cos a) (cos b)) (* (cos a) (cos b))) (+ (* (* (sin a) (sin b)) (* (sin a) (sin b))) (* (* (cos a) (cos b)) (* (sin a) (sin b))))) |
| 193.0ms | (- 1 (+ (* 1/2 (pow a 2)) (* a b))) |
10 alts after pruning (10 fresh and 0 done)
Merged error: 0.0b
0% (0.3b remaining)
Error of 0.4b against oracle of 0.1b and baseline of 0.4b
| 3.7s | 2911× | body | 1280 | valid |
| 1.9s | 1856× | body | 640 | valid |
| 802.0ms | 2119× | body | 80 | valid |
| 414.0ms | 763× | body | 320 | valid |
| 158.0ms | 353× | body | 160 | valid |