
(FPCore (a b angle) :precision binary64 (let* ((t_0 (* PI (/ angle 180.0)))) (* (* (* 2.0 (- (pow b 2.0) (pow a 2.0))) (sin t_0)) (cos t_0))))
double code(double a, double b, double angle) {
double t_0 = ((double) M_PI) * (angle / 180.0);
return ((2.0 * (pow(b, 2.0) - pow(a, 2.0))) * sin(t_0)) * cos(t_0);
}
public static double code(double a, double b, double angle) {
double t_0 = Math.PI * (angle / 180.0);
return ((2.0 * (Math.pow(b, 2.0) - Math.pow(a, 2.0))) * Math.sin(t_0)) * Math.cos(t_0);
}
def code(a, b, angle): t_0 = math.pi * (angle / 180.0) return ((2.0 * (math.pow(b, 2.0) - math.pow(a, 2.0))) * math.sin(t_0)) * math.cos(t_0)
function code(a, b, angle) t_0 = Float64(pi * Float64(angle / 180.0)) return Float64(Float64(Float64(2.0 * Float64((b ^ 2.0) - (a ^ 2.0))) * sin(t_0)) * cos(t_0)) end
function tmp = code(a, b, angle) t_0 = pi * (angle / 180.0); tmp = ((2.0 * ((b ^ 2.0) - (a ^ 2.0))) * sin(t_0)) * cos(t_0); end
code[a_, b_, angle_] := Block[{t$95$0 = N[(Pi * N[(angle / 180.0), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[(2.0 * N[(N[Power[b, 2.0], $MachinePrecision] - N[Power[a, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[t$95$0], $MachinePrecision]), $MachinePrecision] * N[Cos[t$95$0], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \pi \cdot \frac{angle}{180}\\
\left(\left(2 \cdot \left({b}^{2} - {a}^{2}\right)\right) \cdot \sin t_0\right) \cdot \cos t_0
\end{array}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 18 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (a b angle) :precision binary64 (let* ((t_0 (* PI (/ angle 180.0)))) (* (* (* 2.0 (- (pow b 2.0) (pow a 2.0))) (sin t_0)) (cos t_0))))
double code(double a, double b, double angle) {
double t_0 = ((double) M_PI) * (angle / 180.0);
return ((2.0 * (pow(b, 2.0) - pow(a, 2.0))) * sin(t_0)) * cos(t_0);
}
public static double code(double a, double b, double angle) {
double t_0 = Math.PI * (angle / 180.0);
return ((2.0 * (Math.pow(b, 2.0) - Math.pow(a, 2.0))) * Math.sin(t_0)) * Math.cos(t_0);
}
def code(a, b, angle): t_0 = math.pi * (angle / 180.0) return ((2.0 * (math.pow(b, 2.0) - math.pow(a, 2.0))) * math.sin(t_0)) * math.cos(t_0)
function code(a, b, angle) t_0 = Float64(pi * Float64(angle / 180.0)) return Float64(Float64(Float64(2.0 * Float64((b ^ 2.0) - (a ^ 2.0))) * sin(t_0)) * cos(t_0)) end
function tmp = code(a, b, angle) t_0 = pi * (angle / 180.0); tmp = ((2.0 * ((b ^ 2.0) - (a ^ 2.0))) * sin(t_0)) * cos(t_0); end
code[a_, b_, angle_] := Block[{t$95$0 = N[(Pi * N[(angle / 180.0), $MachinePrecision]), $MachinePrecision]}, N[(N[(N[(2.0 * N[(N[Power[b, 2.0], $MachinePrecision] - N[Power[a, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[t$95$0], $MachinePrecision]), $MachinePrecision] * N[Cos[t$95$0], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \pi \cdot \frac{angle}{180}\\
\left(\left(2 \cdot \left({b}^{2} - {a}^{2}\right)\right) \cdot \sin t_0\right) \cdot \cos t_0
\end{array}
\end{array}
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* 2.0 (* (+ b a) (- b a))))
(t_1 (sin (* PI (* angle_m 0.005555555555555556)))))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+41)
(*
(* (* t_1 (* 2.0 (+ b a))) (- b a))
(cos (* angle_m (/ (cbrt (pow PI 3.0)) 180.0))))
(if (<= (/ angle_m 180.0) 4e+105)
(*
t_0
(+
(* -2.8577960676726107e-8 (* (pow PI 3.0) (pow angle_m 3.0)))
(* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 2e+133)
(* t_0 (sqrt (pow t_1 2.0)))
(if (<= (/ angle_m 180.0) 2e+238)
(* t_0 (sin (/ (* angle_m PI) 180.0)))
(*
(*
t_0
(sin
(*
(pow (pow (cbrt (cbrt angle_m)) 2.0) 3.0)
(* (cbrt angle_m) (* PI 0.005555555555555556)))))
(cos (* (/ angle_m 180.0) PI))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = sin((((double) M_PI) * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+41) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (cbrt(pow(((double) M_PI), 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (pow(((double) M_PI), 3.0) * pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = t_0 * sqrt(pow(t_1, 2.0));
} else if ((angle_m / 180.0) <= 2e+238) {
tmp = t_0 * sin(((angle_m * ((double) M_PI)) / 180.0));
} else {
tmp = (t_0 * sin((pow(pow(cbrt(cbrt(angle_m)), 2.0), 3.0) * (cbrt(angle_m) * (((double) M_PI) * 0.005555555555555556))))) * cos(((angle_m / 180.0) * ((double) M_PI)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = Math.sin((Math.PI * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+41) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * Math.cos((angle_m * (Math.cbrt(Math.pow(Math.PI, 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (Math.pow(Math.PI, 3.0) * Math.pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = t_0 * Math.sqrt(Math.pow(t_1, 2.0));
} else if ((angle_m / 180.0) <= 2e+238) {
tmp = t_0 * Math.sin(((angle_m * Math.PI) / 180.0));
} else {
tmp = (t_0 * Math.sin((Math.pow(Math.pow(Math.cbrt(Math.cbrt(angle_m)), 2.0), 3.0) * (Math.cbrt(angle_m) * (Math.PI * 0.005555555555555556))))) * Math.cos(((angle_m / 180.0) * Math.PI));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_1 = sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+41) tmp = Float64(Float64(Float64(t_1 * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(angle_m * Float64(cbrt((pi ^ 3.0)) / 180.0)))); elseif (Float64(angle_m / 180.0) <= 4e+105) tmp = Float64(t_0 * Float64(Float64(-2.8577960676726107e-8 * Float64((pi ^ 3.0) * (angle_m ^ 3.0))) + Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 2e+133) tmp = Float64(t_0 * sqrt((t_1 ^ 2.0))); elseif (Float64(angle_m / 180.0) <= 2e+238) tmp = Float64(t_0 * sin(Float64(Float64(angle_m * pi) / 180.0))); else tmp = Float64(Float64(t_0 * sin(Float64(((cbrt(cbrt(angle_m)) ^ 2.0) ^ 3.0) * Float64(cbrt(angle_m) * Float64(pi * 0.005555555555555556))))) * cos(Float64(Float64(angle_m / 180.0) * pi))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+41], N[(N[(N[(t$95$1 * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(N[Power[N[Power[Pi, 3.0], $MachinePrecision], 1/3], $MachinePrecision] / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 4e+105], N[(t$95$0 * N[(N[(-2.8577960676726107e-8 * N[(N[Power[Pi, 3.0], $MachinePrecision] * N[Power[angle$95$m, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+133], N[(t$95$0 * N[Sqrt[N[Power[t$95$1, 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+238], N[(t$95$0 * N[Sin[N[(N[(angle$95$m * Pi), $MachinePrecision] / 180.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[(t$95$0 * N[Sin[N[(N[Power[N[Power[N[Power[N[Power[angle$95$m, 1/3], $MachinePrecision], 1/3], $MachinePrecision], 2.0], $MachinePrecision], 3.0], $MachinePrecision] * N[(N[Power[angle$95$m, 1/3], $MachinePrecision] * N[(Pi * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_1 := \sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+41}:\\
\;\;\;\;\left(\left(t_1 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(angle_m \cdot \frac{\sqrt[3]{{\pi}^{3}}}{180}\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 4 \cdot 10^{+105}:\\
\;\;\;\;t_0 \cdot \left(-2.8577960676726107 \cdot 10^{-8} \cdot \left({\pi}^{3} \cdot {angle_m}^{3}\right) + 0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+133}:\\
\;\;\;\;t_0 \cdot \sqrt{{t_1}^{2}}\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+238}:\\
\;\;\;\;t_0 \cdot \sin \left(\frac{angle_m \cdot \pi}{180}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(t_0 \cdot \sin \left({\left({\left(\sqrt[3]{\sqrt[3]{angle_m}}\right)}^{2}\right)}^{3} \cdot \left(\sqrt[3]{angle_m} \cdot \left(\pi \cdot 0.005555555555555556\right)\right)\right)\right) \cdot \cos \left(\frac{angle_m}{180} \cdot \pi\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 2.00000000000000001e41Initial program 64.3%
add-sqr-sqrt32.2%
sqrt-unprod30.8%
pow230.8%
*-commutative30.8%
div-inv30.8%
metadata-eval30.8%
Applied egg-rr30.8%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.7%
Applied egg-rr75.7%
associate-*r/76.2%
associate-/l*76.3%
Applied egg-rr76.3%
associate-/r/77.5%
Simplified77.5%
add-cbrt-cube78.4%
pow378.4%
Applied egg-rr78.4%
if 2.00000000000000001e41 < (/.f64 angle 180) < 3.9999999999999998e105Initial program 22.7%
unpow222.7%
unpow222.7%
difference-of-squares29.0%
Applied egg-rr29.0%
Taylor expanded in angle around 0 29.7%
Taylor expanded in angle around 0 45.4%
if 3.9999999999999998e105 < (/.f64 angle 180) < 2e133Initial program 52.4%
unpow252.4%
unpow252.4%
difference-of-squares52.4%
Applied egg-rr52.4%
Taylor expanded in angle around 0 24.3%
add-sqr-sqrt13.9%
sqrt-unprod50.5%
pow250.5%
div-inv50.5%
metadata-eval50.5%
Applied egg-rr50.5%
if 2e133 < (/.f64 angle 180) < 2.0000000000000001e238Initial program 27.0%
unpow227.0%
unpow227.0%
difference-of-squares27.0%
Applied egg-rr27.0%
associate-*r/27.0%
Applied egg-rr27.0%
Taylor expanded in angle around 0 47.9%
if 2.0000000000000001e238 < (/.f64 angle 180) Initial program 13.6%
unpow213.6%
unpow213.6%
difference-of-squares13.7%
Applied egg-rr13.7%
associate-*r/21.6%
Applied egg-rr21.6%
div-inv16.7%
*-commutative16.7%
metadata-eval16.7%
associate-*r*14.9%
add-cube-cbrt13.9%
associate-*l*21.8%
cbrt-unprod0.0%
pow20.0%
Applied egg-rr0.0%
*-commutative0.0%
*-commutative0.0%
Simplified0.0%
add-cube-cbrt0.0%
pow30.0%
unpow20.0%
cbrt-prod37.1%
cbrt-unprod38.0%
pow238.0%
Applied egg-rr38.0%
Final simplification71.1%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* PI (* angle_m 0.005555555555555556)))
(t_1 (* (/ angle_m 180.0) PI))
(t_2 (* (* (sin t_0) (* 2.0 (+ b a))) (- b a))))
(*
angle_s
(if (<=
(* (cos t_1) (* (sin t_1) (* 2.0 (- (pow b 2.0) (pow a 2.0)))))
-1e-99)
(* t_2 (cos (* angle_m (/ (cbrt (pow PI 3.0)) 180.0))))
(* t_2 (log (exp (cos t_0))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double t_1 = (angle_m / 180.0) * ((double) M_PI);
double t_2 = (sin(t_0) * (2.0 * (b + a))) * (b - a);
double tmp;
if ((cos(t_1) * (sin(t_1) * (2.0 * (pow(b, 2.0) - pow(a, 2.0))))) <= -1e-99) {
tmp = t_2 * cos((angle_m * (cbrt(pow(((double) M_PI), 3.0)) / 180.0)));
} else {
tmp = t_2 * log(exp(cos(t_0)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = Math.PI * (angle_m * 0.005555555555555556);
double t_1 = (angle_m / 180.0) * Math.PI;
double t_2 = (Math.sin(t_0) * (2.0 * (b + a))) * (b - a);
double tmp;
if ((Math.cos(t_1) * (Math.sin(t_1) * (2.0 * (Math.pow(b, 2.0) - Math.pow(a, 2.0))))) <= -1e-99) {
tmp = t_2 * Math.cos((angle_m * (Math.cbrt(Math.pow(Math.PI, 3.0)) / 180.0)));
} else {
tmp = t_2 * Math.log(Math.exp(Math.cos(t_0)));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(pi * Float64(angle_m * 0.005555555555555556)) t_1 = Float64(Float64(angle_m / 180.0) * pi) t_2 = Float64(Float64(sin(t_0) * Float64(2.0 * Float64(b + a))) * Float64(b - a)) tmp = 0.0 if (Float64(cos(t_1) * Float64(sin(t_1) * Float64(2.0 * Float64((b ^ 2.0) - (a ^ 2.0))))) <= -1e-99) tmp = Float64(t_2 * cos(Float64(angle_m * Float64(cbrt((pi ^ 3.0)) / 180.0)))); else tmp = Float64(t_2 * log(exp(cos(t_0)))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[Sin[t$95$0], $MachinePrecision] * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(N[Cos[t$95$1], $MachinePrecision] * N[(N[Sin[t$95$1], $MachinePrecision] * N[(2.0 * N[(N[Power[b, 2.0], $MachinePrecision] - N[Power[a, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -1e-99], N[(t$95$2 * N[Cos[N[(angle$95$m * N[(N[Power[N[Power[Pi, 3.0], $MachinePrecision], 1/3], $MachinePrecision] / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(t$95$2 * N[Log[N[Exp[N[Cos[t$95$0], $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
t_1 := \frac{angle_m}{180} \cdot \pi\\
t_2 := \left(\sin t_0 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\cos t_1 \cdot \left(\sin t_1 \cdot \left(2 \cdot \left({b}^{2} - {a}^{2}\right)\right)\right) \leq -1 \cdot 10^{-99}:\\
\;\;\;\;t_2 \cdot \cos \left(angle_m \cdot \frac{\sqrt[3]{{\pi}^{3}}}{180}\right)\\
\mathbf{else}:\\
\;\;\;\;t_2 \cdot \log \left(e^{\cos t_0}\right)\\
\end{array}
\end{array}
\end{array}
if (*.f64 (*.f64 (*.f64 2 (-.f64 (pow.f64 b 2) (pow.f64 a 2))) (sin.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) (cos.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) < -1e-99Initial program 53.2%
add-sqr-sqrt8.4%
sqrt-unprod14.7%
pow214.7%
*-commutative14.7%
div-inv14.8%
metadata-eval14.8%
Applied egg-rr14.8%
sqrt-pow151.1%
metadata-eval51.1%
pow151.1%
unpow251.1%
unpow251.1%
difference-of-squares51.1%
associate-*r*51.1%
associate-*r*59.7%
Applied egg-rr59.7%
associate-*r/62.4%
associate-/l*61.5%
Applied egg-rr61.5%
associate-/r/63.0%
Simplified63.0%
add-cbrt-cube59.1%
pow359.1%
Applied egg-rr59.1%
if -1e-99 < (*.f64 (*.f64 (*.f64 2 (-.f64 (pow.f64 b 2) (pow.f64 a 2))) (sin.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) (cos.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) Initial program 57.9%
add-sqr-sqrt41.2%
sqrt-unprod38.8%
pow238.8%
*-commutative38.8%
div-inv38.7%
metadata-eval38.7%
Applied egg-rr38.7%
sqrt-pow155.4%
metadata-eval55.4%
pow155.4%
unpow255.4%
unpow255.4%
difference-of-squares59.9%
associate-*r*59.9%
associate-*r*68.1%
Applied egg-rr68.1%
add-log-exp68.1%
div-inv68.8%
metadata-eval68.8%
Applied egg-rr68.8%
Final simplification65.2%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* 2.0 (+ b a)))
(t_1 (* (/ angle_m 180.0) PI))
(t_2 (* PI (* angle_m 0.005555555555555556))))
(*
angle_s
(if (<=
(* (cos t_1) (* (sin t_1) (* 2.0 (- (pow b 2.0) (pow a 2.0)))))
-5e+30)
(*
(cos (* angle_m (/ PI 180.0)))
(*
(- b a)
(*
t_0
(sin (* (* angle_m 0.005555555555555556) (cbrt (pow PI 3.0)))))))
(* (* (* (sin t_2) t_0) (- b a)) (log (exp (cos t_2))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * (b + a);
double t_1 = (angle_m / 180.0) * ((double) M_PI);
double t_2 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double tmp;
if ((cos(t_1) * (sin(t_1) * (2.0 * (pow(b, 2.0) - pow(a, 2.0))))) <= -5e+30) {
tmp = cos((angle_m * (((double) M_PI) / 180.0))) * ((b - a) * (t_0 * sin(((angle_m * 0.005555555555555556) * cbrt(pow(((double) M_PI), 3.0))))));
} else {
tmp = ((sin(t_2) * t_0) * (b - a)) * log(exp(cos(t_2)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * (b + a);
double t_1 = (angle_m / 180.0) * Math.PI;
double t_2 = Math.PI * (angle_m * 0.005555555555555556);
double tmp;
if ((Math.cos(t_1) * (Math.sin(t_1) * (2.0 * (Math.pow(b, 2.0) - Math.pow(a, 2.0))))) <= -5e+30) {
tmp = Math.cos((angle_m * (Math.PI / 180.0))) * ((b - a) * (t_0 * Math.sin(((angle_m * 0.005555555555555556) * Math.cbrt(Math.pow(Math.PI, 3.0))))));
} else {
tmp = ((Math.sin(t_2) * t_0) * (b - a)) * Math.log(Math.exp(Math.cos(t_2)));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(2.0 * Float64(b + a)) t_1 = Float64(Float64(angle_m / 180.0) * pi) t_2 = Float64(pi * Float64(angle_m * 0.005555555555555556)) tmp = 0.0 if (Float64(cos(t_1) * Float64(sin(t_1) * Float64(2.0 * Float64((b ^ 2.0) - (a ^ 2.0))))) <= -5e+30) tmp = Float64(cos(Float64(angle_m * Float64(pi / 180.0))) * Float64(Float64(b - a) * Float64(t_0 * sin(Float64(Float64(angle_m * 0.005555555555555556) * cbrt((pi ^ 3.0))))))); else tmp = Float64(Float64(Float64(sin(t_2) * t_0) * Float64(b - a)) * log(exp(cos(t_2)))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]}, Block[{t$95$2 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(N[Cos[t$95$1], $MachinePrecision] * N[(N[Sin[t$95$1], $MachinePrecision] * N[(2.0 * N[(N[Power[b, 2.0], $MachinePrecision] - N[Power[a, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], -5e+30], N[(N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[(N[(b - a), $MachinePrecision] * N[(t$95$0 * N[Sin[N[(N[(angle$95$m * 0.005555555555555556), $MachinePrecision] * N[Power[N[Power[Pi, 3.0], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(N[Sin[t$95$2], $MachinePrecision] * t$95$0), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Log[N[Exp[N[Cos[t$95$2], $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := 2 \cdot \left(b + a\right)\\
t_1 := \frac{angle_m}{180} \cdot \pi\\
t_2 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\cos t_1 \cdot \left(\sin t_1 \cdot \left(2 \cdot \left({b}^{2} - {a}^{2}\right)\right)\right) \leq -5 \cdot 10^{+30}:\\
\;\;\;\;\cos \left(angle_m \cdot \frac{\pi}{180}\right) \cdot \left(\left(b - a\right) \cdot \left(t_0 \cdot \sin \left(\left(angle_m \cdot 0.005555555555555556\right) \cdot \sqrt[3]{{\pi}^{3}}\right)\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\sin t_2 \cdot t_0\right) \cdot \left(b - a\right)\right) \cdot \log \left(e^{\cos t_2}\right)\\
\end{array}
\end{array}
\end{array}
if (*.f64 (*.f64 (*.f64 2 (-.f64 (pow.f64 b 2) (pow.f64 a 2))) (sin.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) (cos.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) < -4.9999999999999998e30Initial program 49.8%
add-sqr-sqrt9.1%
sqrt-unprod16.0%
pow216.0%
*-commutative16.0%
div-inv16.1%
metadata-eval16.1%
Applied egg-rr16.1%
sqrt-pow147.4%
metadata-eval47.4%
pow147.4%
unpow247.4%
unpow247.4%
difference-of-squares47.4%
associate-*r*47.4%
associate-*r*57.0%
Applied egg-rr57.0%
associate-*r/60.0%
associate-/l*59.1%
Applied egg-rr59.1%
associate-/r/60.7%
Simplified60.7%
add-cbrt-cube56.4%
pow356.4%
Applied egg-rr57.9%
if -4.9999999999999998e30 < (*.f64 (*.f64 (*.f64 2 (-.f64 (pow.f64 b 2) (pow.f64 a 2))) (sin.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) (cos.f64 (*.f64 (PI.f64) (/.f64 angle 180)))) Initial program 59.3%
add-sqr-sqrt38.9%
sqrt-unprod36.7%
pow236.7%
*-commutative36.7%
div-inv36.7%
metadata-eval36.7%
Applied egg-rr36.7%
sqrt-pow157.0%
metadata-eval57.0%
pow157.0%
unpow257.0%
unpow257.0%
difference-of-squares61.2%
associate-*r*61.2%
associate-*r*69.0%
Applied egg-rr69.0%
add-log-exp69.0%
div-inv69.6%
metadata-eval69.6%
Applied egg-rr69.6%
Final simplification65.7%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* PI (* angle_m 0.005555555555555556)))
(t_1 (* 2.0 (* (+ b a) (- b a))))
(t_2 (* (/ angle_m 180.0) PI)))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+38)
(*
(* (* (sin t_0) (* 2.0 (+ b a))) (- b a))
(cos (* angle_m (/ (cbrt (pow PI 3.0)) 180.0))))
(if (<= (/ angle_m 180.0) 5e+108)
(* t_1 (sin (* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 5e+131)
(* (* t_1 (sin t_2)) (cos (expm1 (log1p t_0))))
(if (<= (/ angle_m 180.0) 1.5e+228)
(* t_1 (sin (pow (sqrt t_0) 2.0)))
(*
(cos t_2)
(*
t_1
(sin
(*
(* (cbrt angle_m) (* PI 0.005555555555555556))
(pow (cbrt angle_m) 2.0))))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = (angle_m / 180.0) * ((double) M_PI);
double tmp;
if ((angle_m / 180.0) <= 2e+38) {
tmp = ((sin(t_0) * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (cbrt(pow(((double) M_PI), 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * sin((0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 5e+131) {
tmp = (t_1 * sin(t_2)) * cos(expm1(log1p(t_0)));
} else if ((angle_m / 180.0) <= 1.5e+228) {
tmp = t_1 * sin(pow(sqrt(t_0), 2.0));
} else {
tmp = cos(t_2) * (t_1 * sin(((cbrt(angle_m) * (((double) M_PI) * 0.005555555555555556)) * pow(cbrt(angle_m), 2.0))));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = Math.PI * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = (angle_m / 180.0) * Math.PI;
double tmp;
if ((angle_m / 180.0) <= 2e+38) {
tmp = ((Math.sin(t_0) * (2.0 * (b + a))) * (b - a)) * Math.cos((angle_m * (Math.cbrt(Math.pow(Math.PI, 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * Math.sin((0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 5e+131) {
tmp = (t_1 * Math.sin(t_2)) * Math.cos(Math.expm1(Math.log1p(t_0)));
} else if ((angle_m / 180.0) <= 1.5e+228) {
tmp = t_1 * Math.sin(Math.pow(Math.sqrt(t_0), 2.0));
} else {
tmp = Math.cos(t_2) * (t_1 * Math.sin(((Math.cbrt(angle_m) * (Math.PI * 0.005555555555555556)) * Math.pow(Math.cbrt(angle_m), 2.0))));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(pi * Float64(angle_m * 0.005555555555555556)) t_1 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_2 = Float64(Float64(angle_m / 180.0) * pi) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+38) tmp = Float64(Float64(Float64(sin(t_0) * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(angle_m * Float64(cbrt((pi ^ 3.0)) / 180.0)))); elseif (Float64(angle_m / 180.0) <= 5e+108) tmp = Float64(t_1 * sin(Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 5e+131) tmp = Float64(Float64(t_1 * sin(t_2)) * cos(expm1(log1p(t_0)))); elseif (Float64(angle_m / 180.0) <= 1.5e+228) tmp = Float64(t_1 * sin((sqrt(t_0) ^ 2.0))); else tmp = Float64(cos(t_2) * Float64(t_1 * sin(Float64(Float64(cbrt(angle_m) * Float64(pi * 0.005555555555555556)) * (cbrt(angle_m) ^ 2.0))))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+38], N[(N[(N[(N[Sin[t$95$0], $MachinePrecision] * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(N[Power[N[Power[Pi, 3.0], $MachinePrecision], 1/3], $MachinePrecision] / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+108], N[(t$95$1 * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+131], N[(N[(t$95$1 * N[Sin[t$95$2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(Exp[N[Log[1 + t$95$0], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 1.5e+228], N[(t$95$1 * N[Sin[N[Power[N[Sqrt[t$95$0], $MachinePrecision], 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Cos[t$95$2], $MachinePrecision] * N[(t$95$1 * N[Sin[N[(N[(N[Power[angle$95$m, 1/3], $MachinePrecision] * N[(Pi * 0.005555555555555556), $MachinePrecision]), $MachinePrecision] * N[Power[N[Power[angle$95$m, 1/3], $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]]), $MachinePrecision]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
t_1 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_2 := \frac{angle_m}{180} \cdot \pi\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+38}:\\
\;\;\;\;\left(\left(\sin t_0 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(angle_m \cdot \frac{\sqrt[3]{{\pi}^{3}}}{180}\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+108}:\\
\;\;\;\;t_1 \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+131}:\\
\;\;\;\;\left(t_1 \cdot \sin t_2\right) \cdot \cos \left(\mathsf{expm1}\left(\mathsf{log1p}\left(t_0\right)\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 1.5 \cdot 10^{+228}:\\
\;\;\;\;t_1 \cdot \sin \left({\left(\sqrt{t_0}\right)}^{2}\right)\\
\mathbf{else}:\\
\;\;\;\;\cos t_2 \cdot \left(t_1 \cdot \sin \left(\left(\sqrt[3]{angle_m} \cdot \left(\pi \cdot 0.005555555555555556\right)\right) \cdot {\left(\sqrt[3]{angle_m}\right)}^{2}\right)\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 1.99999999999999995e38Initial program 64.3%
add-sqr-sqrt32.2%
sqrt-unprod30.8%
pow230.8%
*-commutative30.8%
div-inv30.8%
metadata-eval30.8%
Applied egg-rr30.8%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.7%
Applied egg-rr75.7%
associate-*r/76.2%
associate-/l*76.3%
Applied egg-rr76.3%
associate-/r/77.5%
Simplified77.5%
add-cbrt-cube78.4%
pow378.4%
Applied egg-rr78.4%
if 1.99999999999999995e38 < (/.f64 angle 180) < 4.99999999999999991e108Initial program 26.3%
unpow226.3%
unpow226.3%
difference-of-squares31.6%
Applied egg-rr31.6%
Taylor expanded in angle around 0 25.8%
Taylor expanded in angle around 0 38.7%
if 4.99999999999999991e108 < (/.f64 angle 180) < 4.99999999999999995e131Initial program 59.6%
unpow259.6%
unpow259.6%
difference-of-squares59.6%
Applied egg-rr59.6%
div-inv59.6%
metadata-eval59.6%
expm1-log1p-u76.8%
Applied egg-rr76.8%
if 4.99999999999999995e131 < (/.f64 angle 180) < 1.5000000000000001e228Initial program 13.9%
unpow213.9%
unpow213.9%
difference-of-squares13.9%
Applied egg-rr13.9%
Taylor expanded in angle around 0 31.7%
div-inv31.7%
metadata-eval31.7%
add-sqr-sqrt38.3%
pow238.3%
Applied egg-rr38.3%
if 1.5000000000000001e228 < (/.f64 angle 180) Initial program 26.6%
unpow226.6%
unpow226.6%
difference-of-squares26.6%
Applied egg-rr26.6%
associate-*r/26.8%
Applied egg-rr26.8%
div-inv28.8%
*-commutative28.8%
metadata-eval28.8%
associate-*r*27.5%
add-cube-cbrt26.8%
associate-*l*38.0%
cbrt-unprod0.0%
pow20.0%
Applied egg-rr0.0%
*-commutative0.0%
*-commutative0.0%
Simplified0.0%
expm1-log1p-u0.0%
expm1-udef0.0%
unpow20.0%
cbrt-prod37.2%
pow237.2%
Applied egg-rr37.2%
expm1-def38.2%
expm1-log1p38.0%
Simplified38.0%
Final simplification70.5%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* PI (* angle_m 0.005555555555555556)))
(t_1 (* 2.0 (* (+ b a) (- b a))))
(t_2 (* (/ angle_m 180.0) PI))
(t_3 (sin t_0)))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+38)
(*
(* (* t_3 (* 2.0 (+ b a))) (- b a))
(cos (/ 1.0 (/ 180.0 (* angle_m PI)))))
(if (<= (/ angle_m 180.0) 5e+108)
(* t_1 (sin (* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 1e+133)
(* (* t_1 (sin t_2)) (cos (expm1 (log1p t_0))))
(if (<= (/ angle_m 180.0) 1e+200)
(* t_1 (sin (pow (cbrt t_0) 3.0)))
(* (cos t_2) (sqrt (pow (* t_3 t_1) 2.0))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = (angle_m / 180.0) * ((double) M_PI);
double t_3 = sin(t_0);
double tmp;
if ((angle_m / 180.0) <= 2e+38) {
tmp = ((t_3 * (2.0 * (b + a))) * (b - a)) * cos((1.0 / (180.0 / (angle_m * ((double) M_PI)))));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * sin((0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 1e+133) {
tmp = (t_1 * sin(t_2)) * cos(expm1(log1p(t_0)));
} else if ((angle_m / 180.0) <= 1e+200) {
tmp = t_1 * sin(pow(cbrt(t_0), 3.0));
} else {
tmp = cos(t_2) * sqrt(pow((t_3 * t_1), 2.0));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = Math.PI * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = (angle_m / 180.0) * Math.PI;
double t_3 = Math.sin(t_0);
double tmp;
if ((angle_m / 180.0) <= 2e+38) {
tmp = ((t_3 * (2.0 * (b + a))) * (b - a)) * Math.cos((1.0 / (180.0 / (angle_m * Math.PI))));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * Math.sin((0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 1e+133) {
tmp = (t_1 * Math.sin(t_2)) * Math.cos(Math.expm1(Math.log1p(t_0)));
} else if ((angle_m / 180.0) <= 1e+200) {
tmp = t_1 * Math.sin(Math.pow(Math.cbrt(t_0), 3.0));
} else {
tmp = Math.cos(t_2) * Math.sqrt(Math.pow((t_3 * t_1), 2.0));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(pi * Float64(angle_m * 0.005555555555555556)) t_1 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_2 = Float64(Float64(angle_m / 180.0) * pi) t_3 = sin(t_0) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+38) tmp = Float64(Float64(Float64(t_3 * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(1.0 / Float64(180.0 / Float64(angle_m * pi))))); elseif (Float64(angle_m / 180.0) <= 5e+108) tmp = Float64(t_1 * sin(Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 1e+133) tmp = Float64(Float64(t_1 * sin(t_2)) * cos(expm1(log1p(t_0)))); elseif (Float64(angle_m / 180.0) <= 1e+200) tmp = Float64(t_1 * sin((cbrt(t_0) ^ 3.0))); else tmp = Float64(cos(t_2) * sqrt((Float64(t_3 * t_1) ^ 2.0))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]}, Block[{t$95$3 = N[Sin[t$95$0], $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+38], N[(N[(N[(t$95$3 * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(1.0 / N[(180.0 / N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+108], N[(t$95$1 * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 1e+133], N[(N[(t$95$1 * N[Sin[t$95$2], $MachinePrecision]), $MachinePrecision] * N[Cos[N[(Exp[N[Log[1 + t$95$0], $MachinePrecision]] - 1), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 1e+200], N[(t$95$1 * N[Sin[N[Power[N[Power[t$95$0, 1/3], $MachinePrecision], 3.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Cos[t$95$2], $MachinePrecision] * N[Sqrt[N[Power[N[(t$95$3 * t$95$1), $MachinePrecision], 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]]), $MachinePrecision]]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
t_1 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_2 := \frac{angle_m}{180} \cdot \pi\\
t_3 := \sin t_0\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+38}:\\
\;\;\;\;\left(\left(t_3 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(\frac{1}{\frac{180}{angle_m \cdot \pi}}\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+108}:\\
\;\;\;\;t_1 \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 10^{+133}:\\
\;\;\;\;\left(t_1 \cdot \sin t_2\right) \cdot \cos \left(\mathsf{expm1}\left(\mathsf{log1p}\left(t_0\right)\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 10^{+200}:\\
\;\;\;\;t_1 \cdot \sin \left({\left(\sqrt[3]{t_0}\right)}^{3}\right)\\
\mathbf{else}:\\
\;\;\;\;\cos t_2 \cdot \sqrt{{\left(t_3 \cdot t_1\right)}^{2}}\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 1.99999999999999995e38Initial program 64.3%
add-sqr-sqrt32.2%
sqrt-unprod30.8%
pow230.8%
*-commutative30.8%
div-inv30.8%
metadata-eval30.8%
Applied egg-rr30.8%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.7%
Applied egg-rr75.7%
associate-*r/76.2%
clear-num76.6%
Applied egg-rr76.6%
if 1.99999999999999995e38 < (/.f64 angle 180) < 4.99999999999999991e108Initial program 26.3%
unpow226.3%
unpow226.3%
difference-of-squares31.6%
Applied egg-rr31.6%
Taylor expanded in angle around 0 25.8%
Taylor expanded in angle around 0 38.7%
if 4.99999999999999991e108 < (/.f64 angle 180) < 1e133Initial program 55.0%
unpow255.0%
unpow255.0%
difference-of-squares55.0%
Applied egg-rr55.0%
div-inv55.0%
metadata-eval55.0%
expm1-log1p-u67.4%
Applied egg-rr67.4%
if 1e133 < (/.f64 angle 180) < 9.9999999999999997e199Initial program 19.7%
unpow219.7%
unpow219.7%
difference-of-squares19.7%
Applied egg-rr19.7%
Taylor expanded in angle around 0 22.0%
div-inv22.0%
metadata-eval22.0%
add-cube-cbrt32.2%
pow329.9%
Applied egg-rr29.9%
if 9.9999999999999997e199 < (/.f64 angle 180) Initial program 21.7%
add-sqr-sqrt10.9%
sqrt-unprod34.8%
pow234.8%
*-commutative34.8%
div-inv34.8%
metadata-eval34.8%
Applied egg-rr34.8%
unpow221.7%
unpow221.7%
difference-of-squares21.8%
Applied egg-rr39.4%
Final simplification68.8%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* 2.0 (* (+ b a) (- b a))))
(t_1 (sin (* PI (* angle_m 0.005555555555555556)))))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+41)
(*
(* (* t_1 (* 2.0 (+ b a))) (- b a))
(cos (* angle_m (/ (cbrt (pow PI 3.0)) 180.0))))
(if (<= (/ angle_m 180.0) 4e+105)
(*
t_0
(+
(* -2.8577960676726107e-8 (* (pow PI 3.0) (pow angle_m 3.0)))
(* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 5e+122)
(* t_0 (sqrt (pow t_1 2.0)))
(*
(cos (* (/ angle_m 180.0) PI))
(*
t_0
(sin
(*
(* (cbrt angle_m) (* PI 0.005555555555555556))
(pow angle_m 0.6666666666666666)))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = sin((((double) M_PI) * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+41) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (cbrt(pow(((double) M_PI), 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (pow(((double) M_PI), 3.0) * pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 5e+122) {
tmp = t_0 * sqrt(pow(t_1, 2.0));
} else {
tmp = cos(((angle_m / 180.0) * ((double) M_PI))) * (t_0 * sin(((cbrt(angle_m) * (((double) M_PI) * 0.005555555555555556)) * pow(angle_m, 0.6666666666666666))));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = Math.sin((Math.PI * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+41) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * Math.cos((angle_m * (Math.cbrt(Math.pow(Math.PI, 3.0)) / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (Math.pow(Math.PI, 3.0) * Math.pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 5e+122) {
tmp = t_0 * Math.sqrt(Math.pow(t_1, 2.0));
} else {
tmp = Math.cos(((angle_m / 180.0) * Math.PI)) * (t_0 * Math.sin(((Math.cbrt(angle_m) * (Math.PI * 0.005555555555555556)) * Math.pow(angle_m, 0.6666666666666666))));
}
return angle_s * tmp;
}
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_1 = sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+41) tmp = Float64(Float64(Float64(t_1 * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(angle_m * Float64(cbrt((pi ^ 3.0)) / 180.0)))); elseif (Float64(angle_m / 180.0) <= 4e+105) tmp = Float64(t_0 * Float64(Float64(-2.8577960676726107e-8 * Float64((pi ^ 3.0) * (angle_m ^ 3.0))) + Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 5e+122) tmp = Float64(t_0 * sqrt((t_1 ^ 2.0))); else tmp = Float64(cos(Float64(Float64(angle_m / 180.0) * pi)) * Float64(t_0 * sin(Float64(Float64(cbrt(angle_m) * Float64(pi * 0.005555555555555556)) * (angle_m ^ 0.6666666666666666))))); end return Float64(angle_s * tmp) end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+41], N[(N[(N[(t$95$1 * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(N[Power[N[Power[Pi, 3.0], $MachinePrecision], 1/3], $MachinePrecision] / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 4e+105], N[(t$95$0 * N[(N[(-2.8577960676726107e-8 * N[(N[Power[Pi, 3.0], $MachinePrecision] * N[Power[angle$95$m, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+122], N[(t$95$0 * N[Sqrt[N[Power[t$95$1, 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision] * N[(t$95$0 * N[Sin[N[(N[(N[Power[angle$95$m, 1/3], $MachinePrecision] * N[(Pi * 0.005555555555555556), $MachinePrecision]), $MachinePrecision] * N[Power[angle$95$m, 0.6666666666666666], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_1 := \sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+41}:\\
\;\;\;\;\left(\left(t_1 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(angle_m \cdot \frac{\sqrt[3]{{\pi}^{3}}}{180}\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 4 \cdot 10^{+105}:\\
\;\;\;\;t_0 \cdot \left(-2.8577960676726107 \cdot 10^{-8} \cdot \left({\pi}^{3} \cdot {angle_m}^{3}\right) + 0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+122}:\\
\;\;\;\;t_0 \cdot \sqrt{{t_1}^{2}}\\
\mathbf{else}:\\
\;\;\;\;\cos \left(\frac{angle_m}{180} \cdot \pi\right) \cdot \left(t_0 \cdot \sin \left(\left(\sqrt[3]{angle_m} \cdot \left(\pi \cdot 0.005555555555555556\right)\right) \cdot {angle_m}^{0.6666666666666666}\right)\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 2.00000000000000001e41Initial program 64.3%
add-sqr-sqrt32.2%
sqrt-unprod30.8%
pow230.8%
*-commutative30.8%
div-inv30.8%
metadata-eval30.8%
Applied egg-rr30.8%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.7%
Applied egg-rr75.7%
associate-*r/76.2%
associate-/l*76.3%
Applied egg-rr76.3%
associate-/r/77.5%
Simplified77.5%
add-cbrt-cube78.4%
pow378.4%
Applied egg-rr78.4%
if 2.00000000000000001e41 < (/.f64 angle 180) < 3.9999999999999998e105Initial program 22.7%
unpow222.7%
unpow222.7%
difference-of-squares29.0%
Applied egg-rr29.0%
Taylor expanded in angle around 0 29.7%
Taylor expanded in angle around 0 45.4%
if 3.9999999999999998e105 < (/.f64 angle 180) < 4.99999999999999989e122Initial program 72.7%
unpow272.7%
unpow272.7%
difference-of-squares72.7%
Applied egg-rr72.7%
Taylor expanded in angle around 0 19.2%
add-sqr-sqrt16.7%
sqrt-unprod67.1%
pow267.1%
div-inv67.1%
metadata-eval67.1%
Applied egg-rr67.1%
if 4.99999999999999989e122 < (/.f64 angle 180) Initial program 22.2%
unpow222.2%
unpow222.2%
difference-of-squares22.2%
Applied egg-rr22.2%
associate-*r/21.9%
Applied egg-rr21.9%
div-inv23.3%
*-commutative23.3%
metadata-eval23.3%
associate-*r*22.2%
add-cube-cbrt20.4%
associate-*l*29.9%
cbrt-unprod1.3%
pow21.3%
Applied egg-rr1.3%
*-commutative1.3%
*-commutative1.3%
Simplified1.3%
pow1/37.3%
pow-pow35.7%
metadata-eval35.7%
Applied egg-rr35.7%
Final simplification70.2%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* PI (* angle_m 0.005555555555555556))) (t_1 (* 2.0 (+ b a))))
(*
angle_s
(if (<= b 3.9e-81)
(*
(* (- b a) (* t_1 (sin (pow (sqrt t_0) 2.0))))
(cos (* angle_m (/ PI 180.0))))
(if (<= b 6.9e+220)
(*
(* (* (sin t_0) t_1) (- b a))
(fabs (cos (* angle_m (* PI 0.005555555555555556)))))
(*
(cos (* (/ angle_m 180.0) PI))
(*
(- b a)
(* t_1 (sin (/ (sqrt PI) (/ (/ 180.0 angle_m) (sqrt PI))))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * (b + a);
double tmp;
if (b <= 3.9e-81) {
tmp = ((b - a) * (t_1 * sin(pow(sqrt(t_0), 2.0)))) * cos((angle_m * (((double) M_PI) / 180.0)));
} else if (b <= 6.9e+220) {
tmp = ((sin(t_0) * t_1) * (b - a)) * fabs(cos((angle_m * (((double) M_PI) * 0.005555555555555556))));
} else {
tmp = cos(((angle_m / 180.0) * ((double) M_PI))) * ((b - a) * (t_1 * sin((sqrt(((double) M_PI)) / ((180.0 / angle_m) / sqrt(((double) M_PI)))))));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = Math.PI * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * (b + a);
double tmp;
if (b <= 3.9e-81) {
tmp = ((b - a) * (t_1 * Math.sin(Math.pow(Math.sqrt(t_0), 2.0)))) * Math.cos((angle_m * (Math.PI / 180.0)));
} else if (b <= 6.9e+220) {
tmp = ((Math.sin(t_0) * t_1) * (b - a)) * Math.abs(Math.cos((angle_m * (Math.PI * 0.005555555555555556))));
} else {
tmp = Math.cos(((angle_m / 180.0) * Math.PI)) * ((b - a) * (t_1 * Math.sin((Math.sqrt(Math.PI) / ((180.0 / angle_m) / Math.sqrt(Math.PI))))));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = math.pi * (angle_m * 0.005555555555555556) t_1 = 2.0 * (b + a) tmp = 0 if b <= 3.9e-81: tmp = ((b - a) * (t_1 * math.sin(math.pow(math.sqrt(t_0), 2.0)))) * math.cos((angle_m * (math.pi / 180.0))) elif b <= 6.9e+220: tmp = ((math.sin(t_0) * t_1) * (b - a)) * math.fabs(math.cos((angle_m * (math.pi * 0.005555555555555556)))) else: tmp = math.cos(((angle_m / 180.0) * math.pi)) * ((b - a) * (t_1 * math.sin((math.sqrt(math.pi) / ((180.0 / angle_m) / math.sqrt(math.pi)))))) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(pi * Float64(angle_m * 0.005555555555555556)) t_1 = Float64(2.0 * Float64(b + a)) tmp = 0.0 if (b <= 3.9e-81) tmp = Float64(Float64(Float64(b - a) * Float64(t_1 * sin((sqrt(t_0) ^ 2.0)))) * cos(Float64(angle_m * Float64(pi / 180.0)))); elseif (b <= 6.9e+220) tmp = Float64(Float64(Float64(sin(t_0) * t_1) * Float64(b - a)) * abs(cos(Float64(angle_m * Float64(pi * 0.005555555555555556))))); else tmp = Float64(cos(Float64(Float64(angle_m / 180.0) * pi)) * Float64(Float64(b - a) * Float64(t_1 * sin(Float64(sqrt(pi) / Float64(Float64(180.0 / angle_m) / sqrt(pi))))))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = pi * (angle_m * 0.005555555555555556); t_1 = 2.0 * (b + a); tmp = 0.0; if (b <= 3.9e-81) tmp = ((b - a) * (t_1 * sin((sqrt(t_0) ^ 2.0)))) * cos((angle_m * (pi / 180.0))); elseif (b <= 6.9e+220) tmp = ((sin(t_0) * t_1) * (b - a)) * abs(cos((angle_m * (pi * 0.005555555555555556)))); else tmp = cos(((angle_m / 180.0) * pi)) * ((b - a) * (t_1 * sin((sqrt(pi) / ((180.0 / angle_m) / sqrt(pi)))))); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[b, 3.9e-81], N[(N[(N[(b - a), $MachinePrecision] * N[(t$95$1 * N[Sin[N[Power[N[Sqrt[t$95$0], $MachinePrecision], 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[b, 6.9e+220], N[(N[(N[(N[Sin[t$95$0], $MachinePrecision] * t$95$1), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Abs[N[Cos[N[(angle$95$m * N[(Pi * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision] * N[(N[(b - a), $MachinePrecision] * N[(t$95$1 * N[Sin[N[(N[Sqrt[Pi], $MachinePrecision] / N[(N[(180.0 / angle$95$m), $MachinePrecision] / N[Sqrt[Pi], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
t_1 := 2 \cdot \left(b + a\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;b \leq 3.9 \cdot 10^{-81}:\\
\;\;\;\;\left(\left(b - a\right) \cdot \left(t_1 \cdot \sin \left({\left(\sqrt{t_0}\right)}^{2}\right)\right)\right) \cdot \cos \left(angle_m \cdot \frac{\pi}{180}\right)\\
\mathbf{elif}\;b \leq 6.9 \cdot 10^{+220}:\\
\;\;\;\;\left(\left(\sin t_0 \cdot t_1\right) \cdot \left(b - a\right)\right) \cdot \left|\cos \left(angle_m \cdot \left(\pi \cdot 0.005555555555555556\right)\right)\right|\\
\mathbf{else}:\\
\;\;\;\;\cos \left(\frac{angle_m}{180} \cdot \pi\right) \cdot \left(\left(b - a\right) \cdot \left(t_1 \cdot \sin \left(\frac{\sqrt{\pi}}{\frac{\frac{180}{angle_m}}{\sqrt{\pi}}}\right)\right)\right)\\
\end{array}
\end{array}
\end{array}
if b < 3.89999999999999985e-81Initial program 63.8%
add-sqr-sqrt35.4%
sqrt-unprod34.8%
pow234.8%
*-commutative34.8%
div-inv34.8%
metadata-eval34.8%
Applied egg-rr34.8%
sqrt-pow162.2%
metadata-eval62.2%
pow162.2%
unpow262.2%
unpow262.2%
difference-of-squares62.2%
associate-*r*62.2%
associate-*r*68.0%
Applied egg-rr68.0%
associate-*r/67.1%
associate-/l*68.3%
Applied egg-rr68.3%
associate-/r/67.4%
Simplified67.4%
rem-cbrt-cube29.5%
add-sqr-sqrt18.2%
pow218.2%
rem-cbrt-cube32.7%
Applied egg-rr32.7%
if 3.89999999999999985e-81 < b < 6.9000000000000004e220Initial program 40.8%
add-sqr-sqrt13.2%
sqrt-unprod17.0%
pow217.0%
*-commutative17.0%
div-inv17.1%
metadata-eval17.1%
Applied egg-rr17.1%
sqrt-pow138.8%
metadata-eval38.8%
pow138.8%
unpow238.8%
unpow238.8%
difference-of-squares42.2%
associate-*r*42.2%
associate-*r*58.1%
Applied egg-rr58.1%
associate-*r/63.4%
associate-/l*59.8%
Applied egg-rr59.8%
associate-/r/64.0%
Simplified64.0%
associate-*l/63.4%
div-inv61.9%
metadata-eval61.9%
associate-*r*64.0%
add-sqr-sqrt56.3%
sqrt-unprod62.1%
pow262.1%
Applied egg-rr62.1%
unpow262.1%
rem-sqrt-square62.1%
associate-*r*62.1%
*-commutative62.1%
associate-*l*62.1%
Simplified62.1%
if 6.9000000000000004e220 < b Initial program 32.1%
add-sqr-sqrt16.1%
sqrt-unprod21.6%
pow221.6%
*-commutative21.6%
div-inv21.6%
metadata-eval21.6%
Applied egg-rr21.6%
sqrt-pow121.6%
metadata-eval21.6%
pow121.6%
unpow221.6%
unpow221.6%
difference-of-squares48.4%
associate-*r*48.4%
associate-*r*58.1%
Applied egg-rr58.1%
associate-*r*52.9%
metadata-eval52.9%
div-inv52.9%
associate-/l*68.7%
add-sqr-sqrt52.9%
associate-/l*68.7%
Applied egg-rr68.7%
Final simplification42.2%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* PI (* angle_m 0.005555555555555556))) (t_1 (* 2.0 (+ b a))))
(*
angle_s
(if (<= b 2e-81)
(*
(* (- b a) (* t_1 (sin (pow (sqrt t_0) 2.0))))
(cos (* angle_m (/ PI 180.0))))
(if (<= b 1.8e+220)
(*
(* (* (sin t_0) t_1) (- b a))
(fabs (cos (* angle_m (* PI 0.005555555555555556)))))
(*
(cos (* (/ angle_m 180.0) PI))
(* (- b a) (* t_1 (sin (/ 1.0 (/ (/ 180.0 PI) angle_m)))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = ((double) M_PI) * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * (b + a);
double tmp;
if (b <= 2e-81) {
tmp = ((b - a) * (t_1 * sin(pow(sqrt(t_0), 2.0)))) * cos((angle_m * (((double) M_PI) / 180.0)));
} else if (b <= 1.8e+220) {
tmp = ((sin(t_0) * t_1) * (b - a)) * fabs(cos((angle_m * (((double) M_PI) * 0.005555555555555556))));
} else {
tmp = cos(((angle_m / 180.0) * ((double) M_PI))) * ((b - a) * (t_1 * sin((1.0 / ((180.0 / ((double) M_PI)) / angle_m)))));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = Math.PI * (angle_m * 0.005555555555555556);
double t_1 = 2.0 * (b + a);
double tmp;
if (b <= 2e-81) {
tmp = ((b - a) * (t_1 * Math.sin(Math.pow(Math.sqrt(t_0), 2.0)))) * Math.cos((angle_m * (Math.PI / 180.0)));
} else if (b <= 1.8e+220) {
tmp = ((Math.sin(t_0) * t_1) * (b - a)) * Math.abs(Math.cos((angle_m * (Math.PI * 0.005555555555555556))));
} else {
tmp = Math.cos(((angle_m / 180.0) * Math.PI)) * ((b - a) * (t_1 * Math.sin((1.0 / ((180.0 / Math.PI) / angle_m)))));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = math.pi * (angle_m * 0.005555555555555556) t_1 = 2.0 * (b + a) tmp = 0 if b <= 2e-81: tmp = ((b - a) * (t_1 * math.sin(math.pow(math.sqrt(t_0), 2.0)))) * math.cos((angle_m * (math.pi / 180.0))) elif b <= 1.8e+220: tmp = ((math.sin(t_0) * t_1) * (b - a)) * math.fabs(math.cos((angle_m * (math.pi * 0.005555555555555556)))) else: tmp = math.cos(((angle_m / 180.0) * math.pi)) * ((b - a) * (t_1 * math.sin((1.0 / ((180.0 / math.pi) / angle_m))))) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(pi * Float64(angle_m * 0.005555555555555556)) t_1 = Float64(2.0 * Float64(b + a)) tmp = 0.0 if (b <= 2e-81) tmp = Float64(Float64(Float64(b - a) * Float64(t_1 * sin((sqrt(t_0) ^ 2.0)))) * cos(Float64(angle_m * Float64(pi / 180.0)))); elseif (b <= 1.8e+220) tmp = Float64(Float64(Float64(sin(t_0) * t_1) * Float64(b - a)) * abs(cos(Float64(angle_m * Float64(pi * 0.005555555555555556))))); else tmp = Float64(cos(Float64(Float64(angle_m / 180.0) * pi)) * Float64(Float64(b - a) * Float64(t_1 * sin(Float64(1.0 / Float64(Float64(180.0 / pi) / angle_m)))))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = pi * (angle_m * 0.005555555555555556); t_1 = 2.0 * (b + a); tmp = 0.0; if (b <= 2e-81) tmp = ((b - a) * (t_1 * sin((sqrt(t_0) ^ 2.0)))) * cos((angle_m * (pi / 180.0))); elseif (b <= 1.8e+220) tmp = ((sin(t_0) * t_1) * (b - a)) * abs(cos((angle_m * (pi * 0.005555555555555556)))); else tmp = cos(((angle_m / 180.0) * pi)) * ((b - a) * (t_1 * sin((1.0 / ((180.0 / pi) / angle_m))))); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[b, 2e-81], N[(N[(N[(b - a), $MachinePrecision] * N[(t$95$1 * N[Sin[N[Power[N[Sqrt[t$95$0], $MachinePrecision], 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[b, 1.8e+220], N[(N[(N[(N[Sin[t$95$0], $MachinePrecision] * t$95$1), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Abs[N[Cos[N[(angle$95$m * N[(Pi * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision] * N[(N[(b - a), $MachinePrecision] * N[(t$95$1 * N[Sin[N[(1.0 / N[(N[(180.0 / Pi), $MachinePrecision] / angle$95$m), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\\
t_1 := 2 \cdot \left(b + a\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;b \leq 2 \cdot 10^{-81}:\\
\;\;\;\;\left(\left(b - a\right) \cdot \left(t_1 \cdot \sin \left({\left(\sqrt{t_0}\right)}^{2}\right)\right)\right) \cdot \cos \left(angle_m \cdot \frac{\pi}{180}\right)\\
\mathbf{elif}\;b \leq 1.8 \cdot 10^{+220}:\\
\;\;\;\;\left(\left(\sin t_0 \cdot t_1\right) \cdot \left(b - a\right)\right) \cdot \left|\cos \left(angle_m \cdot \left(\pi \cdot 0.005555555555555556\right)\right)\right|\\
\mathbf{else}:\\
\;\;\;\;\cos \left(\frac{angle_m}{180} \cdot \pi\right) \cdot \left(\left(b - a\right) \cdot \left(t_1 \cdot \sin \left(\frac{1}{\frac{\frac{180}{\pi}}{angle_m}}\right)\right)\right)\\
\end{array}
\end{array}
\end{array}
if b < 1.9999999999999999e-81Initial program 63.8%
add-sqr-sqrt35.4%
sqrt-unprod34.8%
pow234.8%
*-commutative34.8%
div-inv34.8%
metadata-eval34.8%
Applied egg-rr34.8%
sqrt-pow162.2%
metadata-eval62.2%
pow162.2%
unpow262.2%
unpow262.2%
difference-of-squares62.2%
associate-*r*62.2%
associate-*r*68.0%
Applied egg-rr68.0%
associate-*r/67.1%
associate-/l*68.3%
Applied egg-rr68.3%
associate-/r/67.4%
Simplified67.4%
rem-cbrt-cube29.5%
add-sqr-sqrt18.2%
pow218.2%
rem-cbrt-cube32.7%
Applied egg-rr32.7%
if 1.9999999999999999e-81 < b < 1.80000000000000009e220Initial program 40.8%
add-sqr-sqrt13.2%
sqrt-unprod17.0%
pow217.0%
*-commutative17.0%
div-inv17.1%
metadata-eval17.1%
Applied egg-rr17.1%
sqrt-pow138.8%
metadata-eval38.8%
pow138.8%
unpow238.8%
unpow238.8%
difference-of-squares42.2%
associate-*r*42.2%
associate-*r*58.1%
Applied egg-rr58.1%
associate-*r/63.4%
associate-/l*59.8%
Applied egg-rr59.8%
associate-/r/64.0%
Simplified64.0%
associate-*l/63.4%
div-inv61.9%
metadata-eval61.9%
associate-*r*64.0%
add-sqr-sqrt56.3%
sqrt-unprod62.1%
pow262.1%
Applied egg-rr62.1%
unpow262.1%
rem-sqrt-square62.1%
associate-*r*62.1%
*-commutative62.1%
associate-*l*62.1%
Simplified62.1%
if 1.80000000000000009e220 < b Initial program 32.1%
add-sqr-sqrt16.1%
sqrt-unprod21.6%
pow221.6%
*-commutative21.6%
div-inv21.6%
metadata-eval21.6%
Applied egg-rr21.6%
sqrt-pow121.6%
metadata-eval21.6%
pow121.6%
unpow221.6%
unpow221.6%
difference-of-squares48.4%
associate-*r*48.4%
associate-*r*58.1%
Applied egg-rr58.1%
associate-*r*52.9%
metadata-eval52.9%
div-inv52.9%
clear-num47.6%
associate-/r*63.4%
Applied egg-rr63.4%
Final simplification41.8%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* 2.0 (* (+ b a) (- b a))))
(t_1 (sin (* PI (* angle_m 0.005555555555555556)))))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+27)
(* (* (* t_1 (* 2.0 (+ b a))) (- b a)) (cos (* angle_m (/ PI 180.0))))
(if (<= (/ angle_m 180.0) 4e+105)
(*
t_0
(+
(* -2.8577960676726107e-8 (* (pow PI 3.0) (pow angle_m 3.0)))
(* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 2e+133)
(* t_0 (sqrt (pow t_1 2.0)))
(if (<= (/ angle_m 180.0) 2e+236)
(* t_0 (sin (/ (* angle_m PI) 180.0)))
(*
(* t_0 (sin (* (/ angle_m 180.0) PI)))
(+
1.0
(*
(* -1.54320987654321e-5 (pow angle_m 2.0))
(pow PI 2.0)))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = sin((((double) M_PI) * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+27) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (((double) M_PI) / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (pow(((double) M_PI), 3.0) * pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = t_0 * sqrt(pow(t_1, 2.0));
} else if ((angle_m / 180.0) <= 2e+236) {
tmp = t_0 * sin(((angle_m * ((double) M_PI)) / 180.0));
} else {
tmp = (t_0 * sin(((angle_m / 180.0) * ((double) M_PI)))) * (1.0 + ((-1.54320987654321e-5 * pow(angle_m, 2.0)) * pow(((double) M_PI), 2.0)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double t_1 = Math.sin((Math.PI * (angle_m * 0.005555555555555556)));
double tmp;
if ((angle_m / 180.0) <= 2e+27) {
tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * Math.cos((angle_m * (Math.PI / 180.0)));
} else if ((angle_m / 180.0) <= 4e+105) {
tmp = t_0 * ((-2.8577960676726107e-8 * (Math.pow(Math.PI, 3.0) * Math.pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = t_0 * Math.sqrt(Math.pow(t_1, 2.0));
} else if ((angle_m / 180.0) <= 2e+236) {
tmp = t_0 * Math.sin(((angle_m * Math.PI) / 180.0));
} else {
tmp = (t_0 * Math.sin(((angle_m / 180.0) * Math.PI))) * (1.0 + ((-1.54320987654321e-5 * Math.pow(angle_m, 2.0)) * Math.pow(Math.PI, 2.0)));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = 2.0 * ((b + a) * (b - a)) t_1 = math.sin((math.pi * (angle_m * 0.005555555555555556))) tmp = 0 if (angle_m / 180.0) <= 2e+27: tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * math.cos((angle_m * (math.pi / 180.0))) elif (angle_m / 180.0) <= 4e+105: tmp = t_0 * ((-2.8577960676726107e-8 * (math.pow(math.pi, 3.0) * math.pow(angle_m, 3.0))) + (0.005555555555555556 * (angle_m * math.pi))) elif (angle_m / 180.0) <= 2e+133: tmp = t_0 * math.sqrt(math.pow(t_1, 2.0)) elif (angle_m / 180.0) <= 2e+236: tmp = t_0 * math.sin(((angle_m * math.pi) / 180.0)) else: tmp = (t_0 * math.sin(((angle_m / 180.0) * math.pi))) * (1.0 + ((-1.54320987654321e-5 * math.pow(angle_m, 2.0)) * math.pow(math.pi, 2.0))) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_1 = sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+27) tmp = Float64(Float64(Float64(t_1 * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(angle_m * Float64(pi / 180.0)))); elseif (Float64(angle_m / 180.0) <= 4e+105) tmp = Float64(t_0 * Float64(Float64(-2.8577960676726107e-8 * Float64((pi ^ 3.0) * (angle_m ^ 3.0))) + Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 2e+133) tmp = Float64(t_0 * sqrt((t_1 ^ 2.0))); elseif (Float64(angle_m / 180.0) <= 2e+236) tmp = Float64(t_0 * sin(Float64(Float64(angle_m * pi) / 180.0))); else tmp = Float64(Float64(t_0 * sin(Float64(Float64(angle_m / 180.0) * pi))) * Float64(1.0 + Float64(Float64(-1.54320987654321e-5 * (angle_m ^ 2.0)) * (pi ^ 2.0)))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = 2.0 * ((b + a) * (b - a)); t_1 = sin((pi * (angle_m * 0.005555555555555556))); tmp = 0.0; if ((angle_m / 180.0) <= 2e+27) tmp = ((t_1 * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (pi / 180.0))); elseif ((angle_m / 180.0) <= 4e+105) tmp = t_0 * ((-2.8577960676726107e-8 * ((pi ^ 3.0) * (angle_m ^ 3.0))) + (0.005555555555555556 * (angle_m * pi))); elseif ((angle_m / 180.0) <= 2e+133) tmp = t_0 * sqrt((t_1 ^ 2.0)); elseif ((angle_m / 180.0) <= 2e+236) tmp = t_0 * sin(((angle_m * pi) / 180.0)); else tmp = (t_0 * sin(((angle_m / 180.0) * pi))) * (1.0 + ((-1.54320987654321e-5 * (angle_m ^ 2.0)) * (pi ^ 2.0))); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+27], N[(N[(N[(t$95$1 * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 4e+105], N[(t$95$0 * N[(N[(-2.8577960676726107e-8 * N[(N[Power[Pi, 3.0], $MachinePrecision] * N[Power[angle$95$m, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+133], N[(t$95$0 * N[Sqrt[N[Power[t$95$1, 2.0], $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+236], N[(t$95$0 * N[Sin[N[(N[(angle$95$m * Pi), $MachinePrecision] / 180.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(N[(t$95$0 * N[Sin[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] * N[(1.0 + N[(N[(-1.54320987654321e-5 * N[Power[angle$95$m, 2.0], $MachinePrecision]), $MachinePrecision] * N[Power[Pi, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_1 := \sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+27}:\\
\;\;\;\;\left(\left(t_1 \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(angle_m \cdot \frac{\pi}{180}\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 4 \cdot 10^{+105}:\\
\;\;\;\;t_0 \cdot \left(-2.8577960676726107 \cdot 10^{-8} \cdot \left({\pi}^{3} \cdot {angle_m}^{3}\right) + 0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+133}:\\
\;\;\;\;t_0 \cdot \sqrt{{t_1}^{2}}\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+236}:\\
\;\;\;\;t_0 \cdot \sin \left(\frac{angle_m \cdot \pi}{180}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(t_0 \cdot \sin \left(\frac{angle_m}{180} \cdot \pi\right)\right) \cdot \left(1 + \left(-1.54320987654321 \cdot 10^{-5} \cdot {angle_m}^{2}\right) \cdot {\pi}^{2}\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 2e27Initial program 64.3%
add-sqr-sqrt32.4%
sqrt-unprod31.1%
pow231.1%
*-commutative31.1%
div-inv31.0%
metadata-eval31.0%
Applied egg-rr31.0%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.9%
Applied egg-rr75.9%
associate-*r/76.3%
associate-/l*76.6%
Applied egg-rr76.6%
associate-/r/77.7%
Simplified77.7%
if 2e27 < (/.f64 angle 180) < 3.9999999999999998e105Initial program 27.1%
unpow227.1%
unpow227.1%
difference-of-squares32.7%
Applied egg-rr32.7%
Taylor expanded in angle around 0 27.4%
Taylor expanded in angle around 0 46.2%
if 3.9999999999999998e105 < (/.f64 angle 180) < 2e133Initial program 52.4%
unpow252.4%
unpow252.4%
difference-of-squares52.4%
Applied egg-rr52.4%
Taylor expanded in angle around 0 24.3%
add-sqr-sqrt13.9%
sqrt-unprod50.5%
pow250.5%
div-inv50.5%
metadata-eval50.5%
Applied egg-rr50.5%
if 2e133 < (/.f64 angle 180) < 2.00000000000000011e236Initial program 17.3%
unpow217.3%
unpow217.3%
difference-of-squares17.3%
Applied egg-rr17.3%
associate-*r/23.9%
Applied egg-rr23.9%
Taylor expanded in angle around 0 47.6%
if 2.00000000000000011e236 < (/.f64 angle 180) Initial program 25.1%
unpow225.1%
unpow225.1%
difference-of-squares25.2%
Applied egg-rr25.2%
Taylor expanded in angle around 0 35.0%
associate-*r*35.0%
Simplified35.0%
Final simplification70.1%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* (/ angle_m 180.0) PI))
(t_1 (* 2.0 (* (+ b a) (- b a))))
(t_2 (* t_1 (sin (/ (* angle_m PI) 180.0)))))
(*
angle_s
(if (<= (/ angle_m 180.0) 5e+23)
(*
(cos (* angle_m (/ PI 180.0)))
(*
(- b a)
(* (* 2.0 (+ b a)) (sin (* 0.005555555555555556 (* angle_m PI))))))
(if (<= (/ angle_m 180.0) 2e+133)
(* (cos t_0) (* t_1 (sin t_0)))
(if (<= (/ angle_m 180.0) 2e+238)
t_2
(* t_2 (cos (/ PI (/ 180.0 angle_m))))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (angle_m / 180.0) * ((double) M_PI);
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = t_1 * sin(((angle_m * ((double) M_PI)) / 180.0));
double tmp;
if ((angle_m / 180.0) <= 5e+23) {
tmp = cos((angle_m * (((double) M_PI) / 180.0))) * ((b - a) * ((2.0 * (b + a)) * sin((0.005555555555555556 * (angle_m * ((double) M_PI))))));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = cos(t_0) * (t_1 * sin(t_0));
} else if ((angle_m / 180.0) <= 2e+238) {
tmp = t_2;
} else {
tmp = t_2 * cos((((double) M_PI) / (180.0 / angle_m)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (angle_m / 180.0) * Math.PI;
double t_1 = 2.0 * ((b + a) * (b - a));
double t_2 = t_1 * Math.sin(((angle_m * Math.PI) / 180.0));
double tmp;
if ((angle_m / 180.0) <= 5e+23) {
tmp = Math.cos((angle_m * (Math.PI / 180.0))) * ((b - a) * ((2.0 * (b + a)) * Math.sin((0.005555555555555556 * (angle_m * Math.PI)))));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = Math.cos(t_0) * (t_1 * Math.sin(t_0));
} else if ((angle_m / 180.0) <= 2e+238) {
tmp = t_2;
} else {
tmp = t_2 * Math.cos((Math.PI / (180.0 / angle_m)));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = (angle_m / 180.0) * math.pi t_1 = 2.0 * ((b + a) * (b - a)) t_2 = t_1 * math.sin(((angle_m * math.pi) / 180.0)) tmp = 0 if (angle_m / 180.0) <= 5e+23: tmp = math.cos((angle_m * (math.pi / 180.0))) * ((b - a) * ((2.0 * (b + a)) * math.sin((0.005555555555555556 * (angle_m * math.pi))))) elif (angle_m / 180.0) <= 2e+133: tmp = math.cos(t_0) * (t_1 * math.sin(t_0)) elif (angle_m / 180.0) <= 2e+238: tmp = t_2 else: tmp = t_2 * math.cos((math.pi / (180.0 / angle_m))) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(Float64(angle_m / 180.0) * pi) t_1 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) t_2 = Float64(t_1 * sin(Float64(Float64(angle_m * pi) / 180.0))) tmp = 0.0 if (Float64(angle_m / 180.0) <= 5e+23) tmp = Float64(cos(Float64(angle_m * Float64(pi / 180.0))) * Float64(Float64(b - a) * Float64(Float64(2.0 * Float64(b + a)) * sin(Float64(0.005555555555555556 * Float64(angle_m * pi)))))); elseif (Float64(angle_m / 180.0) <= 2e+133) tmp = Float64(cos(t_0) * Float64(t_1 * sin(t_0))); elseif (Float64(angle_m / 180.0) <= 2e+238) tmp = t_2; else tmp = Float64(t_2 * cos(Float64(pi / Float64(180.0 / angle_m)))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = (angle_m / 180.0) * pi; t_1 = 2.0 * ((b + a) * (b - a)); t_2 = t_1 * sin(((angle_m * pi) / 180.0)); tmp = 0.0; if ((angle_m / 180.0) <= 5e+23) tmp = cos((angle_m * (pi / 180.0))) * ((b - a) * ((2.0 * (b + a)) * sin((0.005555555555555556 * (angle_m * pi))))); elseif ((angle_m / 180.0) <= 2e+133) tmp = cos(t_0) * (t_1 * sin(t_0)); elseif ((angle_m / 180.0) <= 2e+238) tmp = t_2; else tmp = t_2 * cos((pi / (180.0 / angle_m))); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[(t$95$1 * N[Sin[N[(N[(angle$95$m * Pi), $MachinePrecision] / 180.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+23], N[(N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[(N[(b - a), $MachinePrecision] * N[(N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision] * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+133], N[(N[Cos[t$95$0], $MachinePrecision] * N[(t$95$1 * N[Sin[t$95$0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+238], t$95$2, N[(t$95$2 * N[Cos[N[(Pi / N[(180.0 / angle$95$m), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \frac{angle_m}{180} \cdot \pi\\
t_1 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
t_2 := t_1 \cdot \sin \left(\frac{angle_m \cdot \pi}{180}\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+23}:\\
\;\;\;\;\cos \left(angle_m \cdot \frac{\pi}{180}\right) \cdot \left(\left(b - a\right) \cdot \left(\left(2 \cdot \left(b + a\right)\right) \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+133}:\\
\;\;\;\;\cos t_0 \cdot \left(t_1 \cdot \sin t_0\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+238}:\\
\;\;\;\;t_2\\
\mathbf{else}:\\
\;\;\;\;t_2 \cdot \cos \left(\frac{\pi}{\frac{180}{angle_m}}\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 4.9999999999999999e23Initial program 64.4%
add-sqr-sqrt32.8%
sqrt-unprod31.4%
pow231.4%
*-commutative31.4%
div-inv31.4%
metadata-eval31.4%
Applied egg-rr31.4%
sqrt-pow162.0%
metadata-eval62.0%
pow162.0%
unpow262.0%
unpow262.0%
difference-of-squares64.6%
associate-*r*64.6%
associate-*r*75.6%
Applied egg-rr75.6%
associate-*r/76.1%
associate-/l*76.4%
Applied egg-rr76.4%
associate-/r/77.5%
Simplified77.5%
Taylor expanded in angle around inf 75.4%
if 4.9999999999999999e23 < (/.f64 angle 180) < 2e133Initial program 37.6%
unpow237.6%
unpow237.6%
difference-of-squares40.8%
Applied egg-rr40.8%
if 2e133 < (/.f64 angle 180) < 2.0000000000000001e238Initial program 27.0%
unpow227.0%
unpow227.0%
difference-of-squares27.0%
Applied egg-rr27.0%
associate-*r/27.0%
Applied egg-rr27.0%
Taylor expanded in angle around 0 47.9%
if 2.0000000000000001e238 < (/.f64 angle 180) Initial program 13.6%
unpow213.6%
unpow213.6%
difference-of-squares13.7%
Applied egg-rr13.7%
associate-*r/21.6%
Applied egg-rr21.6%
associate-*r/21.3%
associate-/l*13.6%
Applied egg-rr21.7%
Final simplification66.7%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* (+ b a) (- b a)))
(t_1 (* 2.0 t_0))
(t_2 (sin (* 0.005555555555555556 (* angle_m PI)))))
(*
angle_s
(if (<= (/ angle_m 180.0) 2e+15)
(* (cos (* (/ angle_m 180.0) PI)) (* (- b a) (* (* 2.0 (+ b a)) t_2)))
(if (<= (/ angle_m 180.0) 5e+108)
(* t_1 t_2)
(if (<= (/ angle_m 180.0) 2e+133)
(* 0.011111111111111112 (* angle_m (* PI t_0)))
(* t_1 (sin (/ (* angle_m PI) 180.0)))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (b + a) * (b - a);
double t_1 = 2.0 * t_0;
double t_2 = sin((0.005555555555555556 * (angle_m * ((double) M_PI))));
double tmp;
if ((angle_m / 180.0) <= 2e+15) {
tmp = cos(((angle_m / 180.0) * ((double) M_PI))) * ((b - a) * ((2.0 * (b + a)) * t_2));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * t_2;
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = 0.011111111111111112 * (angle_m * (((double) M_PI) * t_0));
} else {
tmp = t_1 * sin(((angle_m * ((double) M_PI)) / 180.0));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (b + a) * (b - a);
double t_1 = 2.0 * t_0;
double t_2 = Math.sin((0.005555555555555556 * (angle_m * Math.PI)));
double tmp;
if ((angle_m / 180.0) <= 2e+15) {
tmp = Math.cos(((angle_m / 180.0) * Math.PI)) * ((b - a) * ((2.0 * (b + a)) * t_2));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * t_2;
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = 0.011111111111111112 * (angle_m * (Math.PI * t_0));
} else {
tmp = t_1 * Math.sin(((angle_m * Math.PI) / 180.0));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = (b + a) * (b - a) t_1 = 2.0 * t_0 t_2 = math.sin((0.005555555555555556 * (angle_m * math.pi))) tmp = 0 if (angle_m / 180.0) <= 2e+15: tmp = math.cos(((angle_m / 180.0) * math.pi)) * ((b - a) * ((2.0 * (b + a)) * t_2)) elif (angle_m / 180.0) <= 5e+108: tmp = t_1 * t_2 elif (angle_m / 180.0) <= 2e+133: tmp = 0.011111111111111112 * (angle_m * (math.pi * t_0)) else: tmp = t_1 * math.sin(((angle_m * math.pi) / 180.0)) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(Float64(b + a) * Float64(b - a)) t_1 = Float64(2.0 * t_0) t_2 = sin(Float64(0.005555555555555556 * Float64(angle_m * pi))) tmp = 0.0 if (Float64(angle_m / 180.0) <= 2e+15) tmp = Float64(cos(Float64(Float64(angle_m / 180.0) * pi)) * Float64(Float64(b - a) * Float64(Float64(2.0 * Float64(b + a)) * t_2))); elseif (Float64(angle_m / 180.0) <= 5e+108) tmp = Float64(t_1 * t_2); elseif (Float64(angle_m / 180.0) <= 2e+133) tmp = Float64(0.011111111111111112 * Float64(angle_m * Float64(pi * t_0))); else tmp = Float64(t_1 * sin(Float64(Float64(angle_m * pi) / 180.0))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = (b + a) * (b - a); t_1 = 2.0 * t_0; t_2 = sin((0.005555555555555556 * (angle_m * pi))); tmp = 0.0; if ((angle_m / 180.0) <= 2e+15) tmp = cos(((angle_m / 180.0) * pi)) * ((b - a) * ((2.0 * (b + a)) * t_2)); elseif ((angle_m / 180.0) <= 5e+108) tmp = t_1 * t_2; elseif ((angle_m / 180.0) <= 2e+133) tmp = 0.011111111111111112 * (angle_m * (pi * t_0)); else tmp = t_1 * sin(((angle_m * pi) / 180.0)); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * t$95$0), $MachinePrecision]}, Block[{t$95$2 = N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+15], N[(N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision] * N[(N[(b - a), $MachinePrecision] * N[(N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+108], N[(t$95$1 * t$95$2), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+133], N[(0.011111111111111112 * N[(angle$95$m * N[(Pi * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(t$95$1 * N[Sin[N[(N[(angle$95$m * Pi), $MachinePrecision] / 180.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \left(b + a\right) \cdot \left(b - a\right)\\
t_1 := 2 \cdot t_0\\
t_2 := \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+15}:\\
\;\;\;\;\cos \left(\frac{angle_m}{180} \cdot \pi\right) \cdot \left(\left(b - a\right) \cdot \left(\left(2 \cdot \left(b + a\right)\right) \cdot t_2\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+108}:\\
\;\;\;\;t_1 \cdot t_2\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+133}:\\
\;\;\;\;0.011111111111111112 \cdot \left(angle_m \cdot \left(\pi \cdot t_0\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t_1 \cdot \sin \left(\frac{angle_m \cdot \pi}{180}\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 2e15Initial program 64.7%
add-sqr-sqrt32.9%
sqrt-unprod31.4%
pow231.4%
*-commutative31.4%
div-inv31.4%
metadata-eval31.4%
Applied egg-rr31.4%
sqrt-pow162.3%
metadata-eval62.3%
pow162.3%
unpow262.3%
unpow262.3%
difference-of-squares64.9%
associate-*r*64.9%
associate-*r*76.0%
Applied egg-rr76.0%
Taylor expanded in angle around 0 75.2%
if 2e15 < (/.f64 angle 180) < 4.99999999999999991e108Initial program 30.3%
unpow230.3%
unpow230.3%
difference-of-squares34.4%
Applied egg-rr34.4%
Taylor expanded in angle around 0 26.1%
Taylor expanded in angle around 0 32.1%
if 4.99999999999999991e108 < (/.f64 angle 180) < 2e133Initial program 55.0%
unpow255.0%
unpow255.0%
difference-of-squares55.0%
Applied egg-rr55.0%
Taylor expanded in angle around 0 31.6%
Taylor expanded in angle around 0 51.9%
if 2e133 < (/.f64 angle 180) Initial program 21.2%
unpow221.2%
unpow221.2%
difference-of-squares21.3%
Applied egg-rr21.3%
associate-*r/24.7%
Applied egg-rr24.7%
Taylor expanded in angle around 0 35.4%
Final simplification65.8%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* (+ b a) (- b a))) (t_1 (* 2.0 t_0)))
(*
angle_s
(if (<= (/ angle_m 180.0) 1e+33)
(*
(*
(* (sin (* PI (* angle_m 0.005555555555555556))) (* 2.0 (+ b a)))
(- b a))
(cos (* (/ angle_m 180.0) PI)))
(if (<= (/ angle_m 180.0) 5e+108)
(* t_1 (sin (* 0.005555555555555556 (* angle_m PI))))
(if (<= (/ angle_m 180.0) 2e+133)
(* 0.011111111111111112 (* angle_m (* PI t_0)))
(* t_1 (sin (/ (* angle_m PI) 180.0)))))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (b + a) * (b - a);
double t_1 = 2.0 * t_0;
double tmp;
if ((angle_m / 180.0) <= 1e+33) {
tmp = ((sin((((double) M_PI) * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * cos(((angle_m / 180.0) * ((double) M_PI)));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * sin((0.005555555555555556 * (angle_m * ((double) M_PI))));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = 0.011111111111111112 * (angle_m * (((double) M_PI) * t_0));
} else {
tmp = t_1 * sin(((angle_m * ((double) M_PI)) / 180.0));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = (b + a) * (b - a);
double t_1 = 2.0 * t_0;
double tmp;
if ((angle_m / 180.0) <= 1e+33) {
tmp = ((Math.sin((Math.PI * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * Math.cos(((angle_m / 180.0) * Math.PI));
} else if ((angle_m / 180.0) <= 5e+108) {
tmp = t_1 * Math.sin((0.005555555555555556 * (angle_m * Math.PI)));
} else if ((angle_m / 180.0) <= 2e+133) {
tmp = 0.011111111111111112 * (angle_m * (Math.PI * t_0));
} else {
tmp = t_1 * Math.sin(((angle_m * Math.PI) / 180.0));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = (b + a) * (b - a) t_1 = 2.0 * t_0 tmp = 0 if (angle_m / 180.0) <= 1e+33: tmp = ((math.sin((math.pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * math.cos(((angle_m / 180.0) * math.pi)) elif (angle_m / 180.0) <= 5e+108: tmp = t_1 * math.sin((0.005555555555555556 * (angle_m * math.pi))) elif (angle_m / 180.0) <= 2e+133: tmp = 0.011111111111111112 * (angle_m * (math.pi * t_0)) else: tmp = t_1 * math.sin(((angle_m * math.pi) / 180.0)) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(Float64(b + a) * Float64(b - a)) t_1 = Float64(2.0 * t_0) tmp = 0.0 if (Float64(angle_m / 180.0) <= 1e+33) tmp = Float64(Float64(Float64(sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(Float64(angle_m / 180.0) * pi))); elseif (Float64(angle_m / 180.0) <= 5e+108) tmp = Float64(t_1 * sin(Float64(0.005555555555555556 * Float64(angle_m * pi)))); elseif (Float64(angle_m / 180.0) <= 2e+133) tmp = Float64(0.011111111111111112 * Float64(angle_m * Float64(pi * t_0))); else tmp = Float64(t_1 * sin(Float64(Float64(angle_m * pi) / 180.0))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = (b + a) * (b - a); t_1 = 2.0 * t_0; tmp = 0.0; if ((angle_m / 180.0) <= 1e+33) tmp = ((sin((pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * cos(((angle_m / 180.0) * pi)); elseif ((angle_m / 180.0) <= 5e+108) tmp = t_1 * sin((0.005555555555555556 * (angle_m * pi))); elseif ((angle_m / 180.0) <= 2e+133) tmp = 0.011111111111111112 * (angle_m * (pi * t_0)); else tmp = t_1 * sin(((angle_m * pi) / 180.0)); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(2.0 * t$95$0), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 1e+33], N[(N[(N[(N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 5e+108], N[(t$95$1 * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[N[(angle$95$m / 180.0), $MachinePrecision], 2e+133], N[(0.011111111111111112 * N[(angle$95$m * N[(Pi * t$95$0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(t$95$1 * N[Sin[N[(N[(angle$95$m * Pi), $MachinePrecision] / 180.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := \left(b + a\right) \cdot \left(b - a\right)\\
t_1 := 2 \cdot t_0\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;\frac{angle_m}{180} \leq 10^{+33}:\\
\;\;\;\;\left(\left(\sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right) \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(\frac{angle_m}{180} \cdot \pi\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 5 \cdot 10^{+108}:\\
\;\;\;\;t_1 \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{elif}\;\frac{angle_m}{180} \leq 2 \cdot 10^{+133}:\\
\;\;\;\;0.011111111111111112 \cdot \left(angle_m \cdot \left(\pi \cdot t_0\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t_1 \cdot \sin \left(\frac{angle_m \cdot \pi}{180}\right)\\
\end{array}
\end{array}
\end{array}
if (/.f64 angle 180) < 9.9999999999999995e32Initial program 64.3%
add-sqr-sqrt32.2%
sqrt-unprod30.8%
pow230.8%
*-commutative30.8%
div-inv30.8%
metadata-eval30.8%
Applied egg-rr30.8%
sqrt-pow162.4%
metadata-eval62.4%
pow162.4%
unpow262.4%
unpow262.4%
difference-of-squares65.0%
associate-*r*65.0%
associate-*r*75.7%
Applied egg-rr75.7%
if 9.9999999999999995e32 < (/.f64 angle 180) < 4.99999999999999991e108Initial program 26.3%
unpow226.3%
unpow226.3%
difference-of-squares31.6%
Applied egg-rr31.6%
Taylor expanded in angle around 0 25.8%
Taylor expanded in angle around 0 38.7%
if 4.99999999999999991e108 < (/.f64 angle 180) < 2e133Initial program 55.0%
unpow255.0%
unpow255.0%
difference-of-squares55.0%
Applied egg-rr55.0%
Taylor expanded in angle around 0 31.6%
Taylor expanded in angle around 0 51.9%
if 2e133 < (/.f64 angle 180) Initial program 21.2%
unpow221.2%
unpow221.2%
difference-of-squares21.3%
Applied egg-rr21.3%
associate-*r/24.7%
Applied egg-rr24.7%
Taylor expanded in angle around 0 35.4%
Final simplification67.5%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(let* ((t_0 (* 2.0 (* (+ b a) (- b a)))))
(*
angle_s
(if (<= (pow a 2.0) 2e+291)
(* t_0 (sin (* 0.005555555555555556 (* angle_m PI))))
(* t_0 (sin (* (/ angle_m 180.0) PI)))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double tmp;
if (pow(a, 2.0) <= 2e+291) {
tmp = t_0 * sin((0.005555555555555556 * (angle_m * ((double) M_PI))));
} else {
tmp = t_0 * sin(((angle_m / 180.0) * ((double) M_PI)));
}
return angle_s * tmp;
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
double t_0 = 2.0 * ((b + a) * (b - a));
double tmp;
if (Math.pow(a, 2.0) <= 2e+291) {
tmp = t_0 * Math.sin((0.005555555555555556 * (angle_m * Math.PI)));
} else {
tmp = t_0 * Math.sin(((angle_m / 180.0) * Math.PI));
}
return angle_s * tmp;
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): t_0 = 2.0 * ((b + a) * (b - a)) tmp = 0 if math.pow(a, 2.0) <= 2e+291: tmp = t_0 * math.sin((0.005555555555555556 * (angle_m * math.pi))) else: tmp = t_0 * math.sin(((angle_m / 180.0) * math.pi)) return angle_s * tmp
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) t_0 = Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) tmp = 0.0 if ((a ^ 2.0) <= 2e+291) tmp = Float64(t_0 * sin(Float64(0.005555555555555556 * Float64(angle_m * pi)))); else tmp = Float64(t_0 * sin(Float64(Float64(angle_m / 180.0) * pi))); end return Float64(angle_s * tmp) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp_2 = code(angle_s, a, b, angle_m) t_0 = 2.0 * ((b + a) * (b - a)); tmp = 0.0; if ((a ^ 2.0) <= 2e+291) tmp = t_0 * sin((0.005555555555555556 * (angle_m * pi))); else tmp = t_0 * sin(((angle_m / 180.0) * pi)); end tmp_2 = angle_s * tmp; end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := Block[{t$95$0 = N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(angle$95$s * If[LessEqual[N[Power[a, 2.0], $MachinePrecision], 2e+291], N[(t$95$0 * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(t$95$0 * N[Sin[N[(N[(angle$95$m / 180.0), $MachinePrecision] * Pi), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
\begin{array}{l}
t_0 := 2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\\
angle_s \cdot \begin{array}{l}
\mathbf{if}\;{a}^{2} \leq 2 \cdot 10^{+291}:\\
\;\;\;\;t_0 \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t_0 \cdot \sin \left(\frac{angle_m}{180} \cdot \pi\right)\\
\end{array}
\end{array}
\end{array}
if (pow.f64 a 2) < 1.9999999999999999e291Initial program 59.3%
unpow259.3%
unpow259.3%
difference-of-squares59.3%
Applied egg-rr59.3%
Taylor expanded in angle around 0 56.8%
Taylor expanded in angle around 0 59.0%
if 1.9999999999999999e291 < (pow.f64 a 2) Initial program 47.5%
unpow247.5%
unpow247.5%
difference-of-squares56.5%
Applied egg-rr56.5%
Taylor expanded in angle around 0 55.6%
Final simplification58.1%
angle_m = (fabs.f64 angle)
angle_s = (copysign.f64 1 angle)
(FPCore (angle_s a b angle_m)
:precision binary64
(*
angle_s
(*
(*
(* (sin (* PI (* angle_m 0.005555555555555556))) (* 2.0 (+ b a)))
(- b a))
(cos (* angle_m (/ PI 180.0))))))angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
return angle_s * (((sin((((double) M_PI) * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (((double) M_PI) / 180.0))));
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
return angle_s * (((Math.sin((Math.PI * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * Math.cos((angle_m * (Math.PI / 180.0))));
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): return angle_s * (((math.sin((math.pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * math.cos((angle_m * (math.pi / 180.0))))
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) return Float64(angle_s * Float64(Float64(Float64(sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) * Float64(2.0 * Float64(b + a))) * Float64(b - a)) * cos(Float64(angle_m * Float64(pi / 180.0))))) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp = code(angle_s, a, b, angle_m) tmp = angle_s * (((sin((pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)) * cos((angle_m * (pi / 180.0)))); end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := N[(angle$95$s * N[(N[(N[(N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision] * N[Cos[N[(angle$95$m * N[(Pi / 180.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
angle_s \cdot \left(\left(\left(\sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right) \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right) \cdot \cos \left(angle_m \cdot \frac{\pi}{180}\right)\right)
\end{array}
Initial program 56.1%
add-sqr-sqrt28.9%
sqrt-unprod29.7%
pow229.7%
*-commutative29.7%
div-inv29.7%
metadata-eval29.7%
Applied egg-rr29.7%
sqrt-pow153.8%
metadata-eval53.8%
pow153.8%
unpow253.8%
unpow253.8%
difference-of-squares56.6%
associate-*r*56.6%
associate-*r*65.0%
Applied egg-rr65.0%
associate-*r/65.6%
associate-/l*64.8%
Applied egg-rr64.8%
associate-/r/66.3%
Simplified66.3%
Final simplification66.3%
angle_m = (fabs.f64 angle) angle_s = (copysign.f64 1 angle) (FPCore (angle_s a b angle_m) :precision binary64 (* angle_s (* (* 2.0 (* (+ b a) (- b a))) (sin (* 0.005555555555555556 (* angle_m PI))))))
angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((2.0 * ((b + a) * (b - a))) * sin((0.005555555555555556 * (angle_m * ((double) M_PI)))));
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((2.0 * ((b + a) * (b - a))) * Math.sin((0.005555555555555556 * (angle_m * Math.PI))));
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): return angle_s * ((2.0 * ((b + a) * (b - a))) * math.sin((0.005555555555555556 * (angle_m * math.pi))))
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) return Float64(angle_s * Float64(Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) * sin(Float64(0.005555555555555556 * Float64(angle_m * pi))))) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp = code(angle_s, a, b, angle_m) tmp = angle_s * ((2.0 * ((b + a) * (b - a))) * sin((0.005555555555555556 * (angle_m * pi)))); end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := N[(angle$95$s * N[(N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[N[(0.005555555555555556 * N[(angle$95$m * Pi), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
angle_s \cdot \left(\left(2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\right) \cdot \sin \left(0.005555555555555556 \cdot \left(angle_m \cdot \pi\right)\right)\right)
\end{array}
Initial program 56.1%
unpow256.1%
unpow256.1%
difference-of-squares58.5%
Applied egg-rr58.5%
Taylor expanded in angle around 0 56.5%
Taylor expanded in angle around 0 56.5%
Final simplification56.5%
angle_m = (fabs.f64 angle) angle_s = (copysign.f64 1 angle) (FPCore (angle_s a b angle_m) :precision binary64 (* angle_s (* (* 2.0 (* (+ b a) (- b a))) (sin (/ PI (/ 180.0 angle_m))))))
angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((2.0 * ((b + a) * (b - a))) * sin((((double) M_PI) / (180.0 / angle_m))));
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((2.0 * ((b + a) * (b - a))) * Math.sin((Math.PI / (180.0 / angle_m))));
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): return angle_s * ((2.0 * ((b + a) * (b - a))) * math.sin((math.pi / (180.0 / angle_m))))
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) return Float64(angle_s * Float64(Float64(2.0 * Float64(Float64(b + a) * Float64(b - a))) * sin(Float64(pi / Float64(180.0 / angle_m))))) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp = code(angle_s, a, b, angle_m) tmp = angle_s * ((2.0 * ((b + a) * (b - a))) * sin((pi / (180.0 / angle_m)))); end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := N[(angle$95$s * N[(N[(2.0 * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Sin[N[(Pi / N[(180.0 / angle$95$m), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
angle_s \cdot \left(\left(2 \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\right) \cdot \sin \left(\frac{\pi}{\frac{180}{angle_m}}\right)\right)
\end{array}
Initial program 56.1%
unpow256.1%
unpow256.1%
difference-of-squares58.5%
Applied egg-rr58.5%
Taylor expanded in angle around 0 56.5%
associate-*r/65.6%
associate-/l*64.8%
Applied egg-rr57.8%
Final simplification57.8%
angle_m = (fabs.f64 angle) angle_s = (copysign.f64 1 angle) (FPCore (angle_s a b angle_m) :precision binary64 (* angle_s (* (* (sin (* PI (* angle_m 0.005555555555555556))) (* 2.0 (+ b a))) (- b a))))
angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((sin((((double) M_PI) * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a));
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
return angle_s * ((Math.sin((Math.PI * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a));
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): return angle_s * ((math.sin((math.pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a))
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) return Float64(angle_s * Float64(Float64(sin(Float64(pi * Float64(angle_m * 0.005555555555555556))) * Float64(2.0 * Float64(b + a))) * Float64(b - a))) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp = code(angle_s, a, b, angle_m) tmp = angle_s * ((sin((pi * (angle_m * 0.005555555555555556))) * (2.0 * (b + a))) * (b - a)); end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := N[(angle$95$s * N[(N[(N[Sin[N[(Pi * N[(angle$95$m * 0.005555555555555556), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * N[(2.0 * N[(b + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
angle_s \cdot \left(\left(\sin \left(\pi \cdot \left(angle_m \cdot 0.005555555555555556\right)\right) \cdot \left(2 \cdot \left(b + a\right)\right)\right) \cdot \left(b - a\right)\right)
\end{array}
Initial program 56.1%
add-sqr-sqrt28.9%
sqrt-unprod29.7%
pow229.7%
*-commutative29.7%
div-inv29.7%
metadata-eval29.7%
Applied egg-rr29.7%
sqrt-pow153.8%
metadata-eval53.8%
pow153.8%
unpow253.8%
unpow253.8%
difference-of-squares56.6%
associate-*r*56.6%
associate-*r*65.0%
Applied egg-rr65.0%
Taylor expanded in angle around 0 63.8%
Final simplification63.8%
angle_m = (fabs.f64 angle) angle_s = (copysign.f64 1 angle) (FPCore (angle_s a b angle_m) :precision binary64 (* angle_s (* 0.011111111111111112 (* angle_m (* PI (* (+ b a) (- b a)))))))
angle_m = fabs(angle);
angle_s = copysign(1.0, angle);
double code(double angle_s, double a, double b, double angle_m) {
return angle_s * (0.011111111111111112 * (angle_m * (((double) M_PI) * ((b + a) * (b - a)))));
}
angle_m = Math.abs(angle);
angle_s = Math.copySign(1.0, angle);
public static double code(double angle_s, double a, double b, double angle_m) {
return angle_s * (0.011111111111111112 * (angle_m * (Math.PI * ((b + a) * (b - a)))));
}
angle_m = math.fabs(angle) angle_s = math.copysign(1.0, angle) def code(angle_s, a, b, angle_m): return angle_s * (0.011111111111111112 * (angle_m * (math.pi * ((b + a) * (b - a)))))
angle_m = abs(angle) angle_s = copysign(1.0, angle) function code(angle_s, a, b, angle_m) return Float64(angle_s * Float64(0.011111111111111112 * Float64(angle_m * Float64(pi * Float64(Float64(b + a) * Float64(b - a)))))) end
angle_m = abs(angle); angle_s = sign(angle) * abs(1.0); function tmp = code(angle_s, a, b, angle_m) tmp = angle_s * (0.011111111111111112 * (angle_m * (pi * ((b + a) * (b - a))))); end
angle_m = N[Abs[angle], $MachinePrecision]
angle_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[angle]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[angle$95$s_, a_, b_, angle$95$m_] := N[(angle$95$s * N[(0.011111111111111112 * N[(angle$95$m * N[(Pi * N[(N[(b + a), $MachinePrecision] * N[(b - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
angle_m = \left|angle\right|
\\
angle_s = \mathsf{copysign}\left(1, angle\right)
\\
angle_s \cdot \left(0.011111111111111112 \cdot \left(angle_m \cdot \left(\pi \cdot \left(\left(b + a\right) \cdot \left(b - a\right)\right)\right)\right)\right)
\end{array}
Initial program 56.1%
unpow256.1%
unpow256.1%
difference-of-squares58.5%
Applied egg-rr58.5%
Taylor expanded in angle around 0 56.5%
Taylor expanded in angle around 0 50.7%
Final simplification50.7%
herbie shell --seed 2024020
(FPCore (a b angle)
:name "ab-angle->ABCF B"
:precision binary64
(* (* (* 2.0 (- (pow b 2.0) (pow a 2.0))) (sin (* PI (/ angle 180.0)))) (cos (* PI (/ angle 180.0)))))