


Bits error versus a1



Bits error versus a2



Bits error versus th
Results
Initial program 0.5
Simplified0.5
rmApplied associate-*l/0.5
Final simplification0.5
herbie shell --seed 2019016
(FPCore (a1 a2 th)
:name "Migdal et al, Equation (64)"
(+ (* (/ (cos th) (sqrt 2)) (* a1 a1)) (* (/ (cos th) (sqrt 2)) (* a2 a2))))
Time bar (total: 24.6s)Debug log
| 447× | (pre true 80) |
| 250× | (body real 80) |
| 96× | (body real 1280) |
| 60× | (body real 640) |
| 22× | (body real 320) |
| 19× | (body real 160) |
| 69.0ms | (+ (* (/ (cos th) (sqrt 2)) (* a1 a1)) (* (/ (cos th) (sqrt 2)) (* a2 a2))) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 0.5b
Found 3 expressions with local error:
| 0.7b | (/ (cos th) (sqrt 2)) |
| 0.4b | (* (/ (cos th) (sqrt 2)) (+ (* a1 a1) (* a2 a2))) |
| 0.0b | (+ (* a1 a1) (* a2 a2)) |
| 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× | add-log-exp |
| 5× | pow1 |
| 3× | associate-/l* |
| 3× | flip-+ |
| 3× | associate-*r* |
| 3× | flip3-+ |
| 3× | associate-/r* |
| 2× | div-inv |
| 2× | cbrt-unprod |
| 2× | associate-*r/ |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | cbrt-undiv |
| 2× | frac-times |
| 1× | *-commutative |
| 1× | associate-*l/ |
| 1× | pow-prod-down |
| 1× | distribute-lft-in |
| 1× | frac-2neg |
| 1× | sum-log |
| 1× | clear-num |
| 1× | +-commutative |
| 1× | distribute-rgt-in |
| 11.0ms | (* (/ (cos th) (sqrt 2)) (+ (* a1 a1) (* a2 a2))) |
| 4.0ms | (+ (* a1 a1) (* a2 a2)) |
| 3.0ms | (/ (cos th) (sqrt 2)) |
| 217.0ms | (* (/ (cos th) (sqrt 2)) (+ (* a1 a1) (* a2 a2))) |
| 52.0ms | (/ (cos th) (sqrt 2)) |
| 25.0ms | (+ (* a1 a1) (* a2 a2)) |
| 394.0ms | (* (cos th) (- (* (* a1 a1) (* a1 a1)) (* (* a2 a2) (* a2 a2)))) |
| 393.0ms | (* (sqrt 2) (- (* a1 a1) (* a2 a2))) |
| 225.0ms | (/ (* (* (cos th) (cos th)) (cos th)) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) |
| 216.0ms | (* (/ (* (* (cos th) (cos th)) (cos th)) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) (* (* (+ (* a1 a1) (* a2 a2)) (+ (* a1 a1) (* a2 a2))) (+ (* a1 a1) (* a2 a2)))) |
| 207.0ms | (+ (* (* a1 a1) (* a1 a1)) (- (* (* a2 a2) (* a2 a2)) (* (* a1 a1) (* a2 a2)))) |
8 alts after pruning (8 fresh and 0 done)
Merged error: 0.0b
Found 3 expressions with local error:
| 0.4b | (/ (* (cos th) (+ (* a1 a1) (* a2 a2))) (sqrt 2)) |
| 0.2b | (* (cos th) (+ (* a1 a1) (* a2 a2))) |
| 0.0b | (+ (* a1 a1) (* a2 a2)) |
| 10× | add-exp-log |
| 10× | add-cbrt-cube |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 5× | add-log-exp |
| 5× | pow1 |
| 4× | associate-*r/ |
| 3× | flip-+ |
| 3× | associate-*l* |
| 3× | associate-*r* |
| 3× | times-frac |
| 3× | flip3-+ |
| 3× | associate-/r* |
| 2× | associate-/l/ |
| 2× | cbrt-unprod |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | cbrt-undiv |
| 1× | associate-/l* |
| 1× | div-inv |
| 1× | *-commutative |
| 1× | pow-prod-down |
| 1× | distribute-lft-in |
| 1× | frac-2neg |
| 1× | sum-log |
| 1× | clear-num |
| 1× | +-commutative |
| 1× | distribute-rgt-in |
| 10.0ms | (/ (* (cos th) (+ (* a1 a1) (* a2 a2))) (sqrt 2)) |
| 8.0ms | (* (cos th) (+ (* a1 a1) (* a2 a2))) |
| 4.0ms | (+ (* a1 a1) (* a2 a2)) |
| 177.0ms | (/ (* (cos th) (+ (* a1 a1) (* a2 a2))) (sqrt 2)) |
| 123.0ms | (* (cos th) (+ (* a1 a1) (* a2 a2))) |
| 15.0ms | (+ (* a1 a1) (* a2 a2)) |
| 401.0ms | (* (cos th) (- (* (* a1 a1) (* a1 a1)) (* (* a2 a2) (* a2 a2)))) |
| 182.0ms | (/ (* (* (* (cos th) (cos th)) (cos th)) (* (* (+ (* a1 a1) (* a2 a2)) (+ (* a1 a1) (* a2 a2))) (+ (* a1 a1) (* a2 a2)))) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) |
| 160.0ms | (+ (* (* a1 a1) (* a1 a1)) (- (* (* a2 a2) (* a2 a2)) (* (* a1 a1) (* a2 a2)))) |
| 140.0ms | (* (cos th) (+ (pow (* a1 a1) 3) (pow (* a2 a2) 3))) |
| 129.0ms | (/ (* (* (* (cos th) (+ (* a1 a1) (* a2 a2))) (* (cos th) (+ (* a1 a1) (* a2 a2)))) (* (cos th) (+ (* a1 a1) (* a2 a2)))) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) |
6 alts after pruning (5 fresh and 1 done)
Merged error: 0b
Found 4 expressions with local error:
| 4.5b | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 4.5b | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 0.7b | (/ (cos th) (sqrt 2)) |
| 0.4b | (* (/ (cos th) (sqrt 2)) (sqrt (+ (* a1 a1) (* a2 a2)))) |
| 25× | add-sqr-sqrt |
| 23× | add-cube-cbrt |
| 23× | *-un-lft-identity |
| 18× | times-frac |
| 13× | associate-*l* |
| 11× | add-exp-log |
| 11× | add-cbrt-cube |
| 9× | sqrt-prod |
| 8× | sqrt-div |
| 6× | associate-*r* |
| 6× | pow1 |
| 4× | add-log-exp |
| 4× | flip-+ |
| 4× | flip3-+ |
| 3× | associate-/l* |
| 3× | associate-/r* |
| 2× | div-inv |
| 2× | cbrt-unprod |
| 2× | associate-*r/ |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | pow1/2 |
| 2× | rem-sqrt-square |
| 2× | cbrt-undiv |
| 2× | frac-times |
| 1× | *-commutative |
| 1× | associate-*l/ |
| 1× | pow-prod-down |
| 1× | frac-2neg |
| 1× | clear-num |
| 20.0ms | (* (/ (cos th) (sqrt 2)) (sqrt (+ (* a1 a1) (* a2 a2)))) |
| 6.0ms | (/ (cos th) (sqrt 2)) |
| 4.0ms | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 4.0ms | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 153.0ms | (* (/ (cos th) (sqrt 2)) (sqrt (+ (* a1 a1) (* a2 a2)))) |
| 38.0ms | (/ (cos th) (sqrt 2)) |
| 32.0ms | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 24.0ms | (sqrt (+ (* a1 a1) (* a2 a2))) |
| 506.0ms | (* (* (* (/ (cos th) (sqrt 2)) (/ (cos th) (sqrt 2))) (/ (cos th) (sqrt 2))) (* (* (sqrt (+ (* a1 a1) (* a2 a2))) (sqrt (+ (* a1 a1) (* a2 a2)))) (sqrt (+ (* a1 a1) (* a2 a2))))) |
| 254.0ms | (/ (* (* (cos th) (cos th)) (cos th)) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) |
| 189.0ms | (sqrt (+ (* (* a1 a1) (* a1 a1)) (- (* (* a2 a2) (* a2 a2)) (* (* a1 a1) (* a2 a2))))) |
| 168.0ms | (* (sqrt 2) (sqrt (+ (* (* a1 a1) (* a1 a1)) (- (* (* a2 a2) (* a2 a2)) (* (* a1 a1) (* a2 a2)))))) |
| 146.0ms | (sqrt (- (* (* a1 a1) (* a1 a1)) (* (* a2 a2) (* a2 a2)))) |
6 alts after pruning (4 fresh and 2 done)
Merged error: 0b
Found 3 expressions with local error:
| 0.7b | (/ (cos th) (sqrt 2)) |
| 0.4b | (* (/ (cos th) (sqrt 2)) (+ (* a2 a2) (* a1 a1))) |
| 0.0b | (+ (* a2 a2) (* a1 a1)) |
| 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× | add-log-exp |
| 5× | pow1 |
| 3× | associate-/l* |
| 3× | flip-+ |
| 3× | associate-*r* |
| 3× | flip3-+ |
| 3× | associate-/r* |
| 2× | div-inv |
| 2× | cbrt-unprod |
| 2× | associate-*r/ |
| 2× | prod-exp |
| 2× | div-exp |
| 2× | cbrt-undiv |
| 2× | frac-times |
| 1× | *-commutative |
| 1× | associate-*l/ |
| 1× | pow-prod-down |
| 1× | distribute-lft-in |
| 1× | frac-2neg |
| 1× | sum-log |
| 1× | clear-num |
| 1× | +-commutative |
| 1× | distribute-rgt-in |
| 15.0ms | (* (/ (cos th) (sqrt 2)) (+ (* a2 a2) (* a1 a1))) |
| 6.0ms | (/ (cos th) (sqrt 2)) |
| 4.0ms | (+ (* a2 a2) (* a1 a1)) |
| 159.0ms | (* (/ (cos th) (sqrt 2)) (+ (* a2 a2) (* a1 a1))) |
| 34.0ms | (/ (cos th) (sqrt 2)) |
| 26.0ms | (+ (* a2 a2) (* a1 a1)) |
| 396.0ms | (* (cos th) (- (* (* a2 a2) (* a2 a2)) (* (* a1 a1) (* a1 a1)))) |
| 336.0ms | (* (sqrt 2) (- (* a2 a2) (* a1 a1))) |
| 220.0ms | (/ (* (* (cos th) (cos th)) (cos th)) (* (* (sqrt 2) (sqrt 2)) (sqrt 2))) |
| 190.0ms | (+ (* (* a2 a2) (* a2 a2)) (- (* (* a1 a1) (* a1 a1)) (* (* a2 a2) (* a1 a1)))) |
| 180.0ms | (* (* (* (/ (cos th) (sqrt 2)) (/ (cos th) (sqrt 2))) (/ (cos th) (sqrt 2))) (* (* (+ (* a2 a2) (* a1 a1)) (+ (* a2 a2) (* a1 a1))) (+ (* a2 a2) (* a1 a1)))) |
6 alts after pruning (3 fresh and 3 done)
Merged error: 0b
0% (0.4b remaining)
Error of 0.5b against oracle of 0.0b and baseline of 0.5b
| 14144× | (pre true 80) |
| 7907× | (body real 80) |
| 2534× | (body real 1280) |
| 2102× | (body real 640) |
| 1066× | (body real 320) |
| 535× | (body real 160) |