
(FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (let* ((t_0 (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))))) (* R (sqrt (+ (* t_0 t_0) (* (- phi1 phi2) (- phi1 phi2)))))))
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0));
return R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0d0))
code = r * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
end function
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * Math.cos(((phi1 + phi2) / 2.0));
return R * Math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
def code(R, lambda1, lambda2, phi1, phi2): t_0 = (lambda1 - lambda2) * math.cos(((phi1 + phi2) / 2.0)) return R * math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
function code(R, lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi1 + phi2) / 2.0))) return Float64(R * sqrt(Float64(Float64(t_0 * t_0) + Float64(Float64(phi1 - phi2) * Float64(phi1 - phi2))))) end
function tmp = code(R, lambda1, lambda2, phi1, phi2) t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0)); tmp = R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2)))); end
code[R_, lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi1 + phi2), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(R * N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] + N[(N[(phi1 - phi2), $MachinePrecision] * N[(phi1 - phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\\
R \cdot \sqrt{t\_0 \cdot t\_0 + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 14 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (let* ((t_0 (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))))) (* R (sqrt (+ (* t_0 t_0) (* (- phi1 phi2) (- phi1 phi2)))))))
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0));
return R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0d0))
code = r * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
end function
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = (lambda1 - lambda2) * Math.cos(((phi1 + phi2) / 2.0));
return R * Math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))));
}
def code(R, lambda1, lambda2, phi1, phi2): t_0 = (lambda1 - lambda2) * math.cos(((phi1 + phi2) / 2.0)) return R * math.sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2))))
function code(R, lambda1, lambda2, phi1, phi2) t_0 = Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi1 + phi2) / 2.0))) return Float64(R * sqrt(Float64(Float64(t_0 * t_0) + Float64(Float64(phi1 - phi2) * Float64(phi1 - phi2))))) end
function tmp = code(R, lambda1, lambda2, phi1, phi2) t_0 = (lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0)); tmp = R * sqrt(((t_0 * t_0) + ((phi1 - phi2) * (phi1 - phi2)))); end
code[R_, lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi1 + phi2), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(R * N[Sqrt[N[(N[(t$95$0 * t$95$0), $MachinePrecision] + N[(N[(phi1 - phi2), $MachinePrecision] * N[(phi1 - phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right)\\
R \cdot \sqrt{t\_0 \cdot t\_0 + \left(\phi_1 - \phi_2\right) \cdot \left(\phi_1 - \phi_2\right)}
\end{array}
\end{array}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= phi2 1.04e+33) (* R (hypot (* (- lambda1 lambda2) (cos (* phi1 0.5))) (- phi1 phi2))) (* R (hypot (* (- lambda1 lambda2) (cos (* phi2 0.5))) (- phi1 phi2)))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 1.04e+33) {
tmp = R * hypot(((lambda1 - lambda2) * cos((phi1 * 0.5))), (phi1 - phi2));
} else {
tmp = R * hypot(((lambda1 - lambda2) * cos((phi2 * 0.5))), (phi1 - phi2));
}
return tmp;
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 1.04e+33) {
tmp = R * Math.hypot(((lambda1 - lambda2) * Math.cos((phi1 * 0.5))), (phi1 - phi2));
} else {
tmp = R * Math.hypot(((lambda1 - lambda2) * Math.cos((phi2 * 0.5))), (phi1 - phi2));
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi2 <= 1.04e+33: tmp = R * math.hypot(((lambda1 - lambda2) * math.cos((phi1 * 0.5))), (phi1 - phi2)) else: tmp = R * math.hypot(((lambda1 - lambda2) * math.cos((phi2 * 0.5))), (phi1 - phi2)) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= 1.04e+33) tmp = Float64(R * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(phi1 * 0.5))), Float64(phi1 - phi2))); else tmp = Float64(R * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(phi2 * 0.5))), Float64(phi1 - phi2))); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi2 <= 1.04e+33)
tmp = R * hypot(((lambda1 - lambda2) * cos((phi1 * 0.5))), (phi1 - phi2));
else
tmp = R * hypot(((lambda1 - lambda2) * cos((phi2 * 0.5))), (phi1 - phi2));
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi2, 1.04e+33], N[(R * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(phi1 * 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], N[(R * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(phi2 * 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_2 \leq 1.04 \cdot 10^{+33}:\\
\;\;\;\;R \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\phi_1 \cdot 0.5\right), \phi_1 - \phi_2\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\phi_2 \cdot 0.5\right), \phi_1 - \phi_2\right)\\
\end{array}
\end{array}
if phi2 < 1.0400000000000001e33Initial program 66.2%
hypot-define98.3%
Simplified98.3%
Taylor expanded in phi2 around 0 96.3%
if 1.0400000000000001e33 < phi2 Initial program 54.3%
hypot-define89.1%
Simplified89.1%
Taylor expanded in phi1 around 0 89.4%
Final simplification94.8%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (* R (hypot (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))) (- phi1 phi2))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * hypot(((lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0))), (phi1 - phi2));
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * Math.hypot(((lambda1 - lambda2) * Math.cos(((phi1 + phi2) / 2.0))), (phi1 - phi2));
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): return R * math.hypot(((lambda1 - lambda2) * math.cos(((phi1 + phi2) / 2.0))), (phi1 - phi2))
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) return Float64(R * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(Float64(phi1 + phi2) / 2.0))), Float64(phi1 - phi2))) end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp = code(R, lambda1, lambda2, phi1, phi2)
tmp = R * hypot(((lambda1 - lambda2) * cos(((phi1 + phi2) / 2.0))), (phi1 - phi2));
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(R * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(N[(phi1 + phi2), $MachinePrecision] / 2.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
R \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\frac{\phi_1 + \phi_2}{2}\right), \phi_1 - \phi_2\right)
\end{array}
Initial program 63.6%
hypot-define96.3%
Simplified96.3%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (* R (hypot (* (- lambda1 lambda2) (cos (* phi1 0.5))) (- phi1 phi2))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * hypot(((lambda1 - lambda2) * cos((phi1 * 0.5))), (phi1 - phi2));
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * Math.hypot(((lambda1 - lambda2) * Math.cos((phi1 * 0.5))), (phi1 - phi2));
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): return R * math.hypot(((lambda1 - lambda2) * math.cos((phi1 * 0.5))), (phi1 - phi2))
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) return Float64(R * hypot(Float64(Float64(lambda1 - lambda2) * cos(Float64(phi1 * 0.5))), Float64(phi1 - phi2))) end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp = code(R, lambda1, lambda2, phi1, phi2)
tmp = R * hypot(((lambda1 - lambda2) * cos((phi1 * 0.5))), (phi1 - phi2));
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(R * N[Sqrt[N[(N[(lambda1 - lambda2), $MachinePrecision] * N[Cos[N[(phi1 * 0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
R \cdot \mathsf{hypot}\left(\left(\lambda_1 - \lambda_2\right) \cdot \cos \left(\phi_1 \cdot 0.5\right), \phi_1 - \phi_2\right)
\end{array}
Initial program 63.6%
hypot-define96.3%
Simplified96.3%
Taylor expanded in phi2 around 0 93.5%
Final simplification93.5%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= phi1 -2.2e-28)
(* R (- phi2 phi1))
(if (<= phi1 -2.7e-304)
(* R (* lambda1 (+ -1.0 (/ lambda2 lambda1))))
(* R (hypot phi2 lambda1)))))assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -2.2e-28) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= -2.7e-304) {
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
} else {
tmp = R * hypot(phi2, lambda1);
}
return tmp;
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -2.2e-28) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= -2.7e-304) {
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
} else {
tmp = R * Math.hypot(phi2, lambda1);
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -2.2e-28: tmp = R * (phi2 - phi1) elif phi1 <= -2.7e-304: tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1))) else: tmp = R * math.hypot(phi2, lambda1) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -2.2e-28) tmp = Float64(R * Float64(phi2 - phi1)); elseif (phi1 <= -2.7e-304) tmp = Float64(R * Float64(lambda1 * Float64(-1.0 + Float64(lambda2 / lambda1)))); else tmp = Float64(R * hypot(phi2, lambda1)); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi1 <= -2.2e-28)
tmp = R * (phi2 - phi1);
elseif (phi1 <= -2.7e-304)
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
else
tmp = R * hypot(phi2, lambda1);
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi1, -2.2e-28], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision], If[LessEqual[phi1, -2.7e-304], N[(R * N[(lambda1 * N[(-1.0 + N[(lambda2 / lambda1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(R * N[Sqrt[phi2 ^ 2 + lambda1 ^ 2], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -2.2 \cdot 10^{-28}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\mathbf{elif}\;\phi_1 \leq -2.7 \cdot 10^{-304}:\\
\;\;\;\;R \cdot \left(\lambda_1 \cdot \left(-1 + \frac{\lambda_2}{\lambda_1}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \mathsf{hypot}\left(\phi_2, \lambda_1\right)\\
\end{array}
\end{array}
if phi1 < -2.19999999999999996e-28Initial program 52.5%
hypot-define95.2%
Simplified95.2%
Taylor expanded in phi1 around -inf 64.1%
associate-*r*64.1%
mul-1-neg64.1%
associate-*r/64.1%
mul-1-neg64.1%
*-commutative64.1%
Simplified64.1%
Taylor expanded in phi1 around 0 64.1%
+-commutative64.1%
mul-1-neg64.1%
unsub-neg64.1%
Simplified64.1%
Taylor expanded in R around 0 70.1%
if -2.19999999999999996e-28 < phi1 < -2.7000000000000001e-304Initial program 72.5%
hypot-define99.9%
Simplified99.9%
Taylor expanded in phi2 around 0 94.7%
expm1-log1p-u94.7%
expm1-undefine94.7%
*-commutative94.7%
Applied egg-rr94.7%
expm1-define94.7%
Simplified94.7%
Taylor expanded in phi1 around 0 68.2%
+-commutative68.2%
unpow268.2%
unpow268.2%
hypot-define91.6%
Simplified91.6%
Taylor expanded in lambda1 around -inf 37.6%
associate-*r*37.6%
mul-1-neg37.6%
associate-*r/37.6%
neg-mul-137.6%
Simplified37.6%
if -2.7000000000000001e-304 < phi1 Initial program 67.2%
hypot-define95.2%
Simplified95.2%
Taylor expanded in phi2 around 0 91.5%
expm1-log1p-u84.7%
expm1-undefine84.6%
*-commutative84.6%
Applied egg-rr84.6%
expm1-define84.7%
Simplified84.7%
Taylor expanded in phi1 around 0 50.2%
+-commutative50.2%
unpow250.2%
unpow250.2%
hypot-define66.2%
Simplified66.2%
Taylor expanded in lambda2 around 0 32.8%
+-commutative32.8%
unpow232.8%
unpow232.8%
hypot-define43.6%
Simplified43.6%
Final simplification50.9%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= phi1 -2.8e+21) (* R (- phi2 phi1)) (* R (hypot phi2 (- lambda1 lambda2)))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -2.8e+21) {
tmp = R * (phi2 - phi1);
} else {
tmp = R * hypot(phi2, (lambda1 - lambda2));
}
return tmp;
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -2.8e+21) {
tmp = R * (phi2 - phi1);
} else {
tmp = R * Math.hypot(phi2, (lambda1 - lambda2));
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -2.8e+21: tmp = R * (phi2 - phi1) else: tmp = R * math.hypot(phi2, (lambda1 - lambda2)) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -2.8e+21) tmp = Float64(R * Float64(phi2 - phi1)); else tmp = Float64(R * hypot(phi2, Float64(lambda1 - lambda2))); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi1 <= -2.8e+21)
tmp = R * (phi2 - phi1);
else
tmp = R * hypot(phi2, (lambda1 - lambda2));
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi1, -2.8e+21], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision], N[(R * N[Sqrt[phi2 ^ 2 + N[(lambda1 - lambda2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -2.8 \cdot 10^{+21}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \mathsf{hypot}\left(\phi_2, \lambda_1 - \lambda_2\right)\\
\end{array}
\end{array}
if phi1 < -2.8e21Initial program 52.6%
hypot-define95.9%
Simplified95.9%
Taylor expanded in phi1 around -inf 63.8%
associate-*r*63.8%
mul-1-neg63.8%
associate-*r/63.8%
mul-1-neg63.8%
*-commutative63.8%
Simplified63.8%
Taylor expanded in phi1 around 0 63.8%
+-commutative63.8%
mul-1-neg63.8%
unsub-neg63.8%
Simplified63.8%
Taylor expanded in R around 0 70.3%
if -2.8e21 < phi1 Initial program 68.5%
hypot-define96.5%
Simplified96.5%
Taylor expanded in phi2 around 0 92.4%
Taylor expanded in phi1 around 0 55.7%
unpow255.7%
unpow255.7%
hypot-define74.8%
Simplified74.8%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= phi2 1.45e+55) (* R (hypot phi1 (- lambda1 lambda2))) (* R (- phi2 phi1))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 1.45e+55) {
tmp = R * hypot(phi1, (lambda1 - lambda2));
} else {
tmp = R * (phi2 - phi1);
}
return tmp;
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 1.45e+55) {
tmp = R * Math.hypot(phi1, (lambda1 - lambda2));
} else {
tmp = R * (phi2 - phi1);
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi2 <= 1.45e+55: tmp = R * math.hypot(phi1, (lambda1 - lambda2)) else: tmp = R * (phi2 - phi1) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= 1.45e+55) tmp = Float64(R * hypot(phi1, Float64(lambda1 - lambda2))); else tmp = Float64(R * Float64(phi2 - phi1)); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi2 <= 1.45e+55)
tmp = R * hypot(phi1, (lambda1 - lambda2));
else
tmp = R * (phi2 - phi1);
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi2, 1.45e+55], N[(R * N[Sqrt[phi1 ^ 2 + N[(lambda1 - lambda2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_2 \leq 1.45 \cdot 10^{+55}:\\
\;\;\;\;R \cdot \mathsf{hypot}\left(\phi_1, \lambda_1 - \lambda_2\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\end{array}
\end{array}
if phi2 < 1.4499999999999999e55Initial program 66.6%
hypot-define98.3%
Simplified98.3%
Taylor expanded in phi1 around 0 86.7%
Taylor expanded in phi2 around 0 58.3%
unpow258.3%
unpow258.3%
hypot-define75.3%
Simplified75.3%
if 1.4499999999999999e55 < phi2 Initial program 52.7%
hypot-define88.7%
Simplified88.7%
Taylor expanded in phi1 around -inf 74.4%
associate-*r*74.4%
mul-1-neg74.4%
associate-*r/74.4%
mul-1-neg74.4%
*-commutative74.4%
Simplified74.4%
Taylor expanded in phi1 around 0 67.6%
+-commutative67.6%
mul-1-neg67.6%
unsub-neg67.6%
Simplified67.6%
Taylor expanded in R around 0 69.4%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (* R (hypot (- lambda1 lambda2) (- phi1 phi2))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * hypot((lambda1 - lambda2), (phi1 - phi2));
}
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * Math.hypot((lambda1 - lambda2), (phi1 - phi2));
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): return R * math.hypot((lambda1 - lambda2), (phi1 - phi2))
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) return Float64(R * hypot(Float64(lambda1 - lambda2), Float64(phi1 - phi2))) end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp = code(R, lambda1, lambda2, phi1, phi2)
tmp = R * hypot((lambda1 - lambda2), (phi1 - phi2));
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(R * N[Sqrt[N[(lambda1 - lambda2), $MachinePrecision] ^ 2 + N[(phi1 - phi2), $MachinePrecision] ^ 2], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
R \cdot \mathsf{hypot}\left(\lambda_1 - \lambda_2, \phi_1 - \phi_2\right)
\end{array}
Initial program 63.6%
hypot-define96.3%
Simplified96.3%
Taylor expanded in phi2 around 0 93.5%
Taylor expanded in phi1 around 0 89.1%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(let* ((t_0 (* R (- lambda1))))
(if (<= phi1 -4.3e+24)
(* R (- phi1))
(if (<= phi1 -1.4e-159)
t_0
(if (<= phi1 -1.85e-202)
(* R lambda2)
(if (<= phi1 -4.6e-269) t_0 (* R phi2)))))))assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = R * -lambda1;
double tmp;
if (phi1 <= -4.3e+24) {
tmp = R * -phi1;
} else if (phi1 <= -1.4e-159) {
tmp = t_0;
} else if (phi1 <= -1.85e-202) {
tmp = R * lambda2;
} else if (phi1 <= -4.6e-269) {
tmp = t_0;
} else {
tmp = R * phi2;
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: t_0
real(8) :: tmp
t_0 = r * -lambda1
if (phi1 <= (-4.3d+24)) then
tmp = r * -phi1
else if (phi1 <= (-1.4d-159)) then
tmp = t_0
else if (phi1 <= (-1.85d-202)) then
tmp = r * lambda2
else if (phi1 <= (-4.6d-269)) then
tmp = t_0
else
tmp = r * phi2
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double t_0 = R * -lambda1;
double tmp;
if (phi1 <= -4.3e+24) {
tmp = R * -phi1;
} else if (phi1 <= -1.4e-159) {
tmp = t_0;
} else if (phi1 <= -1.85e-202) {
tmp = R * lambda2;
} else if (phi1 <= -4.6e-269) {
tmp = t_0;
} else {
tmp = R * phi2;
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): t_0 = R * -lambda1 tmp = 0 if phi1 <= -4.3e+24: tmp = R * -phi1 elif phi1 <= -1.4e-159: tmp = t_0 elif phi1 <= -1.85e-202: tmp = R * lambda2 elif phi1 <= -4.6e-269: tmp = t_0 else: tmp = R * phi2 return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) t_0 = Float64(R * Float64(-lambda1)) tmp = 0.0 if (phi1 <= -4.3e+24) tmp = Float64(R * Float64(-phi1)); elseif (phi1 <= -1.4e-159) tmp = t_0; elseif (phi1 <= -1.85e-202) tmp = Float64(R * lambda2); elseif (phi1 <= -4.6e-269) tmp = t_0; else tmp = Float64(R * phi2); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
t_0 = R * -lambda1;
tmp = 0.0;
if (phi1 <= -4.3e+24)
tmp = R * -phi1;
elseif (phi1 <= -1.4e-159)
tmp = t_0;
elseif (phi1 <= -1.85e-202)
tmp = R * lambda2;
elseif (phi1 <= -4.6e-269)
tmp = t_0;
else
tmp = R * phi2;
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
code[R_, lambda1_, lambda2_, phi1_, phi2_] := Block[{t$95$0 = N[(R * (-lambda1)), $MachinePrecision]}, If[LessEqual[phi1, -4.3e+24], N[(R * (-phi1)), $MachinePrecision], If[LessEqual[phi1, -1.4e-159], t$95$0, If[LessEqual[phi1, -1.85e-202], N[(R * lambda2), $MachinePrecision], If[LessEqual[phi1, -4.6e-269], t$95$0, N[(R * phi2), $MachinePrecision]]]]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
t_0 := R \cdot \left(-\lambda_1\right)\\
\mathbf{if}\;\phi_1 \leq -4.3 \cdot 10^{+24}:\\
\;\;\;\;R \cdot \left(-\phi_1\right)\\
\mathbf{elif}\;\phi_1 \leq -1.4 \cdot 10^{-159}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;\phi_1 \leq -1.85 \cdot 10^{-202}:\\
\;\;\;\;R \cdot \lambda_2\\
\mathbf{elif}\;\phi_1 \leq -4.6 \cdot 10^{-269}:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;R \cdot \phi_2\\
\end{array}
\end{array}
if phi1 < -4.29999999999999987e24Initial program 52.6%
hypot-define95.9%
Simplified95.9%
Taylor expanded in phi1 around -inf 67.6%
mul-1-neg67.6%
Simplified67.6%
if -4.29999999999999987e24 < phi1 < -1.4000000000000001e-159 or -1.84999999999999995e-202 < phi1 < -4.5999999999999999e-269Initial program 61.7%
hypot-define98.1%
Simplified98.1%
Taylor expanded in phi2 around 0 92.9%
expm1-log1p-u92.5%
expm1-undefine92.5%
*-commutative92.5%
Applied egg-rr92.5%
expm1-define92.5%
Simplified92.5%
Taylor expanded in phi1 around 0 55.6%
+-commutative55.6%
unpow255.6%
unpow255.6%
hypot-define86.8%
Simplified86.8%
Taylor expanded in lambda1 around -inf 27.2%
associate-*r*27.2%
neg-mul-127.2%
Simplified27.2%
if -1.4000000000000001e-159 < phi1 < -1.84999999999999995e-202Initial program 92.7%
hypot-define100.0%
Simplified100.0%
Taylor expanded in phi2 around 0 100.0%
expm1-log1p-u100.0%
expm1-undefine100.0%
*-commutative100.0%
Applied egg-rr100.0%
expm1-define100.0%
Simplified100.0%
Taylor expanded in phi1 around 0 92.7%
+-commutative92.7%
unpow292.7%
unpow292.7%
hypot-define100.0%
Simplified100.0%
Taylor expanded in lambda2 around inf 25.5%
if -4.5999999999999999e-269 < phi1 Initial program 68.4%
hypot-define95.5%
Simplified95.5%
Taylor expanded in phi2 around inf 11.0%
*-commutative11.0%
Simplified11.0%
Final simplification31.9%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= phi1 -1.25e-23)
(* R (- phi2 phi1))
(if (<= phi1 5e-282)
(* R (* lambda1 (+ -1.0 (/ lambda2 lambda1))))
(* phi2 (- R (* phi1 (/ R phi2)))))))assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -1.25e-23) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= 5e-282) {
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
} else {
tmp = phi2 * (R - (phi1 * (R / phi2)));
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi1 <= (-1.25d-23)) then
tmp = r * (phi2 - phi1)
else if (phi1 <= 5d-282) then
tmp = r * (lambda1 * ((-1.0d0) + (lambda2 / lambda1)))
else
tmp = phi2 * (r - (phi1 * (r / phi2)))
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -1.25e-23) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= 5e-282) {
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
} else {
tmp = phi2 * (R - (phi1 * (R / phi2)));
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -1.25e-23: tmp = R * (phi2 - phi1) elif phi1 <= 5e-282: tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1))) else: tmp = phi2 * (R - (phi1 * (R / phi2))) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -1.25e-23) tmp = Float64(R * Float64(phi2 - phi1)); elseif (phi1 <= 5e-282) tmp = Float64(R * Float64(lambda1 * Float64(-1.0 + Float64(lambda2 / lambda1)))); else tmp = Float64(phi2 * Float64(R - Float64(phi1 * Float64(R / phi2)))); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi1 <= -1.25e-23)
tmp = R * (phi2 - phi1);
elseif (phi1 <= 5e-282)
tmp = R * (lambda1 * (-1.0 + (lambda2 / lambda1)));
else
tmp = phi2 * (R - (phi1 * (R / phi2)));
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi1, -1.25e-23], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision], If[LessEqual[phi1, 5e-282], N[(R * N[(lambda1 * N[(-1.0 + N[(lambda2 / lambda1), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(phi2 * N[(R - N[(phi1 * N[(R / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -1.25 \cdot 10^{-23}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\mathbf{elif}\;\phi_1 \leq 5 \cdot 10^{-282}:\\
\;\;\;\;R \cdot \left(\lambda_1 \cdot \left(-1 + \frac{\lambda_2}{\lambda_1}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\phi_2 \cdot \left(R - \phi_1 \cdot \frac{R}{\phi_2}\right)\\
\end{array}
\end{array}
if phi1 < -1.2500000000000001e-23Initial program 52.5%
hypot-define95.2%
Simplified95.2%
Taylor expanded in phi1 around -inf 64.1%
associate-*r*64.1%
mul-1-neg64.1%
associate-*r/64.1%
mul-1-neg64.1%
*-commutative64.1%
Simplified64.1%
Taylor expanded in phi1 around 0 64.1%
+-commutative64.1%
mul-1-neg64.1%
unsub-neg64.1%
Simplified64.1%
Taylor expanded in R around 0 70.1%
if -1.2500000000000001e-23 < phi1 < 5.0000000000000001e-282Initial program 72.2%
hypot-define99.9%
Simplified99.9%
Taylor expanded in phi2 around 0 95.2%
expm1-log1p-u95.2%
expm1-undefine95.2%
*-commutative95.2%
Applied egg-rr95.2%
expm1-define95.2%
Simplified95.2%
Taylor expanded in phi1 around 0 68.2%
+-commutative68.2%
unpow268.2%
unpow268.2%
hypot-define92.4%
Simplified92.4%
Taylor expanded in lambda1 around -inf 37.4%
associate-*r*37.4%
mul-1-neg37.4%
associate-*r/37.4%
neg-mul-137.4%
Simplified37.4%
if 5.0000000000000001e-282 < phi1 Initial program 67.1%
hypot-define95.0%
Simplified95.0%
Taylor expanded in phi2 around inf 8.3%
mul-1-neg8.3%
unsub-neg8.3%
*-commutative8.3%
associate-/l*9.2%
Simplified9.2%
Final simplification36.3%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
(FPCore (R lambda1 lambda2 phi1 phi2)
:precision binary64
(if (<= phi1 -4.2e-24)
(* R (- phi2 phi1))
(if (<= phi1 4.3e-288)
(* lambda2 (- R (/ (* R lambda1) lambda2)))
(* phi2 (- R (* phi1 (/ R phi2)))))))assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -4.2e-24) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= 4.3e-288) {
tmp = lambda2 * (R - ((R * lambda1) / lambda2));
} else {
tmp = phi2 * (R - (phi1 * (R / phi2)));
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi1 <= (-4.2d-24)) then
tmp = r * (phi2 - phi1)
else if (phi1 <= 4.3d-288) then
tmp = lambda2 * (r - ((r * lambda1) / lambda2))
else
tmp = phi2 * (r - (phi1 * (r / phi2)))
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -4.2e-24) {
tmp = R * (phi2 - phi1);
} else if (phi1 <= 4.3e-288) {
tmp = lambda2 * (R - ((R * lambda1) / lambda2));
} else {
tmp = phi2 * (R - (phi1 * (R / phi2)));
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -4.2e-24: tmp = R * (phi2 - phi1) elif phi1 <= 4.3e-288: tmp = lambda2 * (R - ((R * lambda1) / lambda2)) else: tmp = phi2 * (R - (phi1 * (R / phi2))) return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -4.2e-24) tmp = Float64(R * Float64(phi2 - phi1)); elseif (phi1 <= 4.3e-288) tmp = Float64(lambda2 * Float64(R - Float64(Float64(R * lambda1) / lambda2))); else tmp = Float64(phi2 * Float64(R - Float64(phi1 * Float64(R / phi2)))); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi1 <= -4.2e-24)
tmp = R * (phi2 - phi1);
elseif (phi1 <= 4.3e-288)
tmp = lambda2 * (R - ((R * lambda1) / lambda2));
else
tmp = phi2 * (R - (phi1 * (R / phi2)));
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi1, -4.2e-24], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision], If[LessEqual[phi1, 4.3e-288], N[(lambda2 * N[(R - N[(N[(R * lambda1), $MachinePrecision] / lambda2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(phi2 * N[(R - N[(phi1 * N[(R / phi2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -4.2 \cdot 10^{-24}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\mathbf{elif}\;\phi_1 \leq 4.3 \cdot 10^{-288}:\\
\;\;\;\;\lambda_2 \cdot \left(R - \frac{R \cdot \lambda_1}{\lambda_2}\right)\\
\mathbf{else}:\\
\;\;\;\;\phi_2 \cdot \left(R - \phi_1 \cdot \frac{R}{\phi_2}\right)\\
\end{array}
\end{array}
if phi1 < -4.1999999999999999e-24Initial program 52.5%
hypot-define95.2%
Simplified95.2%
Taylor expanded in phi1 around -inf 64.1%
associate-*r*64.1%
mul-1-neg64.1%
associate-*r/64.1%
mul-1-neg64.1%
*-commutative64.1%
Simplified64.1%
Taylor expanded in phi1 around 0 64.1%
+-commutative64.1%
mul-1-neg64.1%
unsub-neg64.1%
Simplified64.1%
Taylor expanded in R around 0 70.1%
if -4.1999999999999999e-24 < phi1 < 4.29999999999999976e-288Initial program 71.7%
hypot-define99.9%
Simplified99.9%
Taylor expanded in phi2 around 0 95.1%
expm1-log1p-u95.1%
expm1-undefine95.1%
*-commutative95.1%
Applied egg-rr95.1%
expm1-define95.1%
Simplified95.1%
Taylor expanded in phi1 around 0 67.7%
+-commutative67.7%
unpow267.7%
unpow267.7%
hypot-define92.3%
Simplified92.3%
Taylor expanded in lambda2 around inf 36.3%
associate-*r/36.3%
associate-*r*36.3%
neg-mul-136.3%
Simplified36.3%
if 4.29999999999999976e-288 < phi1 Initial program 67.4%
hypot-define95.0%
Simplified95.0%
Taylor expanded in phi2 around inf 8.2%
mul-1-neg8.2%
unsub-neg8.2%
*-commutative8.2%
associate-/l*9.2%
Simplified9.2%
Final simplification35.9%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= lambda1 -3.7e+145) (* R (- lambda1)) (if (<= lambda1 2.3e-6) (* R (- phi2 phi1)) (* R lambda2))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -3.7e+145) {
tmp = R * -lambda1;
} else if (lambda1 <= 2.3e-6) {
tmp = R * (phi2 - phi1);
} else {
tmp = R * lambda2;
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (lambda1 <= (-3.7d+145)) then
tmp = r * -lambda1
else if (lambda1 <= 2.3d-6) then
tmp = r * (phi2 - phi1)
else
tmp = r * lambda2
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (lambda1 <= -3.7e+145) {
tmp = R * -lambda1;
} else if (lambda1 <= 2.3e-6) {
tmp = R * (phi2 - phi1);
} else {
tmp = R * lambda2;
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if lambda1 <= -3.7e+145: tmp = R * -lambda1 elif lambda1 <= 2.3e-6: tmp = R * (phi2 - phi1) else: tmp = R * lambda2 return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (lambda1 <= -3.7e+145) tmp = Float64(R * Float64(-lambda1)); elseif (lambda1 <= 2.3e-6) tmp = Float64(R * Float64(phi2 - phi1)); else tmp = Float64(R * lambda2); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (lambda1 <= -3.7e+145)
tmp = R * -lambda1;
elseif (lambda1 <= 2.3e-6)
tmp = R * (phi2 - phi1);
else
tmp = R * lambda2;
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[lambda1, -3.7e+145], N[(R * (-lambda1)), $MachinePrecision], If[LessEqual[lambda1, 2.3e-6], N[(R * N[(phi2 - phi1), $MachinePrecision]), $MachinePrecision], N[(R * lambda2), $MachinePrecision]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\lambda_1 \leq -3.7 \cdot 10^{+145}:\\
\;\;\;\;R \cdot \left(-\lambda_1\right)\\
\mathbf{elif}\;\lambda_1 \leq 2.3 \cdot 10^{-6}:\\
\;\;\;\;R \cdot \left(\phi_2 - \phi_1\right)\\
\mathbf{else}:\\
\;\;\;\;R \cdot \lambda_2\\
\end{array}
\end{array}
if lambda1 < -3.69999999999999993e145Initial program 50.6%
hypot-define85.7%
Simplified85.7%
Taylor expanded in phi2 around 0 80.1%
expm1-log1p-u50.4%
expm1-undefine50.4%
*-commutative50.4%
Applied egg-rr50.4%
expm1-define50.4%
Simplified50.4%
Taylor expanded in phi1 around 0 47.9%
+-commutative47.9%
unpow247.9%
unpow247.9%
hypot-define67.5%
Simplified67.5%
Taylor expanded in lambda1 around -inf 60.1%
associate-*r*60.1%
neg-mul-160.1%
Simplified60.1%
if -3.69999999999999993e145 < lambda1 < 2.3e-6Initial program 69.3%
hypot-define97.4%
Simplified97.4%
Taylor expanded in phi1 around -inf 32.7%
associate-*r*32.7%
mul-1-neg32.7%
associate-*r/32.7%
mul-1-neg32.7%
*-commutative32.7%
Simplified32.7%
Taylor expanded in phi1 around 0 32.1%
+-commutative32.1%
mul-1-neg32.1%
unsub-neg32.1%
Simplified32.1%
Taylor expanded in R around 0 33.3%
if 2.3e-6 < lambda1 Initial program 53.9%
hypot-define97.8%
Simplified97.8%
Taylor expanded in phi2 around 0 93.9%
expm1-log1p-u57.7%
expm1-undefine57.6%
*-commutative57.6%
Applied egg-rr57.6%
expm1-define57.7%
Simplified57.7%
Taylor expanded in phi1 around 0 51.5%
+-commutative51.5%
unpow251.5%
unpow251.5%
hypot-define75.9%
Simplified75.9%
Taylor expanded in lambda2 around inf 14.4%
Final simplification31.6%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= phi1 -6.6e-59) (* R (- phi1)) (if (<= phi1 -1.15e-304) (* R lambda2) (* R phi2))))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -6.6e-59) {
tmp = R * -phi1;
} else if (phi1 <= -1.15e-304) {
tmp = R * lambda2;
} else {
tmp = R * phi2;
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi1 <= (-6.6d-59)) then
tmp = r * -phi1
else if (phi1 <= (-1.15d-304)) then
tmp = r * lambda2
else
tmp = r * phi2
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi1 <= -6.6e-59) {
tmp = R * -phi1;
} else if (phi1 <= -1.15e-304) {
tmp = R * lambda2;
} else {
tmp = R * phi2;
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi1 <= -6.6e-59: tmp = R * -phi1 elif phi1 <= -1.15e-304: tmp = R * lambda2 else: tmp = R * phi2 return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi1 <= -6.6e-59) tmp = Float64(R * Float64(-phi1)); elseif (phi1 <= -1.15e-304) tmp = Float64(R * lambda2); else tmp = Float64(R * phi2); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi1 <= -6.6e-59)
tmp = R * -phi1;
elseif (phi1 <= -1.15e-304)
tmp = R * lambda2;
else
tmp = R * phi2;
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi1, -6.6e-59], N[(R * (-phi1)), $MachinePrecision], If[LessEqual[phi1, -1.15e-304], N[(R * lambda2), $MachinePrecision], N[(R * phi2), $MachinePrecision]]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_1 \leq -6.6 \cdot 10^{-59}:\\
\;\;\;\;R \cdot \left(-\phi_1\right)\\
\mathbf{elif}\;\phi_1 \leq -1.15 \cdot 10^{-304}:\\
\;\;\;\;R \cdot \lambda_2\\
\mathbf{else}:\\
\;\;\;\;R \cdot \phi_2\\
\end{array}
\end{array}
if phi1 < -6.59999999999999964e-59Initial program 53.6%
hypot-define95.5%
Simplified95.5%
Taylor expanded in phi1 around -inf 61.3%
mul-1-neg61.3%
Simplified61.3%
if -6.59999999999999964e-59 < phi1 < -1.15e-304Initial program 73.0%
hypot-define99.9%
Simplified99.9%
Taylor expanded in phi2 around 0 94.1%
expm1-log1p-u94.1%
expm1-undefine94.1%
*-commutative94.1%
Applied egg-rr94.1%
expm1-define94.1%
Simplified94.1%
Taylor expanded in phi1 around 0 69.9%
+-commutative69.9%
unpow269.9%
unpow269.9%
hypot-define92.5%
Simplified92.5%
Taylor expanded in lambda2 around inf 28.6%
if -1.15e-304 < phi1 Initial program 67.2%
hypot-define95.2%
Simplified95.2%
Taylor expanded in phi2 around inf 11.4%
*-commutative11.4%
Simplified11.4%
Final simplification32.5%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (if (<= phi2 2.8e+55) (* R lambda2) (* R phi2)))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 2.8e+55) {
tmp = R * lambda2;
} else {
tmp = R * phi2;
}
return tmp;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
real(8) :: tmp
if (phi2 <= 2.8d+55) then
tmp = r * lambda2
else
tmp = r * phi2
end if
code = tmp
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
double tmp;
if (phi2 <= 2.8e+55) {
tmp = R * lambda2;
} else {
tmp = R * phi2;
}
return tmp;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): tmp = 0 if phi2 <= 2.8e+55: tmp = R * lambda2 else: tmp = R * phi2 return tmp
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) tmp = 0.0 if (phi2 <= 2.8e+55) tmp = Float64(R * lambda2); else tmp = Float64(R * phi2); end return tmp end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp_2 = code(R, lambda1, lambda2, phi1, phi2)
tmp = 0.0;
if (phi2 <= 2.8e+55)
tmp = R * lambda2;
else
tmp = R * phi2;
end
tmp_2 = tmp;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := If[LessEqual[phi2, 2.8e+55], N[(R * lambda2), $MachinePrecision], N[(R * phi2), $MachinePrecision]]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
\begin{array}{l}
\mathbf{if}\;\phi_2 \leq 2.8 \cdot 10^{+55}:\\
\;\;\;\;R \cdot \lambda_2\\
\mathbf{else}:\\
\;\;\;\;R \cdot \phi_2\\
\end{array}
\end{array}
if phi2 < 2.8000000000000001e55Initial program 66.6%
hypot-define98.3%
Simplified98.3%
Taylor expanded in phi2 around 0 95.9%
expm1-log1p-u66.1%
expm1-undefine66.1%
*-commutative66.1%
Applied egg-rr66.1%
expm1-define66.1%
Simplified66.1%
Taylor expanded in phi1 around 0 51.5%
+-commutative51.5%
unpow251.5%
unpow251.5%
hypot-define67.7%
Simplified67.7%
Taylor expanded in lambda2 around inf 17.5%
if 2.8000000000000001e55 < phi2 Initial program 52.7%
hypot-define88.7%
Simplified88.7%
Taylor expanded in phi2 around inf 56.7%
*-commutative56.7%
Simplified56.7%
Final simplification25.8%
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. (FPCore (R lambda1 lambda2 phi1 phi2) :precision binary64 (* R lambda2))
assert(R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2);
double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * lambda2;
}
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function.
real(8) function code(r, lambda1, lambda2, phi1, phi2)
real(8), intent (in) :: r
real(8), intent (in) :: lambda1
real(8), intent (in) :: lambda2
real(8), intent (in) :: phi1
real(8), intent (in) :: phi2
code = r * lambda2
end function
assert R < lambda1 && lambda1 < lambda2 && lambda2 < phi1 && phi1 < phi2;
public static double code(double R, double lambda1, double lambda2, double phi1, double phi2) {
return R * lambda2;
}
[R, lambda1, lambda2, phi1, phi2] = sort([R, lambda1, lambda2, phi1, phi2]) def code(R, lambda1, lambda2, phi1, phi2): return R * lambda2
R, lambda1, lambda2, phi1, phi2 = sort([R, lambda1, lambda2, phi1, phi2]) function code(R, lambda1, lambda2, phi1, phi2) return Float64(R * lambda2) end
R, lambda1, lambda2, phi1, phi2 = num2cell(sort([R, lambda1, lambda2, phi1, phi2])){:}
function tmp = code(R, lambda1, lambda2, phi1, phi2)
tmp = R * lambda2;
end
NOTE: R, lambda1, lambda2, phi1, and phi2 should be sorted in increasing order before calling this function. code[R_, lambda1_, lambda2_, phi1_, phi2_] := N[(R * lambda2), $MachinePrecision]
\begin{array}{l}
[R, lambda1, lambda2, phi1, phi2] = \mathsf{sort}([R, lambda1, lambda2, phi1, phi2])\\
\\
R \cdot \lambda_2
\end{array}
Initial program 63.6%
hypot-define96.3%
Simplified96.3%
Taylor expanded in phi2 around 0 93.5%
expm1-log1p-u61.2%
expm1-undefine61.1%
*-commutative61.1%
Applied egg-rr61.1%
expm1-define61.2%
Simplified61.2%
Taylor expanded in phi1 around 0 50.3%
+-commutative50.3%
unpow250.3%
unpow250.3%
hypot-define67.4%
Simplified67.4%
Taylor expanded in lambda2 around inf 17.1%
herbie shell --seed 2024110
(FPCore (R lambda1 lambda2 phi1 phi2)
:name "Equirectangular approximation to distance on a great circle"
:precision binary64
(* R (sqrt (+ (* (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0))) (* (- lambda1 lambda2) (cos (/ (+ phi1 phi2) 2.0)))) (* (- phi1 phi2) (- phi1 phi2))))))