| Alternative 1 | |
|---|---|
| Accuracy | 93.8% |
| Cost | 58688 |
\[R \cdot \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\cos \lambda_2 \cdot \cos \lambda_1 + \sin \lambda_2 \cdot \sin \lambda_1\right) \cdot \left(\cos \phi_2 \cdot \cos \phi_1\right)\right)
\]
(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(*
(acos
(+
(* (sin phi1) (sin phi2))
(* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2)))))
R))(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(*
(acos
(fma
(cos phi2)
(*
(cos phi1)
(fma (sin lambda2) (sin lambda1) (* (cos lambda2) (cos lambda1))))
(* (sin phi1) (sin phi2))))
R))double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return acos(((sin(phi1) * sin(phi2)) + ((cos(phi1) * cos(phi2)) * cos((lambda1 - lambda2))))) * R;
}
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return acos(fma(cos(phi2), (cos(phi1) * fma(sin(lambda2), sin(lambda1), (cos(lambda2) * cos(lambda1)))), (sin(phi1) * sin(phi2)))) * R;
}
function code(R, lambda1, lambda2, phi1, phi2) return Float64(acos(Float64(Float64(sin(phi1) * sin(phi2)) + Float64(Float64(cos(phi1) * cos(phi2)) * cos(Float64(lambda1 - lambda2))))) * R) end
function code(R, lambda1, lambda2, phi1, phi2) return Float64(acos(fma(cos(phi2), Float64(cos(phi1) * fma(sin(lambda2), sin(lambda1), Float64(cos(lambda2) * cos(lambda1)))), Float64(sin(phi1) * sin(phi2)))) * R) end
code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(N[ArcCos[N[(N[(N[Sin[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] + N[(N[(N[Cos[phi1], $MachinePrecision] * N[Cos[phi2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(lambda1 - lambda2), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * R), $MachinePrecision]
code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(N[ArcCos[N[(N[Cos[phi2], $MachinePrecision] * N[(N[Cos[phi1], $MachinePrecision] * N[(N[Sin[lambda2], $MachinePrecision] * N[Sin[lambda1], $MachinePrecision] + N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(N[Sin[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * R), $MachinePrecision]
\cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\cos \phi_1 \cdot \cos \phi_2\right) \cdot \cos \left(\lambda_1 - \lambda_2\right)\right) \cdot R
\cos^{-1} \left(\mathsf{fma}\left(\cos \phi_2, \cos \phi_1 \cdot \mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_2 \cdot \cos \lambda_1\right), \sin \phi_1 \cdot \sin \phi_2\right)\right) \cdot R
Initial program 73.2%
Applied egg-rr93.8%
Taylor expanded in phi1 around 0 93.8%
Simplified93.8%
[Start]93.8 | \[ \cos^{-1} \left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right) + \left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right)\right) \cdot R
\] |
|---|---|
associate-+r+ [=>]93.8 | \[ \cos^{-1} \color{blue}{\left(\left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right) + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right)} \cdot R
\] |
+-commutative [=>]93.8 | \[ \cos^{-1} \left(\color{blue}{\left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1\right)\right) + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right)} + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
*-commutative [=>]93.8 | \[ \cos^{-1} \left(\left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2\right)}\right) + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
associate-*r* [=>]93.8 | \[ \cos^{-1} \left(\left(\color{blue}{\left(\cos \phi_2 \cdot \cos \phi_1\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)} + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
*-commutative [<=]93.8 | \[ \cos^{-1} \left(\left(\color{blue}{\left(\cos \phi_1 \cdot \cos \phi_2\right)} \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right) + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
*-commutative [<=]93.8 | \[ \cos^{-1} \left(\left(\color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)} + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
associate-*r* [<=]93.8 | \[ \cos^{-1} \left(\left(\color{blue}{\sin \lambda_1 \cdot \left(\sin \lambda_2 \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right)} + \cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\cos \lambda_2 \cdot \cos \lambda_1\right)\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
Taylor expanded in phi1 around 0 93.8%
Simplified93.8%
[Start]93.8 | \[ \cos^{-1} \left(\cos \phi_2 \cdot \left(\cos \phi_1 \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1 + \cos \lambda_2 \cdot \cos \lambda_1\right)\right) + \sin \phi_1 \cdot \sin \phi_2\right) \cdot R
\] |
|---|---|
fma-def [=>]93.8 | \[ \cos^{-1} \color{blue}{\left(\mathsf{fma}\left(\cos \phi_2, \cos \phi_1 \cdot \left(\sin \lambda_2 \cdot \sin \lambda_1 + \cos \lambda_2 \cdot \cos \lambda_1\right), \sin \phi_1 \cdot \sin \phi_2\right)\right)} \cdot R
\] |
fma-def [=>]93.8 | \[ \cos^{-1} \left(\mathsf{fma}\left(\cos \phi_2, \cos \phi_1 \cdot \color{blue}{\mathsf{fma}\left(\sin \lambda_2, \sin \lambda_1, \cos \lambda_2 \cdot \cos \lambda_1\right)}, \sin \phi_1 \cdot \sin \phi_2\right)\right) \cdot R
\] |
Final simplification93.8%
| Alternative 1 | |
|---|---|
| Accuracy | 93.8% |
| Cost | 58688 |
| Alternative 2 | |
|---|---|
| Accuracy | 82.9% |
| Cost | 52424 |
| Alternative 3 | |
|---|---|
| Accuracy | 82.7% |
| Cost | 45900 |
| Alternative 4 | |
|---|---|
| Accuracy | 82.7% |
| Cost | 45900 |
| Alternative 5 | |
|---|---|
| Accuracy | 82.7% |
| Cost | 39761 |
| Alternative 6 | |
|---|---|
| Accuracy | 56.5% |
| Cost | 39500 |
| Alternative 7 | |
|---|---|
| Accuracy | 68.7% |
| Cost | 39368 |
| Alternative 8 | |
|---|---|
| Accuracy | 73.2% |
| Cost | 39368 |
| Alternative 9 | |
|---|---|
| Accuracy | 73.4% |
| Cost | 39368 |
| Alternative 10 | |
|---|---|
| Accuracy | 52.3% |
| Cost | 39364 |
| Alternative 11 | |
|---|---|
| Accuracy | 56.1% |
| Cost | 33220 |
| Alternative 12 | |
|---|---|
| Accuracy | 56.0% |
| Cost | 32968 |
| Alternative 13 | |
|---|---|
| Accuracy | 54.4% |
| Cost | 32841 |
| Alternative 14 | |
|---|---|
| Accuracy | 38.6% |
| Cost | 32708 |
| Alternative 15 | |
|---|---|
| Accuracy | 36.6% |
| Cost | 32708 |
| Alternative 16 | |
|---|---|
| Accuracy | 37.2% |
| Cost | 26436 |
| Alternative 17 | |
|---|---|
| Accuracy | 23.1% |
| Cost | 26308 |
| Alternative 18 | |
|---|---|
| Accuracy | 23.3% |
| Cost | 26308 |
| Alternative 19 | |
|---|---|
| Accuracy | 28.0% |
| Cost | 26304 |
| Alternative 20 | |
|---|---|
| Accuracy | 19.0% |
| Cost | 19780 |
| Alternative 21 | |
|---|---|
| Accuracy | 16.6% |
| Cost | 19780 |
| Alternative 22 | |
|---|---|
| Accuracy | 20.4% |
| Cost | 19776 |
| Alternative 23 | |
|---|---|
| Accuracy | 18.4% |
| Cost | 13376 |
herbie shell --seed 2023122
(FPCore (R lambda1 lambda2 phi1 phi2)
:name "Spherical law of cosines"
:precision binary64
(* (acos (+ (* (sin phi1) (sin phi2)) (* (* (cos phi1) (cos phi2)) (cos (- lambda1 lambda2))))) R))