


Bits error versus R



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Results
Initial program 17.0
rmApplied cos-diff4.0
rmApplied distribute-rgt-in4.0
rmApplied add-log-exp4.0
Final simplification4.0
herbie shell --seed 2019022
(FPCore (R lambda1 lambda2 phi1 phi2)
:name "Spherical law of cosines"
(* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R))
Time bar (total: 47.9s)Debug log
| 733.0ms | 154× | body | 1280 | valid |
| 91.0ms | 65× | body | 640 | valid |
| 19.0ms | 18× | body | 320 | valid |
| 6.0ms | 10× | body | 160 | valid |
| 3.0ms | 9× | body | 80 | valid |
| 25.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R) |
1 alts after pruning (1 fresh and 0 done)
Merged error: 15.5b
Found 4 expressions with local error:
| 4.2b | (cos (- lambda1 lambda2)) |
| 0.6b | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) |
| 0.2b | (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))) |
| 0.2b | (* (sin phi1) (sin phi2)) |
| 11× | add-exp-log |
| 11× | add-cbrt-cube |
| 11× | pow1 |
| 7× | add-cube-cbrt |
| 7× | *-un-lft-identity |
| 7× | add-sqr-sqrt |
| 6× | associate-*r* |
| 4× | add-log-exp |
| 4× | cbrt-unprod |
| 4× | prod-exp |
| 4× | pow-prod-down |
| 4× | associate-*l* |
| 3× | cos-diff |
| 2× | *-commutative |
| 2× | cos-sum |
| 1× | sin-mult |
| 1× | cos-mult |
| 1× | associate-*l/ |
| 1× | distribute-lft-in |
| 1× | sub-neg |
| 1× | acos-asin |
| 1× | distribute-rgt-in |
| 11.0ms | (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))) |
| 4.0ms | (cos (- lambda1 lambda2)) |
| 3.0ms | (* (sin phi1) (sin phi2)) |
| 1.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) |
| 104.0ms | (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))) |
| 52.0ms | (* (sin phi1) (sin phi2)) |
| 23.0ms | (cos (- lambda1 lambda2)) |
| 11.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) |
| 216.0ms | (* (* (* (* (cos phi1) (cos phi2)) (* (cos phi1) (cos phi2))) (* (cos phi1) (cos phi2))) (* (* (cos (- lambda1 lambda2)) (cos (- lambda1 lambda2))) (cos (- lambda1 lambda2)))) |
| 213.0ms | (* (* (* (* (cos phi1) (cos phi1)) (cos phi1)) (* (* (cos phi2) (cos phi2)) (cos phi2))) (* (* (cos (- lambda1 lambda2)) (cos (- lambda1 lambda2))) (cos (- lambda1 lambda2)))) |
| 140.0ms | (- 1 (+ (* 1/2 (pow phi2 2)) (* 1/2 (pow phi1 2)))) |
| 91.0ms | (* (* (* (sin phi1) (sin phi1)) (sin phi1)) (* (* (sin phi2) (sin phi2)) (sin phi2))) |
| 49.0ms | (- (+ 1 (* lambda2 lambda1)) (* 1/2 (pow lambda1 2))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 2.3b
Found 4 expressions with local error:
| 0.6b | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 0.2b | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 0.2b | (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) |
| 0.2b | (* (sin phi1) (sin phi2)) |
| 11× | add-exp-log |
| 11× | add-cbrt-cube |
| 11× | pow1 |
| 8× | add-cube-cbrt |
| 8× | *-un-lft-identity |
| 8× | add-sqr-sqrt |
| 7× | associate-*l* |
| 6× | cos-mult |
| 6× | associate-*r* |
| 4× | add-log-exp |
| 4× | cbrt-unprod |
| 4× | prod-exp |
| 4× | pow-prod-down |
| 3× | sin-mult |
| 3× | *-commutative |
| 3× | associate-*r/ |
| 3× | frac-times |
| 2× | flip-+ |
| 2× | frac-add |
| 2× | flip3-+ |
| 1× | associate-*l/ |
| 1× | distribute-lft-in |
| 1× | acos-asin |
| 1× | distribute-rgt-in |
| 36.0ms | (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) |
| 7.0ms | (* (sin phi1) (sin phi2)) |
| 5.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 2.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 236.0ms | (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) |
| 106.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 68.0ms | (* (sin phi1) (sin phi2)) |
| 28.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 369.0ms | (* (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2))) (+ (* (+ (cos (+ lambda1 lambda2)) (cos (- lambda1 lambda2))) 2) (* 2 (- (cos (- lambda1 lambda2)) (cos (+ lambda1 lambda2)))))) |
| 368.0ms | (+ (* (* (cos lambda1) (cos lambda2)) (* (cos lambda1) (cos lambda2))) (- (* (* (sin lambda1) (sin lambda2)) (* (sin lambda1) (sin lambda2))) (* (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2))))) |
| 251.0ms | (* 2 (+ (* (* (cos lambda1) (cos lambda2)) (* (cos lambda1) (cos lambda2))) (- (* (* (sin lambda1) (sin lambda2)) (* (sin lambda1) (sin lambda2))) (* (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 244.0ms | (* (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2))) (- (* (* (cos lambda1) (cos lambda2)) (* (cos lambda1) (cos lambda2))) (* (* (sin lambda1) (sin lambda2)) (* (sin lambda1) (sin lambda2))))) |
| 187.0ms | (* (* (* (* (cos phi1) (cos phi1)) (cos phi1)) (* (* (cos phi2) (cos phi2)) (cos phi2))) (* (* (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2))) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2))))) |
16 alts after pruning (16 fresh and 0 done)
Merged error: 2.2b
Found 4 expressions with local error:
| 0.6b | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 0.3b | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 0.2b | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 0.2b | (* (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) R) |
| 28× | add-exp-log |
| 28× | add-cbrt-cube |
| 28× | pow1 |
| 16× | cbrt-unprod |
| 16× | prod-exp |
| 16× | pow-prod-down |
| 6× | cos-mult |
| 5× | add-cube-cbrt |
| 5× | associate-*l* |
| 5× | *-un-lft-identity |
| 5× | add-sqr-sqrt |
| 4× | add-log-exp |
| 3× | *-commutative |
| 2× | sin-mult |
| 2× | associate-*r/ |
| 2× | associate-*l/ |
| 2× | associate-*r* |
| 2× | frac-times |
| 1× | acos-asin |
| 33.0ms | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 29.0ms | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 4.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) R) |
| 2.0ms | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 149.0ms | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 147.0ms | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 108.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) R) |
| 27.0ms | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 670.0ms | (* (* (* (* (cos lambda1) (cos lambda2)) (* (cos lambda1) (cos lambda2))) (* (cos lambda1) (cos lambda2))) (* (* (* (cos phi1) (cos phi2)) (* (cos phi1) (cos phi2))) (* (cos phi1) (cos phi2)))) |
| 612.0ms | (* (* (* (* (sin lambda1) (sin lambda2)) (* (sin lambda1) (sin lambda2))) (* (sin lambda1) (sin lambda2))) (* (* (* (cos phi1) (cos phi2)) (* (cos phi1) (cos phi2))) (* (cos phi1) (cos phi2)))) |
| 138.0ms | (* R (acos (+ (* (cos phi1) (* (cos phi2) (* (sin lambda1) (sin lambda2)))) (+ (* (cos phi1) (* (cos phi2) (* (cos lambda1) (cos lambda2)))) (* (sin phi1) (sin phi2)))))) |
| 137.0ms | (* (+ (cos (+ lambda1 lambda2)) (cos (- lambda1 lambda2))) (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2)))) |
| 134.0ms | (* (- (cos (- lambda1 lambda2)) (cos (+ lambda1 lambda2))) (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2)))) |
15 alts after pruning (15 fresh and 0 done)
Merged error: 2.1b
Found 4 expressions with local error:
| 0.7b | (log (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))))))) |
| 0.6b | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 0.3b | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 0.2b | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 29× | add-exp-log |
| 29× | pow1 |
| 28× | add-cbrt-cube |
| 16× | cbrt-unprod |
| 16× | prod-exp |
| 16× | pow-prod-down |
| 6× | cos-mult |
| 5× | add-cube-cbrt |
| 5× | *-un-lft-identity |
| 5× | add-sqr-sqrt |
| 4× | add-log-exp |
| 3× | log-prod |
| 2× | sin-mult |
| 2× | *-commutative |
| 2× | associate-*r/ |
| 2× | associate-*l/ |
| 2× | associate-*l* |
| 2× | associate-*r* |
| 2× | frac-times |
| 1× | log-pow |
| 1× | rem-log-exp |
| 1× | acos-asin |
| 15.0ms | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 13.0ms | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 1.0ms | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 1.0ms | (log (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))))))) |
| 124.0ms | (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) |
| 112.0ms | (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))) |
| 50.0ms | (log (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))))))) |
| 15.0ms | (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2)))))) |
| 670.0ms | (* (* (* (* (sin lambda1) (sin lambda2)) (* (sin lambda1) (sin lambda2))) (* (sin lambda1) (sin lambda2))) (* (* (* (cos phi1) (cos phi2)) (* (cos phi1) (cos phi2))) (* (cos phi1) (cos phi2)))) |
| 572.0ms | (* (* (* (* (cos lambda1) (cos lambda2)) (* (cos lambda1) (cos lambda2))) (* (cos lambda1) (cos lambda2))) (* (* (* (cos phi1) (cos phi2)) (* (cos phi1) (cos phi2))) (* (cos phi1) (cos phi2)))) |
| 132.0ms | (* (- (cos (- lambda1 lambda2)) (cos (+ lambda1 lambda2))) (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2)))) |
| 120.0ms | (log (* (cbrt (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))))))) (cbrt (acos (+ (* (sin phi1) (sin phi2)) (+ (* (* (cos lambda1) (cos lambda2)) (* (cos phi1) (cos phi2))) (* (* (sin lambda1) (sin lambda2)) (* (cos phi1) (cos phi2))))))))) |
| 118.0ms | (log (acos (+ (* (cos phi1) (* (cos phi2) (* (sin lambda1) (sin lambda2)))) (+ (* (cos phi1) (* (cos phi2) (* (cos lambda1) (cos lambda2)))) (* (sin phi1) (sin phi2)))))) |
13 alts after pruning (13 fresh and 0 done)
Merged error: 2.1b
0% (0.3b remaining)
Error of 4.0b against oracle of 3.7b and baseline of 4.0b
| 17.6s | 4739× | body | 1280 | valid |
| 4.8s | 2083× | body | 640 | valid |
| 897.0ms | 731× | body | 320 | valid |
| 257.0ms | 294× | body | 160 | valid |
| 79.0ms | 147× | body | 80 | valid |
| 44.0ms | 8× | body | 2560 | valid |