


Bits error versus R



Bits error versus lambda1



Bits error versus lambda2



Bits error versus phi1



Bits error versus phi2
Results
Initial program 16.6
rmApplied cos-diff4.1
rmApplied add-log-exp4.1
Final simplification4.1
herbie shell --seed 2019004
(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: 45.9s)Debug log
1 calls. Slowest were:
| 21.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: 17.9b
Found 4 expressions with local error:
| 4.6b | (cos (- lambda1 lambda2)) |
| 0.5b | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) |
| 0.3b | (* (sin phi1) (sin phi2)) |
| 0.2b | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R) |
4 calls. Slowest were:
| 4.0ms | (* (sin phi1) (sin phi2)) |
| 4.0ms | (cos (- lambda1 lambda2)) |
| 3.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R) |
4 calls. Slowest were:
| 69.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R) |
| 68.0ms | (* (sin phi1) (sin phi2)) |
| 22.0ms | (cos (- lambda1 lambda2)) |
| 15.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) |
26 calls. Slowest were:
| 60.0ms | (- (+ 1 (* lambda2 lambda1)) (* 1/2 (pow lambda1 2))) |
| 59.0ms | (* (* (* (sin phi1) (sin phi1)) (sin phi1)) (* (* (sin phi2) (sin phi2)) (sin phi2))) |
| 29.0ms | (acos (+ (* (cos phi1) (* (cos (- lambda1 lambda2)) (cos phi2))) (* (sin phi1) (sin phi2)))) |
15 alts after pruning (15 fresh and 0 done)
Merged error: 2.0b
Found 4 expressions with local error:
| 0.5b | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 0.3b | (* (sin phi1) (sin phi2)) |
| 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)))) |
4 calls. Slowest were:
| 23.0ms | (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) |
| 5.0ms | (* (sin phi1) (sin phi2)) |
| 2.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
4 calls. Slowest were:
| 244.0ms | (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))) |
| 79.0ms | (* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 70.0ms | (* (sin phi1) (sin phi2)) |
| 27.0ms | (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
45 calls. Slowest were:
| 330.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))))) |
| 279.0ms | (* (+ (cos (+ phi1 phi2)) (cos (- phi1 phi2))) (+ (* (+ (cos (+ lambda1 lambda2)) (cos (- lambda1 lambda2))) 2) (* 2 (- (cos (- lambda1 lambda2)) (cos (+ lambda1 lambda2)))))) |
| 238.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)))))) |
18 alts after pruning (18 fresh and 0 done)
Merged error: 1.9b
Found 4 expressions with local error:
| 0.6b | (pow (* (cos lambda1) (cos lambda2)) 3) |
| 0.5b | (acos (+ (* (sin phi1) (sin phi2)) (/ (* (* (cos phi1) (cos phi2)) (+ (pow (* (cos lambda1) (cos lambda2)) 3) (pow (* (sin lambda1) (sin lambda2)) 3))) (+ (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (- (* (sin lambda2) (sin lambda1)) (* (cos lambda2) (cos lambda1))) (* (sin lambda2) (sin lambda1))))))) |
| 0.4b | (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) |
| 0.3b | (pow (* (sin lambda1) (sin lambda2)) 3) |
4 calls. Slowest were:
| 25.0ms | (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) |
| 7.0ms | (pow (* (cos lambda1) (cos lambda2)) 3) |
| 3.0ms | (pow (* (sin lambda1) (sin lambda2)) 3) |
4 calls. Slowest were:
| 93.0ms | (pow (* (sin lambda1) (sin lambda2)) 3) |
| 86.0ms | (acos (+ (* (sin phi1) (sin phi2)) (/ (* (* (cos phi1) (cos phi2)) (+ (pow (* (cos lambda1) (cos lambda2)) 3) (pow (* (sin lambda1) (sin lambda2)) 3))) (+ (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (- (* (sin lambda2) (sin lambda1)) (* (cos lambda2) (cos lambda1))) (* (sin lambda2) (sin lambda1))))))) |
| 59.0ms | (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) |
| 56.0ms | (pow (* (cos lambda1) (cos lambda2)) 3) |
57 calls. Slowest were:
| 926.0ms | (* (* (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (cos lambda2) (cos lambda1))) (* (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (cos lambda2) (cos lambda1)))) |
| 589.0ms | (* (* (* (* (cos lambda2) (cos lambda2)) (cos lambda2)) (* (* (cos lambda1) (cos lambda1)) (cos lambda1))) (* (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (cos lambda2) (cos lambda1)))) |
| 552.0ms | (* (* (* (* (cos lambda2) (cos lambda1)) (* (cos lambda2) (cos lambda1))) (* (cos lambda2) (cos lambda1))) (* (* (* (cos lambda2) (cos lambda2)) (cos lambda2)) (* (* (cos lambda1) (cos lambda1)) (cos lambda1)))) |
17 alts after pruning (17 fresh and 0 done)
Merged error: 1.9b
Found 4 expressions with local error:
| 3.3b | (log (exp (* (sin phi1) (sin phi2)))) |
| 0.5b | (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
| 0.3b | (* (sin phi1) (sin phi2)) |
| 0.2b | (* (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
4 calls. Slowest were:
| 4.0ms | (* (sin phi1) (sin phi2)) |
| 2.0ms | (* (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 2.0ms | (log (exp (* (sin phi1) (sin phi2)))) |
4 calls. Slowest were:
| 96.0ms | (* (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) R) |
| 50.0ms | (* (sin phi1) (sin phi2)) |
| 47.0ms | (log (exp (* (sin phi1) (sin phi2)))) |
| 15.0ms | (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))) |
29 calls. Slowest were:
| 218.0ms | (sqrt (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2))))))) |
| 191.0ms | (* (cbrt (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2))))))) (cbrt (acos (+ (log (exp (* (sin phi1) (sin phi2)))) (* (* (cos phi1) (cos phi2)) (+ (* (cos lambda1) (cos lambda2)) (* (sin lambda1) (sin lambda2)))))))) |
| 133.0ms | (* (acos (+ (* (cos phi1) (* (cos phi2) (* (cos lambda1) (cos lambda2)))) (+ (* (cos phi1) (* (cos phi2) (* (sin lambda2) (sin lambda1)))) (* (sin phi1) (sin phi2))))) R) |
18 alts after pruning (18 fresh and 0 done)
Merged error: 1.8b
0% (0.3b remaining)
Error of 4.1b against oracle of 3.7b and baseline of 4.1b