
(FPCore (re im) :precision binary64 (* 0.5 (sqrt (* 2.0 (- (sqrt (+ (* re re) (* im im))) re)))))
double code(double re, double im) {
return 0.5 * sqrt((2.0 * (sqrt(((re * re) + (im * im))) - re)));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = 0.5d0 * sqrt((2.0d0 * (sqrt(((re * re) + (im * im))) - re)))
end function
public static double code(double re, double im) {
return 0.5 * Math.sqrt((2.0 * (Math.sqrt(((re * re) + (im * im))) - re)));
}
def code(re, im): return 0.5 * math.sqrt((2.0 * (math.sqrt(((re * re) + (im * im))) - re)))
function code(re, im) return Float64(0.5 * sqrt(Float64(2.0 * Float64(sqrt(Float64(Float64(re * re) + Float64(im * im))) - re)))) end
function tmp = code(re, im) tmp = 0.5 * sqrt((2.0 * (sqrt(((re * re) + (im * im))) - re))); end
code[re_, im_] := N[(0.5 * N[Sqrt[N[(2.0 * N[(N[Sqrt[N[(N[(re * re), $MachinePrecision] + N[(im * im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
0.5 \cdot \sqrt{2 \cdot \left(\sqrt{re \cdot re + im \cdot im} - re\right)}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 6 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (re im) :precision binary64 (* 0.5 (sqrt (* 2.0 (- (sqrt (+ (* re re) (* im im))) re)))))
double code(double re, double im) {
return 0.5 * sqrt((2.0 * (sqrt(((re * re) + (im * im))) - re)));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = 0.5d0 * sqrt((2.0d0 * (sqrt(((re * re) + (im * im))) - re)))
end function
public static double code(double re, double im) {
return 0.5 * Math.sqrt((2.0 * (Math.sqrt(((re * re) + (im * im))) - re)));
}
def code(re, im): return 0.5 * math.sqrt((2.0 * (math.sqrt(((re * re) + (im * im))) - re)))
function code(re, im) return Float64(0.5 * sqrt(Float64(2.0 * Float64(sqrt(Float64(Float64(re * re) + Float64(im * im))) - re)))) end
function tmp = code(re, im) tmp = 0.5 * sqrt((2.0 * (sqrt(((re * re) + (im * im))) - re))); end
code[re_, im_] := N[(0.5 * N[Sqrt[N[(2.0 * N[(N[Sqrt[N[(N[(re * re), $MachinePrecision] + N[(im * im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
0.5 \cdot \sqrt{2 \cdot \left(\sqrt{re \cdot re + im \cdot im} - re\right)}
\end{array}
(FPCore (re im) :precision binary64 (if (<= (- (sqrt (+ (* re re) (* im im))) re) 0.0) (* 0.5 (/ im (sqrt re))) (* 0.5 (sqrt (* 2.0 (- (hypot re im) re))))))
double code(double re, double im) {
double tmp;
if ((sqrt(((re * re) + (im * im))) - re) <= 0.0) {
tmp = 0.5 * (im / sqrt(re));
} else {
tmp = 0.5 * sqrt((2.0 * (hypot(re, im) - re)));
}
return tmp;
}
public static double code(double re, double im) {
double tmp;
if ((Math.sqrt(((re * re) + (im * im))) - re) <= 0.0) {
tmp = 0.5 * (im / Math.sqrt(re));
} else {
tmp = 0.5 * Math.sqrt((2.0 * (Math.hypot(re, im) - re)));
}
return tmp;
}
def code(re, im): tmp = 0 if (math.sqrt(((re * re) + (im * im))) - re) <= 0.0: tmp = 0.5 * (im / math.sqrt(re)) else: tmp = 0.5 * math.sqrt((2.0 * (math.hypot(re, im) - re))) return tmp
function code(re, im) tmp = 0.0 if (Float64(sqrt(Float64(Float64(re * re) + Float64(im * im))) - re) <= 0.0) tmp = Float64(0.5 * Float64(im / sqrt(re))); else tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(hypot(re, im) - re)))); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if ((sqrt(((re * re) + (im * im))) - re) <= 0.0) tmp = 0.5 * (im / sqrt(re)); else tmp = 0.5 * sqrt((2.0 * (hypot(re, im) - re))); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[N[(N[Sqrt[N[(N[(re * re), $MachinePrecision] + N[(im * im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] - re), $MachinePrecision], 0.0], N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(0.5 * N[Sqrt[N[(2.0 * N[(N[Sqrt[re ^ 2 + im ^ 2], $MachinePrecision] - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;\sqrt{re \cdot re + im \cdot im} - re \leq 0:\\
\;\;\;\;0.5 \cdot \frac{im}{\sqrt{re}}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(\mathsf{hypot}\left(re, im\right) - re\right)}\\
\end{array}
\end{array}
if (-.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) re) < 0.0Initial program 5.9%
Taylor expanded in re around inf 38.8%
unpow238.8%
associate-/l*50.4%
Simplified50.4%
associate-*r*50.4%
metadata-eval50.4%
*-un-lft-identity50.4%
associate-/l*38.8%
div-inv38.8%
sqrt-prod41.1%
sqrt-prod89.7%
add-sqr-sqrt89.9%
*-un-lft-identity89.9%
sqrt-prod89.9%
metadata-eval89.9%
sqrt-unprod88.7%
associate-*r*89.2%
expm1-log1p-u88.9%
expm1-udef14.0%
Applied egg-rr14.0%
expm1-def89.7%
expm1-log1p90.1%
Simplified90.1%
if 0.0 < (-.f64 (sqrt.f64 (+.f64 (*.f64 re re) (*.f64 im im))) re) Initial program 47.3%
sqr-neg47.3%
sqr-neg47.3%
hypot-def91.3%
Simplified91.3%
Final simplification91.1%
(FPCore (re im)
:precision binary64
(if (<= re -5.1e-17)
(* 0.5 (sqrt (* 2.0 (* re -2.0))))
(if (<= re 1e-144)
(* 0.5 (sqrt (* 2.0 (- im re))))
(if (or (<= re 1.2e-112) (not (<= re 6.9e+106)))
(* 0.5 (/ im (sqrt re)))
(* 0.5 (* (sqrt im) (sqrt 2.0)))))))
double code(double re, double im) {
double tmp;
if (re <= -5.1e-17) {
tmp = 0.5 * sqrt((2.0 * (re * -2.0)));
} else if (re <= 1e-144) {
tmp = 0.5 * sqrt((2.0 * (im - re)));
} else if ((re <= 1.2e-112) || !(re <= 6.9e+106)) {
tmp = 0.5 * (im / sqrt(re));
} else {
tmp = 0.5 * (sqrt(im) * sqrt(2.0));
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (re <= (-5.1d-17)) then
tmp = 0.5d0 * sqrt((2.0d0 * (re * (-2.0d0))))
else if (re <= 1d-144) then
tmp = 0.5d0 * sqrt((2.0d0 * (im - re)))
else if ((re <= 1.2d-112) .or. (.not. (re <= 6.9d+106))) then
tmp = 0.5d0 * (im / sqrt(re))
else
tmp = 0.5d0 * (sqrt(im) * sqrt(2.0d0))
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (re <= -5.1e-17) {
tmp = 0.5 * Math.sqrt((2.0 * (re * -2.0)));
} else if (re <= 1e-144) {
tmp = 0.5 * Math.sqrt((2.0 * (im - re)));
} else if ((re <= 1.2e-112) || !(re <= 6.9e+106)) {
tmp = 0.5 * (im / Math.sqrt(re));
} else {
tmp = 0.5 * (Math.sqrt(im) * Math.sqrt(2.0));
}
return tmp;
}
def code(re, im): tmp = 0 if re <= -5.1e-17: tmp = 0.5 * math.sqrt((2.0 * (re * -2.0))) elif re <= 1e-144: tmp = 0.5 * math.sqrt((2.0 * (im - re))) elif (re <= 1.2e-112) or not (re <= 6.9e+106): tmp = 0.5 * (im / math.sqrt(re)) else: tmp = 0.5 * (math.sqrt(im) * math.sqrt(2.0)) return tmp
function code(re, im) tmp = 0.0 if (re <= -5.1e-17) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(re * -2.0)))); elseif (re <= 1e-144) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(im - re)))); elseif ((re <= 1.2e-112) || !(re <= 6.9e+106)) tmp = Float64(0.5 * Float64(im / sqrt(re))); else tmp = Float64(0.5 * Float64(sqrt(im) * sqrt(2.0))); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (re <= -5.1e-17) tmp = 0.5 * sqrt((2.0 * (re * -2.0))); elseif (re <= 1e-144) tmp = 0.5 * sqrt((2.0 * (im - re))); elseif ((re <= 1.2e-112) || ~((re <= 6.9e+106))) tmp = 0.5 * (im / sqrt(re)); else tmp = 0.5 * (sqrt(im) * sqrt(2.0)); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[re, -5.1e-17], N[(0.5 * N[Sqrt[N[(2.0 * N[(re * -2.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[re, 1e-144], N[(0.5 * N[Sqrt[N[(2.0 * N[(im - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[Or[LessEqual[re, 1.2e-112], N[Not[LessEqual[re, 6.9e+106]], $MachinePrecision]], N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(0.5 * N[(N[Sqrt[im], $MachinePrecision] * N[Sqrt[2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;re \leq -5.1 \cdot 10^{-17}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(re \cdot -2\right)}\\
\mathbf{elif}\;re \leq 10^{-144}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(im - re\right)}\\
\mathbf{elif}\;re \leq 1.2 \cdot 10^{-112} \lor \neg \left(re \leq 6.9 \cdot 10^{+106}\right):\\
\;\;\;\;0.5 \cdot \frac{im}{\sqrt{re}}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \left(\sqrt{im} \cdot \sqrt{2}\right)\\
\end{array}
\end{array}
if re < -5.1000000000000003e-17Initial program 51.4%
Taylor expanded in re around -inf 79.1%
*-commutative79.1%
Simplified79.1%
if -5.1000000000000003e-17 < re < 9.9999999999999995e-145Initial program 55.5%
Taylor expanded in re around 0 80.5%
if 9.9999999999999995e-145 < re < 1.2e-112 or 6.8999999999999998e106 < re Initial program 8.6%
Taylor expanded in re around inf 50.6%
unpow250.6%
associate-/l*54.7%
Simplified54.7%
associate-*r*54.7%
metadata-eval54.7%
*-un-lft-identity54.7%
associate-/l*50.6%
div-inv50.5%
sqrt-prod63.4%
sqrt-prod84.6%
add-sqr-sqrt84.7%
*-un-lft-identity84.7%
sqrt-prod84.7%
metadata-eval84.7%
sqrt-unprod83.9%
associate-*r*84.2%
expm1-log1p-u83.6%
expm1-udef35.7%
Applied egg-rr35.7%
expm1-def84.0%
expm1-log1p84.8%
Simplified84.8%
if 1.2e-112 < re < 6.8999999999999998e106Initial program 32.3%
Taylor expanded in re around 0 67.2%
Final simplification78.9%
(FPCore (re im)
:precision binary64
(if (<= re -3.6e-16)
(* 0.5 (sqrt (* 2.0 (* re -2.0))))
(if (<= re 1e-144)
(* 0.5 (sqrt (* 2.0 (- im re))))
(if (or (<= re 1.35e-112) (not (<= re 6.9e+106)))
(* 0.5 (/ im (sqrt re)))
(* 0.5 (sqrt (* 2.0 (+ (- im re) (* 0.5 (/ re (/ im re)))))))))))
double code(double re, double im) {
double tmp;
if (re <= -3.6e-16) {
tmp = 0.5 * sqrt((2.0 * (re * -2.0)));
} else if (re <= 1e-144) {
tmp = 0.5 * sqrt((2.0 * (im - re)));
} else if ((re <= 1.35e-112) || !(re <= 6.9e+106)) {
tmp = 0.5 * (im / sqrt(re));
} else {
tmp = 0.5 * sqrt((2.0 * ((im - re) + (0.5 * (re / (im / re))))));
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (re <= (-3.6d-16)) then
tmp = 0.5d0 * sqrt((2.0d0 * (re * (-2.0d0))))
else if (re <= 1d-144) then
tmp = 0.5d0 * sqrt((2.0d0 * (im - re)))
else if ((re <= 1.35d-112) .or. (.not. (re <= 6.9d+106))) then
tmp = 0.5d0 * (im / sqrt(re))
else
tmp = 0.5d0 * sqrt((2.0d0 * ((im - re) + (0.5d0 * (re / (im / re))))))
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (re <= -3.6e-16) {
tmp = 0.5 * Math.sqrt((2.0 * (re * -2.0)));
} else if (re <= 1e-144) {
tmp = 0.5 * Math.sqrt((2.0 * (im - re)));
} else if ((re <= 1.35e-112) || !(re <= 6.9e+106)) {
tmp = 0.5 * (im / Math.sqrt(re));
} else {
tmp = 0.5 * Math.sqrt((2.0 * ((im - re) + (0.5 * (re / (im / re))))));
}
return tmp;
}
def code(re, im): tmp = 0 if re <= -3.6e-16: tmp = 0.5 * math.sqrt((2.0 * (re * -2.0))) elif re <= 1e-144: tmp = 0.5 * math.sqrt((2.0 * (im - re))) elif (re <= 1.35e-112) or not (re <= 6.9e+106): tmp = 0.5 * (im / math.sqrt(re)) else: tmp = 0.5 * math.sqrt((2.0 * ((im - re) + (0.5 * (re / (im / re)))))) return tmp
function code(re, im) tmp = 0.0 if (re <= -3.6e-16) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(re * -2.0)))); elseif (re <= 1e-144) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(im - re)))); elseif ((re <= 1.35e-112) || !(re <= 6.9e+106)) tmp = Float64(0.5 * Float64(im / sqrt(re))); else tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(Float64(im - re) + Float64(0.5 * Float64(re / Float64(im / re))))))); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (re <= -3.6e-16) tmp = 0.5 * sqrt((2.0 * (re * -2.0))); elseif (re <= 1e-144) tmp = 0.5 * sqrt((2.0 * (im - re))); elseif ((re <= 1.35e-112) || ~((re <= 6.9e+106))) tmp = 0.5 * (im / sqrt(re)); else tmp = 0.5 * sqrt((2.0 * ((im - re) + (0.5 * (re / (im / re)))))); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[re, -3.6e-16], N[(0.5 * N[Sqrt[N[(2.0 * N[(re * -2.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[re, 1e-144], N[(0.5 * N[Sqrt[N[(2.0 * N[(im - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[Or[LessEqual[re, 1.35e-112], N[Not[LessEqual[re, 6.9e+106]], $MachinePrecision]], N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(0.5 * N[Sqrt[N[(2.0 * N[(N[(im - re), $MachinePrecision] + N[(0.5 * N[(re / N[(im / re), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;re \leq -3.6 \cdot 10^{-16}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(re \cdot -2\right)}\\
\mathbf{elif}\;re \leq 10^{-144}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(im - re\right)}\\
\mathbf{elif}\;re \leq 1.35 \cdot 10^{-112} \lor \neg \left(re \leq 6.9 \cdot 10^{+106}\right):\\
\;\;\;\;0.5 \cdot \frac{im}{\sqrt{re}}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(\left(im - re\right) + 0.5 \cdot \frac{re}{\frac{im}{re}}\right)}\\
\end{array}
\end{array}
if re < -3.59999999999999983e-16Initial program 51.4%
Taylor expanded in re around -inf 79.1%
*-commutative79.1%
Simplified79.1%
if -3.59999999999999983e-16 < re < 9.9999999999999995e-145Initial program 55.5%
Taylor expanded in re around 0 80.5%
if 9.9999999999999995e-145 < re < 1.35e-112 or 6.8999999999999998e106 < re Initial program 8.6%
Taylor expanded in re around inf 50.6%
unpow250.6%
associate-/l*54.7%
Simplified54.7%
associate-*r*54.7%
metadata-eval54.7%
*-un-lft-identity54.7%
associate-/l*50.6%
div-inv50.5%
sqrt-prod63.4%
sqrt-prod84.6%
add-sqr-sqrt84.7%
*-un-lft-identity84.7%
sqrt-prod84.7%
metadata-eval84.7%
sqrt-unprod83.9%
associate-*r*84.2%
expm1-log1p-u83.6%
expm1-udef35.7%
Applied egg-rr35.7%
expm1-def84.0%
expm1-log1p84.8%
Simplified84.8%
if 1.35e-112 < re < 6.8999999999999998e106Initial program 32.3%
Taylor expanded in re around 0 66.7%
neg-mul-166.7%
associate-+r+66.7%
sub-neg66.7%
+-commutative66.7%
unpow266.7%
associate-/l*66.7%
Simplified66.7%
Final simplification78.9%
(FPCore (re im)
:precision binary64
(if (<= re -8e-17)
(* 0.5 (sqrt (* 2.0 (* re -2.0))))
(if (or (<= re 6.5e-145) (and (not (<= re 2.4e-112)) (<= re 6.9e+106)))
(* 0.5 (sqrt (* 2.0 (- im re))))
(* 0.5 (/ im (sqrt re))))))
double code(double re, double im) {
double tmp;
if (re <= -8e-17) {
tmp = 0.5 * sqrt((2.0 * (re * -2.0)));
} else if ((re <= 6.5e-145) || (!(re <= 2.4e-112) && (re <= 6.9e+106))) {
tmp = 0.5 * sqrt((2.0 * (im - re)));
} else {
tmp = 0.5 * (im / sqrt(re));
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (re <= (-8d-17)) then
tmp = 0.5d0 * sqrt((2.0d0 * (re * (-2.0d0))))
else if ((re <= 6.5d-145) .or. (.not. (re <= 2.4d-112)) .and. (re <= 6.9d+106)) then
tmp = 0.5d0 * sqrt((2.0d0 * (im - re)))
else
tmp = 0.5d0 * (im / sqrt(re))
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (re <= -8e-17) {
tmp = 0.5 * Math.sqrt((2.0 * (re * -2.0)));
} else if ((re <= 6.5e-145) || (!(re <= 2.4e-112) && (re <= 6.9e+106))) {
tmp = 0.5 * Math.sqrt((2.0 * (im - re)));
} else {
tmp = 0.5 * (im / Math.sqrt(re));
}
return tmp;
}
def code(re, im): tmp = 0 if re <= -8e-17: tmp = 0.5 * math.sqrt((2.0 * (re * -2.0))) elif (re <= 6.5e-145) or (not (re <= 2.4e-112) and (re <= 6.9e+106)): tmp = 0.5 * math.sqrt((2.0 * (im - re))) else: tmp = 0.5 * (im / math.sqrt(re)) return tmp
function code(re, im) tmp = 0.0 if (re <= -8e-17) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(re * -2.0)))); elseif ((re <= 6.5e-145) || (!(re <= 2.4e-112) && (re <= 6.9e+106))) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(im - re)))); else tmp = Float64(0.5 * Float64(im / sqrt(re))); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (re <= -8e-17) tmp = 0.5 * sqrt((2.0 * (re * -2.0))); elseif ((re <= 6.5e-145) || (~((re <= 2.4e-112)) && (re <= 6.9e+106))) tmp = 0.5 * sqrt((2.0 * (im - re))); else tmp = 0.5 * (im / sqrt(re)); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[re, -8e-17], N[(0.5 * N[Sqrt[N[(2.0 * N[(re * -2.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[Or[LessEqual[re, 6.5e-145], And[N[Not[LessEqual[re, 2.4e-112]], $MachinePrecision], LessEqual[re, 6.9e+106]]], N[(0.5 * N[Sqrt[N[(2.0 * N[(im - re), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;re \leq -8 \cdot 10^{-17}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(re \cdot -2\right)}\\
\mathbf{elif}\;re \leq 6.5 \cdot 10^{-145} \lor \neg \left(re \leq 2.4 \cdot 10^{-112}\right) \land re \leq 6.9 \cdot 10^{+106}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(im - re\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \frac{im}{\sqrt{re}}\\
\end{array}
\end{array}
if re < -8.00000000000000057e-17Initial program 51.4%
Taylor expanded in re around -inf 79.1%
*-commutative79.1%
Simplified79.1%
if -8.00000000000000057e-17 < re < 6.5000000000000002e-145 or 2.4000000000000001e-112 < re < 6.8999999999999998e106Initial program 48.5%
Taylor expanded in re around 0 75.8%
if 6.5000000000000002e-145 < re < 2.4000000000000001e-112 or 6.8999999999999998e106 < re Initial program 8.6%
Taylor expanded in re around inf 50.6%
unpow250.6%
associate-/l*54.7%
Simplified54.7%
associate-*r*54.7%
metadata-eval54.7%
*-un-lft-identity54.7%
associate-/l*50.6%
div-inv50.5%
sqrt-prod63.4%
sqrt-prod84.6%
add-sqr-sqrt84.7%
*-un-lft-identity84.7%
sqrt-prod84.7%
metadata-eval84.7%
sqrt-unprod83.9%
associate-*r*84.2%
expm1-log1p-u83.6%
expm1-udef35.7%
Applied egg-rr35.7%
expm1-def84.0%
expm1-log1p84.8%
Simplified84.8%
Final simplification78.6%
(FPCore (re im) :precision binary64 (if (<= re -5e-310) (* 0.5 (sqrt (* 2.0 (* re -2.0)))) (* 0.5 (/ im (sqrt re)))))
double code(double re, double im) {
double tmp;
if (re <= -5e-310) {
tmp = 0.5 * sqrt((2.0 * (re * -2.0)));
} else {
tmp = 0.5 * (im / sqrt(re));
}
return tmp;
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
real(8) :: tmp
if (re <= (-5d-310)) then
tmp = 0.5d0 * sqrt((2.0d0 * (re * (-2.0d0))))
else
tmp = 0.5d0 * (im / sqrt(re))
end if
code = tmp
end function
public static double code(double re, double im) {
double tmp;
if (re <= -5e-310) {
tmp = 0.5 * Math.sqrt((2.0 * (re * -2.0)));
} else {
tmp = 0.5 * (im / Math.sqrt(re));
}
return tmp;
}
def code(re, im): tmp = 0 if re <= -5e-310: tmp = 0.5 * math.sqrt((2.0 * (re * -2.0))) else: tmp = 0.5 * (im / math.sqrt(re)) return tmp
function code(re, im) tmp = 0.0 if (re <= -5e-310) tmp = Float64(0.5 * sqrt(Float64(2.0 * Float64(re * -2.0)))); else tmp = Float64(0.5 * Float64(im / sqrt(re))); end return tmp end
function tmp_2 = code(re, im) tmp = 0.0; if (re <= -5e-310) tmp = 0.5 * sqrt((2.0 * (re * -2.0))); else tmp = 0.5 * (im / sqrt(re)); end tmp_2 = tmp; end
code[re_, im_] := If[LessEqual[re, -5e-310], N[(0.5 * N[Sqrt[N[(2.0 * N[(re * -2.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;re \leq -5 \cdot 10^{-310}:\\
\;\;\;\;0.5 \cdot \sqrt{2 \cdot \left(re \cdot -2\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \frac{im}{\sqrt{re}}\\
\end{array}
\end{array}
if re < -4.999999999999985e-310Initial program 55.9%
Taylor expanded in re around -inf 55.8%
*-commutative55.8%
Simplified55.8%
if -4.999999999999985e-310 < re Initial program 26.1%
Taylor expanded in re around inf 29.9%
unpow229.9%
associate-/l*35.2%
Simplified35.2%
associate-*r*35.2%
metadata-eval35.2%
*-un-lft-identity35.2%
associate-/l*29.9%
div-inv29.8%
sqrt-prod35.3%
sqrt-prod53.6%
add-sqr-sqrt53.7%
*-un-lft-identity53.7%
sqrt-prod53.7%
metadata-eval53.7%
sqrt-unprod53.2%
associate-*r*53.4%
expm1-log1p-u53.2%
expm1-udef18.1%
Applied egg-rr18.1%
expm1-def53.5%
expm1-log1p53.8%
Simplified53.8%
Final simplification54.8%
(FPCore (re im) :precision binary64 (* 0.5 (/ im (sqrt re))))
double code(double re, double im) {
return 0.5 * (im / sqrt(re));
}
real(8) function code(re, im)
real(8), intent (in) :: re
real(8), intent (in) :: im
code = 0.5d0 * (im / sqrt(re))
end function
public static double code(double re, double im) {
return 0.5 * (im / Math.sqrt(re));
}
def code(re, im): return 0.5 * (im / math.sqrt(re))
function code(re, im) return Float64(0.5 * Float64(im / sqrt(re))) end
function tmp = code(re, im) tmp = 0.5 * (im / sqrt(re)); end
code[re_, im_] := N[(0.5 * N[(im / N[Sqrt[re], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
0.5 \cdot \frac{im}{\sqrt{re}}
\end{array}
Initial program 40.9%
Taylor expanded in re around inf 15.4%
unpow215.4%
associate-/l*18.0%
Simplified18.0%
associate-*r*18.0%
metadata-eval18.0%
*-un-lft-identity18.0%
associate-/l*15.4%
div-inv15.4%
sqrt-prod17.8%
sqrt-prod27.0%
add-sqr-sqrt27.1%
*-un-lft-identity27.1%
sqrt-prod27.1%
metadata-eval27.1%
sqrt-unprod26.8%
associate-*r*26.9%
expm1-log1p-u26.8%
expm1-udef9.1%
Applied egg-rr9.1%
expm1-def27.0%
expm1-log1p27.1%
Simplified27.1%
Final simplification27.1%
herbie shell --seed 2023293
(FPCore (re im)
:name "math.sqrt on complex, imaginary part, im greater than 0 branch"
:precision binary64
:pre (> im 0.0)
(* 0.5 (sqrt (* 2.0 (- (sqrt (+ (* re re) (* im im))) re)))))