
(FPCore (re im) :precision binary64 (* (* 0.5 (sin re)) (+ (exp (- 0.0 im)) (exp im))))
double code(double re, double im) {
return (0.5 * sin(re)) * (exp((0.0 - im)) + exp(im));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = (0.5d0 * sin(re)) * (exp((0.0d0 - im)) + exp(im))
end function
public static double code(double re, double im) {
return (0.5 * Math.sin(re)) * (Math.exp((0.0 - im)) + Math.exp(im));
}
def code(re, im): return (0.5 * math.sin(re)) * (math.exp((0.0 - im)) + math.exp(im))
function code(re, im) return Float64(Float64(0.5 * sin(re)) * Float64(exp(Float64(0.0 - im)) + exp(im))) end
function tmp = code(re, im) tmp = (0.5 * sin(re)) * (exp((0.0 - im)) + exp(im)); end
code[re_, im_] := N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(N[Exp[N[(0.0 - im), $MachinePrecision]], $MachinePrecision] + N[Exp[im], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\left(0.5 \cdot \sin re\right) \cdot \left(e^{0 - im} + e^{im}\right)
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 13 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (re im) :precision binary64 (* (* 0.5 (sin re)) (+ (exp (- 0.0 im)) (exp im))))
double code(double re, double im) {
return (0.5 * sin(re)) * (exp((0.0 - im)) + exp(im));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = (0.5d0 * sin(re)) * (exp((0.0d0 - im)) + exp(im))
end function
public static double code(double re, double im) {
return (0.5 * Math.sin(re)) * (Math.exp((0.0 - im)) + Math.exp(im));
}
def code(re, im): return (0.5 * math.sin(re)) * (math.exp((0.0 - im)) + math.exp(im))
function code(re, im) return Float64(Float64(0.5 * sin(re)) * Float64(exp(Float64(0.0 - im)) + exp(im))) end
function tmp = code(re, im) tmp = (0.5 * sin(re)) * (exp((0.0 - im)) + exp(im)); end
code[re_, im_] := N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(N[Exp[N[(0.0 - im), $MachinePrecision]], $MachinePrecision] + N[Exp[im], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\left(0.5 \cdot \sin re\right) \cdot \left(e^{0 - im} + e^{im}\right)
\end{array}
(FPCore (re im) :precision binary64 (* (* 0.5 (sin re)) (+ (exp (- im)) (exp im))))
double code(double re, double im) {
return (0.5 * sin(re)) * (exp(-im) + exp(im));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = (0.5d0 * sin(re)) * (exp(-im) + exp(im))
end function
public static double code(double re, double im) {
return (0.5 * Math.sin(re)) * (Math.exp(-im) + Math.exp(im));
}
def code(re, im): return (0.5 * math.sin(re)) * (math.exp(-im) + math.exp(im))
function code(re, im) return Float64(Float64(0.5 * sin(re)) * Float64(exp(Float64(-im)) + exp(im))) end
function tmp = code(re, im) tmp = (0.5 * sin(re)) * (exp(-im) + exp(im)); end
code[re_, im_] := N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(N[Exp[(-im)], $MachinePrecision] + N[Exp[im], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\left(0.5 \cdot \sin re\right) \cdot \left(e^{-im} + e^{im}\right)
\end{array}
Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Final simplification100.0%
(FPCore (re im)
:precision binary64
(let* ((t_0 (* (* 0.5 re) (+ (exp (- im)) (exp im))))
(t_1 (* (* 0.5 (sin re)) (fma im im 2.0))))
(if (<= im 0.1)
t_1
(if (<= im 7.5e+105)
t_0
(if (<= im 6.8e+115)
(*
(fma im im 2.0)
(+ (* 0.5 re) (* -0.08333333333333333 (pow re 3.0))))
(if (<= im 2.65e+147) t_0 t_1))))))
double code(double re, double im) {
double t_0 = (0.5 * re) * (exp(-im) + exp(im));
double t_1 = (0.5 * sin(re)) * fma(im, im, 2.0);
double tmp;
if (im <= 0.1) {
tmp = t_1;
} else if (im <= 7.5e+105) {
tmp = t_0;
} else if (im <= 6.8e+115) {
tmp = fma(im, im, 2.0) * ((0.5 * re) + (-0.08333333333333333 * pow(re, 3.0)));
} else if (im <= 2.65e+147) {
tmp = t_0;
} else {
tmp = t_1;
}
return tmp;
}
function code(re, im) t_0 = Float64(Float64(0.5 * re) * Float64(exp(Float64(-im)) + exp(im))) t_1 = Float64(Float64(0.5 * sin(re)) * fma(im, im, 2.0)) tmp = 0.0 if (im <= 0.1) tmp = t_1; elseif (im <= 7.5e+105) tmp = t_0; elseif (im <= 6.8e+115) tmp = Float64(fma(im, im, 2.0) * Float64(Float64(0.5 * re) + Float64(-0.08333333333333333 * (re ^ 3.0)))); elseif (im <= 2.65e+147) tmp = t_0; else tmp = t_1; end return tmp end
code[re_, im_] := Block[{t$95$0 = N[(N[(0.5 * re), $MachinePrecision] * N[(N[Exp[(-im)], $MachinePrecision] + N[Exp[im], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(im * im + 2.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[im, 0.1], t$95$1, If[LessEqual[im, 7.5e+105], t$95$0, If[LessEqual[im, 6.8e+115], N[(N[(im * im + 2.0), $MachinePrecision] * N[(N[(0.5 * re), $MachinePrecision] + N[(-0.08333333333333333 * N[Power[re, 3.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[im, 2.65e+147], t$95$0, t$95$1]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(0.5 \cdot re\right) \cdot \left(e^{-im} + e^{im}\right)\\
t_1 := \left(0.5 \cdot \sin re\right) \cdot \mathsf{fma}\left(im, im, 2\right)\\
\mathbf{if}\;im \leq 0.1:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;im \leq 7.5 \cdot 10^{+105}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;im \leq 6.8 \cdot 10^{+115}:\\
\;\;\;\;\mathsf{fma}\left(im, im, 2\right) \cdot \left(0.5 \cdot re + -0.08333333333333333 \cdot {re}^{3}\right)\\
\mathbf{elif}\;im \leq 2.65 \cdot 10^{+147}:\\
\;\;\;\;t\_0\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
if im < 0.10000000000000001 or 2.6500000000000001e147 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 84.8%
+-commutative84.8%
unpow284.8%
fma-define84.8%
Simplified84.8%
if 0.10000000000000001 < im < 7.5000000000000002e105 or 6.8000000000000001e115 < im < 2.6500000000000001e147Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 77.5%
associate-*r*77.5%
Simplified77.5%
if 7.5000000000000002e105 < im < 6.8000000000000001e115Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 5.7%
+-commutative5.7%
unpow25.7%
fma-define5.7%
Simplified5.7%
Taylor expanded in re around 0 1.8%
+-commutative1.8%
associate-*r*1.8%
*-commutative1.8%
associate-*r*1.8%
distribute-rgt-out68.5%
+-commutative68.5%
unpow268.5%
fma-undefine68.5%
*-commutative68.5%
Simplified68.5%
Final simplification83.7%
(FPCore (re im)
:precision binary64
(let* ((t_0 (* (* 0.5 (sin re)) (fma im im 2.0))))
(if (<= im 2.3e+14)
t_0
(if (<= im 7.3e+105)
(pow re -4.0)
(if (<= im 6.8e+115)
(- (+ re (* (pow re 3.0) -0.16666666666666666)) 2.0)
(if (<= im 1.46e+144) (pow re -4.0) t_0))))))
double code(double re, double im) {
double t_0 = (0.5 * sin(re)) * fma(im, im, 2.0);
double tmp;
if (im <= 2.3e+14) {
tmp = t_0;
} else if (im <= 7.3e+105) {
tmp = pow(re, -4.0);
} else if (im <= 6.8e+115) {
tmp = (re + (pow(re, 3.0) * -0.16666666666666666)) - 2.0;
} else if (im <= 1.46e+144) {
tmp = pow(re, -4.0);
} else {
tmp = t_0;
}
return tmp;
}
function code(re, im) t_0 = Float64(Float64(0.5 * sin(re)) * fma(im, im, 2.0)) tmp = 0.0 if (im <= 2.3e+14) tmp = t_0; elseif (im <= 7.3e+105) tmp = re ^ -4.0; elseif (im <= 6.8e+115) tmp = Float64(Float64(re + Float64((re ^ 3.0) * -0.16666666666666666)) - 2.0); elseif (im <= 1.46e+144) tmp = re ^ -4.0; else tmp = t_0; end return tmp end
code[re_, im_] := Block[{t$95$0 = N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(im * im + 2.0), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[im, 2.3e+14], t$95$0, If[LessEqual[im, 7.3e+105], N[Power[re, -4.0], $MachinePrecision], If[LessEqual[im, 6.8e+115], N[(N[(re + N[(N[Power[re, 3.0], $MachinePrecision] * -0.16666666666666666), $MachinePrecision]), $MachinePrecision] - 2.0), $MachinePrecision], If[LessEqual[im, 1.46e+144], N[Power[re, -4.0], $MachinePrecision], t$95$0]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left(0.5 \cdot \sin re\right) \cdot \mathsf{fma}\left(im, im, 2\right)\\
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;t\_0\\
\mathbf{elif}\;im \leq 7.3 \cdot 10^{+105}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{elif}\;im \leq 6.8 \cdot 10^{+115}:\\
\;\;\;\;\left(re + {re}^{3} \cdot -0.16666666666666666\right) - 2\\
\mathbf{elif}\;im \leq 1.46 \cdot 10^{+144}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{else}:\\
\;\;\;\;t\_0\\
\end{array}
\end{array}
if im < 2.3e14 or 1.46e144 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 83.3%
+-commutative83.3%
unpow283.3%
fma-define83.3%
Simplified83.3%
if 2.3e14 < im < 7.30000000000000024e105 or 6.8000000000000001e115 < im < 1.46e144Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 80.8%
associate-*r*80.8%
Simplified80.8%
Applied egg-rr27.6%
if 7.30000000000000024e105 < im < 6.8000000000000001e115Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 5.7%
Applied egg-rr2.3%
Taylor expanded in re around 0 67.7%
Final simplification77.4%
(FPCore (re im)
:precision binary64
(if (<= im 2.3e+14)
(sin re)
(if (<= im 5e+105)
(pow re -4.0)
(if (<= im 6.8e+115)
(- (+ re (* (pow re 3.0) -0.16666666666666666)) 2.0)
(if (<= im 1.46e+144)
(pow re -4.0)
(* (* 0.5 (sin re)) (pow im 2.0)))))))
double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = sin(re);
} else if (im <= 5e+105) {
tmp = pow(re, -4.0);
} else if (im <= 6.8e+115) {
tmp = (re + (pow(re, 3.0) * -0.16666666666666666)) - 2.0;
} else if (im <= 1.46e+144) {
tmp = pow(re, -4.0);
} else {
tmp = (0.5 * sin(re)) * pow(im, 2.0);
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (im <= 2.3d+14) then
tmp = sin(re)
else if (im <= 5d+105) then
tmp = re ** (-4.0d0)
else if (im <= 6.8d+115) then
tmp = (re + ((re ** 3.0d0) * (-0.16666666666666666d0))) - 2.0d0
else if (im <= 1.46d+144) then
tmp = re ** (-4.0d0)
else
tmp = (0.5d0 * sin(re)) * (im ** 2.0d0)
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = Math.sin(re);
} else if (im <= 5e+105) {
tmp = Math.pow(re, -4.0);
} else if (im <= 6.8e+115) {
tmp = (re + (Math.pow(re, 3.0) * -0.16666666666666666)) - 2.0;
} else if (im <= 1.46e+144) {
tmp = Math.pow(re, -4.0);
} else {
tmp = (0.5 * Math.sin(re)) * Math.pow(im, 2.0);
}
return tmp;
}
def code(re, im): tmp = 0 if im <= 2.3e+14: tmp = math.sin(re) elif im <= 5e+105: tmp = math.pow(re, -4.0) elif im <= 6.8e+115: tmp = (re + (math.pow(re, 3.0) * -0.16666666666666666)) - 2.0 elif im <= 1.46e+144: tmp = math.pow(re, -4.0) else: tmp = (0.5 * math.sin(re)) * math.pow(im, 2.0) return tmp
function code(re, im) tmp = 0.0 if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 5e+105) tmp = re ^ -4.0; elseif (im <= 6.8e+115) tmp = Float64(Float64(re + Float64((re ^ 3.0) * -0.16666666666666666)) - 2.0); elseif (im <= 1.46e+144) tmp = re ^ -4.0; else tmp = Float64(Float64(0.5 * sin(re)) * (im ^ 2.0)); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 5e+105) tmp = re ^ -4.0; elseif (im <= 6.8e+115) tmp = (re + ((re ^ 3.0) * -0.16666666666666666)) - 2.0; elseif (im <= 1.46e+144) tmp = re ^ -4.0; else tmp = (0.5 * sin(re)) * (im ^ 2.0); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[im, 2.3e+14], N[Sin[re], $MachinePrecision], If[LessEqual[im, 5e+105], N[Power[re, -4.0], $MachinePrecision], If[LessEqual[im, 6.8e+115], N[(N[(re + N[(N[Power[re, 3.0], $MachinePrecision] * -0.16666666666666666), $MachinePrecision]), $MachinePrecision] - 2.0), $MachinePrecision], If[LessEqual[im, 1.46e+144], N[Power[re, -4.0], $MachinePrecision], N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[Power[im, 2.0], $MachinePrecision]), $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;\sin re\\
\mathbf{elif}\;im \leq 5 \cdot 10^{+105}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{elif}\;im \leq 6.8 \cdot 10^{+115}:\\
\;\;\;\;\left(re + {re}^{3} \cdot -0.16666666666666666\right) - 2\\
\mathbf{elif}\;im \leq 1.46 \cdot 10^{+144}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{else}:\\
\;\;\;\;\left(0.5 \cdot \sin re\right) \cdot {im}^{2}\\
\end{array}
\end{array}
if im < 2.3e14Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 63.0%
if 2.3e14 < im < 5.00000000000000046e105 or 6.8000000000000001e115 < im < 1.46e144Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 80.8%
associate-*r*80.8%
Simplified80.8%
Applied egg-rr27.6%
if 5.00000000000000046e105 < im < 6.8000000000000001e115Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 5.7%
Applied egg-rr2.3%
Taylor expanded in re around 0 67.7%
if 1.46e144 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 95.0%
Taylor expanded in im around inf 95.0%
associate-*r*95.0%
*-commutative95.0%
associate-*l*95.0%
Simplified95.0%
Final simplification64.1%
(FPCore (re im) :precision binary64 (if (or (<= im 0.105) (not (<= im 2.65e+147))) (* (* 0.5 (sin re)) (fma im im 2.0)) (* (* 0.5 re) (+ (exp (- im)) (exp im)))))
double code(double re, double im) {
double tmp;
if ((im <= 0.105) || !(im <= 2.65e+147)) {
tmp = (0.5 * sin(re)) * fma(im, im, 2.0);
} else {
tmp = (0.5 * re) * (exp(-im) + exp(im));
}
return tmp;
}
function code(re, im) tmp = 0.0 if ((im <= 0.105) || !(im <= 2.65e+147)) tmp = Float64(Float64(0.5 * sin(re)) * fma(im, im, 2.0)); else tmp = Float64(Float64(0.5 * re) * Float64(exp(Float64(-im)) + exp(im))); end return tmp end
code[re_, im_] := If[Or[LessEqual[im, 0.105], N[Not[LessEqual[im, 2.65e+147]], $MachinePrecision]], N[(N[(0.5 * N[Sin[re], $MachinePrecision]), $MachinePrecision] * N[(im * im + 2.0), $MachinePrecision]), $MachinePrecision], N[(N[(0.5 * re), $MachinePrecision] * N[(N[Exp[(-im)], $MachinePrecision] + N[Exp[im], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 0.105 \lor \neg \left(im \leq 2.65 \cdot 10^{+147}\right):\\
\;\;\;\;\left(0.5 \cdot \sin re\right) \cdot \mathsf{fma}\left(im, im, 2\right)\\
\mathbf{else}:\\
\;\;\;\;\left(0.5 \cdot re\right) \cdot \left(e^{-im} + e^{im}\right)\\
\end{array}
\end{array}
if im < 0.104999999999999996 or 2.6500000000000001e147 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 84.8%
+-commutative84.8%
unpow284.8%
fma-define84.8%
Simplified84.8%
if 0.104999999999999996 < im < 2.6500000000000001e147Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 73.6%
associate-*r*73.6%
Simplified73.6%
Final simplification83.3%
(FPCore (re im)
:precision binary64
(if (<= im 2.3e+14)
(sin re)
(if (<= im 1.05e+105)
(pow re -4.0)
(if (<= im 6.8e+115)
(- (+ re (* (pow re 3.0) -0.16666666666666666)) 2.0)
(if (<= im 2.65e+144) (pow re -4.0) (* (fma im im 2.0) (* 0.5 re)))))))
double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = sin(re);
} else if (im <= 1.05e+105) {
tmp = pow(re, -4.0);
} else if (im <= 6.8e+115) {
tmp = (re + (pow(re, 3.0) * -0.16666666666666666)) - 2.0;
} else if (im <= 2.65e+144) {
tmp = pow(re, -4.0);
} else {
tmp = fma(im, im, 2.0) * (0.5 * re);
}
return tmp;
}
function code(re, im) tmp = 0.0 if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 1.05e+105) tmp = re ^ -4.0; elseif (im <= 6.8e+115) tmp = Float64(Float64(re + Float64((re ^ 3.0) * -0.16666666666666666)) - 2.0); elseif (im <= 2.65e+144) tmp = re ^ -4.0; else tmp = Float64(fma(im, im, 2.0) * Float64(0.5 * re)); end return tmp end
code[re_, im_] := If[LessEqual[im, 2.3e+14], N[Sin[re], $MachinePrecision], If[LessEqual[im, 1.05e+105], N[Power[re, -4.0], $MachinePrecision], If[LessEqual[im, 6.8e+115], N[(N[(re + N[(N[Power[re, 3.0], $MachinePrecision] * -0.16666666666666666), $MachinePrecision]), $MachinePrecision] - 2.0), $MachinePrecision], If[LessEqual[im, 2.65e+144], N[Power[re, -4.0], $MachinePrecision], N[(N[(im * im + 2.0), $MachinePrecision] * N[(0.5 * re), $MachinePrecision]), $MachinePrecision]]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;\sin re\\
\mathbf{elif}\;im \leq 1.05 \cdot 10^{+105}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{elif}\;im \leq 6.8 \cdot 10^{+115}:\\
\;\;\;\;\left(re + {re}^{3} \cdot -0.16666666666666666\right) - 2\\
\mathbf{elif}\;im \leq 2.65 \cdot 10^{+144}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(im, im, 2\right) \cdot \left(0.5 \cdot re\right)\\
\end{array}
\end{array}
if im < 2.3e14Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 63.0%
if 2.3e14 < im < 1.05000000000000005e105 or 6.8000000000000001e115 < im < 2.6499999999999998e144Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 77.8%
associate-*r*77.8%
Simplified77.8%
Applied egg-rr26.6%
if 1.05000000000000005e105 < im < 6.8000000000000001e115Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 5.7%
Applied egg-rr2.3%
Taylor expanded in re around 0 67.7%
if 2.6499999999999998e144 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 75.0%
associate-*r*75.0%
Simplified75.0%
Taylor expanded in im around 0 72.4%
+-commutative72.4%
unpow272.4%
fma-define72.4%
Simplified72.4%
Final simplification60.5%
(FPCore (re im) :precision binary64 (if (<= im 2.3e+14) (sin re) (if (<= im 1.8e+144) (pow re -4.0) (* (fma im im 2.0) (* 0.5 re)))))
double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = sin(re);
} else if (im <= 1.8e+144) {
tmp = pow(re, -4.0);
} else {
tmp = fma(im, im, 2.0) * (0.5 * re);
}
return tmp;
}
function code(re, im) tmp = 0.0 if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 1.8e+144) tmp = re ^ -4.0; else tmp = Float64(fma(im, im, 2.0) * Float64(0.5 * re)); end return tmp end
code[re_, im_] := If[LessEqual[im, 2.3e+14], N[Sin[re], $MachinePrecision], If[LessEqual[im, 1.8e+144], N[Power[re, -4.0], $MachinePrecision], N[(N[(im * im + 2.0), $MachinePrecision] * N[(0.5 * re), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;\sin re\\
\mathbf{elif}\;im \leq 1.8 \cdot 10^{+144}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(im, im, 2\right) \cdot \left(0.5 \cdot re\right)\\
\end{array}
\end{array}
if im < 2.3e14Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 63.0%
if 2.3e14 < im < 1.7999999999999999e144Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 73.3%
associate-*r*73.3%
Simplified73.3%
Applied egg-rr24.1%
if 1.7999999999999999e144 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 75.0%
associate-*r*75.0%
Simplified75.0%
Taylor expanded in im around 0 72.4%
+-commutative72.4%
unpow272.4%
fma-define72.4%
Simplified72.4%
Final simplification59.7%
(FPCore (re im) :precision binary64 (if (<= im 2.3e+14) (sin re) (if (<= im 2.4e+144) (pow re -4.0) (* (* 0.5 re) (pow im 2.0)))))
double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = sin(re);
} else if (im <= 2.4e+144) {
tmp = pow(re, -4.0);
} else {
tmp = (0.5 * re) * pow(im, 2.0);
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (im <= 2.3d+14) then
tmp = sin(re)
else if (im <= 2.4d+144) then
tmp = re ** (-4.0d0)
else
tmp = (0.5d0 * re) * (im ** 2.0d0)
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = Math.sin(re);
} else if (im <= 2.4e+144) {
tmp = Math.pow(re, -4.0);
} else {
tmp = (0.5 * re) * Math.pow(im, 2.0);
}
return tmp;
}
def code(re, im): tmp = 0 if im <= 2.3e+14: tmp = math.sin(re) elif im <= 2.4e+144: tmp = math.pow(re, -4.0) else: tmp = (0.5 * re) * math.pow(im, 2.0) return tmp
function code(re, im) tmp = 0.0 if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 2.4e+144) tmp = re ^ -4.0; else tmp = Float64(Float64(0.5 * re) * (im ^ 2.0)); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (im <= 2.3e+14) tmp = sin(re); elseif (im <= 2.4e+144) tmp = re ^ -4.0; else tmp = (0.5 * re) * (im ^ 2.0); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[im, 2.3e+14], N[Sin[re], $MachinePrecision], If[LessEqual[im, 2.4e+144], N[Power[re, -4.0], $MachinePrecision], N[(N[(0.5 * re), $MachinePrecision] * N[Power[im, 2.0], $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;\sin re\\
\mathbf{elif}\;im \leq 2.4 \cdot 10^{+144}:\\
\;\;\;\;{re}^{-4}\\
\mathbf{else}:\\
\;\;\;\;\left(0.5 \cdot re\right) \cdot {im}^{2}\\
\end{array}
\end{array}
if im < 2.3e14Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 63.0%
if 2.3e14 < im < 2.4000000000000001e144Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 73.3%
associate-*r*73.3%
Simplified73.3%
Applied egg-rr24.1%
if 2.4000000000000001e144 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 75.0%
associate-*r*75.0%
Simplified75.0%
Taylor expanded in im around 0 72.4%
Taylor expanded in im around inf 72.4%
associate-*r*72.4%
*-commutative72.4%
associate-*r*72.4%
Simplified72.4%
Final simplification59.7%
(FPCore (re im) :precision binary64 (if (<= im 2.3e+14) (sin re) (pow re -4.0)))
double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = sin(re);
} else {
tmp = pow(re, -4.0);
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (im <= 2.3d+14) then
tmp = sin(re)
else
tmp = re ** (-4.0d0)
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (im <= 2.3e+14) {
tmp = Math.sin(re);
} else {
tmp = Math.pow(re, -4.0);
}
return tmp;
}
def code(re, im): tmp = 0 if im <= 2.3e+14: tmp = math.sin(re) else: tmp = math.pow(re, -4.0) return tmp
function code(re, im) tmp = 0.0 if (im <= 2.3e+14) tmp = sin(re); else tmp = re ^ -4.0; end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (im <= 2.3e+14) tmp = sin(re); else tmp = re ^ -4.0; end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[im, 2.3e+14], N[Sin[re], $MachinePrecision], N[Power[re, -4.0], $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;im \leq 2.3 \cdot 10^{+14}:\\
\;\;\;\;\sin re\\
\mathbf{else}:\\
\;\;\;\;{re}^{-4}\\
\end{array}
\end{array}
if im < 2.3e14Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 63.0%
if 2.3e14 < im Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 74.2%
associate-*r*74.2%
Simplified74.2%
Applied egg-rr22.1%
Final simplification52.4%
(FPCore (re im) :precision binary64 (sin re))
double code(double re, double im) {
return sin(re);
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = sin(re)
end function
public static double code(double re, double im) {
return Math.sin(re);
}
def code(re, im): return math.sin(re)
function code(re, im) return sin(re) end
function tmp = code(re, im) tmp = sin(re); end
code[re_, im_] := N[Sin[re], $MachinePrecision]
\begin{array}{l}
\\
\sin re
\end{array}
Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 47.4%
Final simplification47.4%
(FPCore (re im) :precision binary64 (if (<= re 420000000.0) re 1.0))
double code(double re, double im) {
double tmp;
if (re <= 420000000.0) {
tmp = re;
} else {
tmp = 1.0;
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (re <= 420000000.0d0) then
tmp = re
else
tmp = 1.0d0
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (re <= 420000000.0) {
tmp = re;
} else {
tmp = 1.0;
}
return tmp;
}
def code(re, im): tmp = 0 if re <= 420000000.0: tmp = re else: tmp = 1.0 return tmp
function code(re, im) tmp = 0.0 if (re <= 420000000.0) tmp = re; else tmp = 1.0; end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (re <= 420000000.0) tmp = re; else tmp = 1.0; end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[re, 420000000.0], re, 1.0]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;re \leq 420000000:\\
\;\;\;\;re\\
\mathbf{else}:\\
\;\;\;\;1\\
\end{array}
\end{array}
if re < 4.2e8Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in re around 0 71.2%
associate-*r*71.2%
Simplified71.2%
Taylor expanded in im around 0 28.1%
if 4.2e8 < re Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Applied egg-rr5.6%
+-inverses5.6%
+-rgt-identity5.6%
*-inverses5.6%
Simplified5.6%
Final simplification22.7%
(FPCore (re im) :precision binary64 -2.0)
double code(double re, double im) {
return -2.0;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = -2.0d0
end function
public static double code(double re, double im) {
return -2.0;
}
def code(re, im): return -2.0
function code(re, im) return -2.0 end
function tmp = code(re, im) tmp = -2.0; end
code[re_, im_] := -2.0
\begin{array}{l}
\\
-2
\end{array}
Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Taylor expanded in im around 0 74.3%
Applied egg-rr4.6%
Taylor expanded in re around 0 4.7%
Final simplification4.7%
(FPCore (re im) :precision binary64 1.0)
double code(double re, double im) {
return 1.0;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = 1.0d0
end function
public static double code(double re, double im) {
return 1.0;
}
def code(re, im): return 1.0
function code(re, im) return 1.0 end
function tmp = code(re, im) tmp = 1.0; end
code[re_, im_] := 1.0
\begin{array}{l}
\\
1
\end{array}
Initial program 100.0%
distribute-rgt-in100.0%
cancel-sign-sub100.0%
distribute-rgt-out--100.0%
sub-neg100.0%
neg-sub0100.0%
remove-double-neg100.0%
Simplified100.0%
Applied egg-rr4.6%
+-inverses4.6%
+-rgt-identity4.6%
*-inverses4.6%
Simplified4.6%
Final simplification4.6%
herbie shell --seed 2024062
(FPCore (re im)
:name "math.sin on complex, real part"
:precision binary64
(* (* 0.5 (sin re)) (+ (exp (- 0.0 im)) (exp im))))