| Alternative 1 | |
|---|---|
| Error | 3.6 |
| Cost | 64960 |
\[R \cdot \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\cos \phi_2 \cdot \cos \phi_1\right) \cdot \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\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
(+
(* (sin phi1) (sin phi2))
(*
(fma
(cos lambda2)
(cos lambda1)
(cbrt (cbrt (pow (pow (* (sin lambda1) (sin lambda2)) 3.0) 3.0))))
(* (cos phi2) (cos phi1)))))
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(((sin(phi1) * sin(phi2)) + (fma(cos(lambda2), cos(lambda1), cbrt(cbrt(pow(pow((sin(lambda1) * sin(lambda2)), 3.0), 3.0)))) * (cos(phi2) * cos(phi1))))) * 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(Float64(Float64(sin(phi1) * sin(phi2)) + Float64(fma(cos(lambda2), cos(lambda1), cbrt(cbrt(((Float64(sin(lambda1) * sin(lambda2)) ^ 3.0) ^ 3.0)))) * Float64(cos(phi2) * cos(phi1))))) * 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[(N[Sin[phi1], $MachinePrecision] * N[Sin[phi2], $MachinePrecision]), $MachinePrecision] + N[(N[(N[Cos[lambda2], $MachinePrecision] * N[Cos[lambda1], $MachinePrecision] + N[Power[N[Power[N[Power[N[Power[N[(N[Sin[lambda1], $MachinePrecision] * N[Sin[lambda2], $MachinePrecision]), $MachinePrecision], 3.0], $MachinePrecision], 3.0], $MachinePrecision], 1/3], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision] * N[(N[Cos[phi2], $MachinePrecision] * N[Cos[phi1], $MachinePrecision]), $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(\sin \phi_1 \cdot \sin \phi_2 + \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sqrt[3]{\sqrt[3]{{\left({\left(\sin \lambda_1 \cdot \sin \lambda_2\right)}^{3}\right)}^{3}}}\right) \cdot \left(\cos \phi_2 \cdot \cos \phi_1\right)\right) \cdot R
Initial program 16.8
Applied egg-rr3.6
Simplified3.6
[Start]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\left(\cos \phi_1 \cdot \cos \phi_2\right) \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2\right) + \left(\cos \phi_1 \cdot \cos \phi_2\right) \cdot \left(\sin \lambda_1 \cdot \sin \lambda_2\right)\right)\right) \cdot R
\] |
|---|---|
distribute-lft-out [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \color{blue}{\left(\cos \phi_1 \cdot \cos \phi_2\right) \cdot \left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)}\right) \cdot R
\] |
+-commutative [<=]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\cos \phi_1 \cdot \cos \phi_2\right) \cdot \color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_1 \cdot \cos \lambda_2\right)}\right) \cdot R
\] |
*-commutative [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \color{blue}{\left(\sin \lambda_1 \cdot \sin \lambda_2 + \cos \lambda_1 \cdot \cos \lambda_2\right) \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)}\right) \cdot R
\] |
+-commutative [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \color{blue}{\left(\cos \lambda_1 \cdot \cos \lambda_2 + \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right) \cdot R
\] |
*-commutative [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\color{blue}{\cos \lambda_2 \cdot \cos \lambda_1} + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right) \cdot R
\] |
cos-neg [<=]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \left(\color{blue}{\cos \left(-\lambda_2\right)} \cdot \cos \lambda_1 + \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right) \cdot R
\] |
fma-def [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \color{blue}{\mathsf{fma}\left(\cos \left(-\lambda_2\right), \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right)} \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right) \cdot R
\] |
cos-neg [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \mathsf{fma}\left(\color{blue}{\cos \lambda_2}, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \left(\cos \phi_1 \cdot \cos \phi_2\right)\right) \cdot R
\] |
*-commutative [=>]3.6 | \[ \cos^{-1} \left(\sin \phi_1 \cdot \sin \phi_2 + \mathsf{fma}\left(\cos \lambda_2, \cos \lambda_1, \sin \lambda_1 \cdot \sin \lambda_2\right) \cdot \color{blue}{\left(\cos \phi_2 \cdot \cos \phi_1\right)}\right) \cdot R
\] |
Applied egg-rr3.6
Applied egg-rr3.6
Final simplification3.6
| Alternative 1 | |
|---|---|
| Error | 3.6 |
| Cost | 64960 |
| Alternative 2 | |
|---|---|
| Error | 3.6 |
| Cost | 58688 |
| Alternative 3 | |
|---|---|
| Error | 10.6 |
| Cost | 52488 |
| Alternative 4 | |
|---|---|
| Error | 10.6 |
| Cost | 52424 |
| Alternative 5 | |
|---|---|
| Error | 15.9 |
| Cost | 52297 |
| Alternative 6 | |
|---|---|
| Error | 15.9 |
| Cost | 52296 |
| Alternative 7 | |
|---|---|
| Error | 15.9 |
| Cost | 46025 |
| Alternative 8 | |
|---|---|
| Error | 23.9 |
| Cost | 39633 |
| Alternative 9 | |
|---|---|
| Error | 23.3 |
| Cost | 39236 |
| Alternative 10 | |
|---|---|
| Error | 23.3 |
| Cost | 39236 |
| Alternative 11 | |
|---|---|
| Error | 16.8 |
| Cost | 39232 |
| Alternative 12 | |
|---|---|
| Error | 32.0 |
| Cost | 32836 |
| Alternative 13 | |
|---|---|
| Error | 39.4 |
| Cost | 32708 |
| Alternative 14 | |
|---|---|
| Error | 40.9 |
| Cost | 32708 |
| Alternative 15 | |
|---|---|
| Error | 36.9 |
| Cost | 32704 |
| Alternative 16 | |
|---|---|
| Error | 40.4 |
| Cost | 26436 |
| Alternative 17 | |
|---|---|
| Error | 50.4 |
| Cost | 26308 |
| Alternative 18 | |
|---|---|
| Error | 49.2 |
| Cost | 26308 |
| Alternative 19 | |
|---|---|
| Error | 46.2 |
| Cost | 26304 |
| Alternative 20 | |
|---|---|
| Error | 53.8 |
| Cost | 19780 |
| Alternative 21 | |
|---|---|
| Error | 51.3 |
| Cost | 19776 |
| Alternative 22 | |
|---|---|
| Error | 52.6 |
| Cost | 13376 |
herbie shell --seed 2023040
(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))