| Alternative 1 | |
|---|---|
| Accuracy | 99.1% |
| Cost | 19712 |
\[\left(1 + \frac{\log \left(\mathsf{hypot}\left(re, im\right)\right)}{\log 10}\right) + -1
\]
(FPCore (re im) :precision binary64 (/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))
(FPCore (re im) :precision binary64 (let* ((t_0 (sqrt (log 10.0)))) (* (/ 1.0 t_0) (/ (log (hypot re im)) t_0))))
double code(double re, double im) {
return log(sqrt(((re * re) + (im * im)))) / log(10.0);
}
double code(double re, double im) {
double t_0 = sqrt(log(10.0));
return (1.0 / t_0) * (log(hypot(re, im)) / t_0);
}
public static double code(double re, double im) {
return Math.log(Math.sqrt(((re * re) + (im * im)))) / Math.log(10.0);
}
public static double code(double re, double im) {
double t_0 = Math.sqrt(Math.log(10.0));
return (1.0 / t_0) * (Math.log(Math.hypot(re, im)) / t_0);
}
def code(re, im): return math.log(math.sqrt(((re * re) + (im * im)))) / math.log(10.0)
def code(re, im): t_0 = math.sqrt(math.log(10.0)) return (1.0 / t_0) * (math.log(math.hypot(re, im)) / t_0)
function code(re, im) return Float64(log(sqrt(Float64(Float64(re * re) + Float64(im * im)))) / log(10.0)) end
function code(re, im) t_0 = sqrt(log(10.0)) return Float64(Float64(1.0 / t_0) * Float64(log(hypot(re, im)) / t_0)) end
function tmp = code(re, im) tmp = log(sqrt(((re * re) + (im * im)))) / log(10.0); end
function tmp = code(re, im) t_0 = sqrt(log(10.0)); tmp = (1.0 / t_0) * (log(hypot(re, im)) / t_0); end
code[re_, im_] := N[(N[Log[N[Sqrt[N[(N[(re * re), $MachinePrecision] + N[(im * im), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision] / N[Log[10.0], $MachinePrecision]), $MachinePrecision]
code[re_, im_] := Block[{t$95$0 = N[Sqrt[N[Log[10.0], $MachinePrecision]], $MachinePrecision]}, N[(N[(1.0 / t$95$0), $MachinePrecision] * N[(N[Log[N[Sqrt[re ^ 2 + im ^ 2], $MachinePrecision]], $MachinePrecision] / t$95$0), $MachinePrecision]), $MachinePrecision]]
\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}
\begin{array}{l}
t_0 := \sqrt{\log 10}\\
\frac{1}{t_0} \cdot \frac{\log \left(\mathsf{hypot}\left(re, im\right)\right)}{t_0}
\end{array}
Results
Initial program 53.4%
Simplified99.1%
[Start]53.4 | \[ \frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}
\] |
|---|---|
hypot-def [=>]99.1 | \[ \frac{\log \color{blue}{\left(\mathsf{hypot}\left(re, im\right)\right)}}{\log 10}
\] |
Applied egg-rr99.1%
[Start]99.1 | \[ \frac{\log \left(\mathsf{hypot}\left(re, im\right)\right)}{\log 10}
\] |
|---|---|
*-un-lft-identity [=>]99.1 | \[ \frac{\color{blue}{1 \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)}}{\log 10}
\] |
add-sqr-sqrt [=>]99.1 | \[ \frac{1 \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)}{\color{blue}{\sqrt{\log 10} \cdot \sqrt{\log 10}}}
\] |
times-frac [=>]99.1 | \[ \color{blue}{\frac{1}{\sqrt{\log 10}} \cdot \frac{\log \left(\mathsf{hypot}\left(re, im\right)\right)}{\sqrt{\log 10}}}
\] |
Final simplification99.1%
| Alternative 1 | |
|---|---|
| Accuracy | 99.1% |
| Cost | 19712 |
| Alternative 2 | |
|---|---|
| Accuracy | 99.1% |
| Cost | 19456 |
| Alternative 3 | |
|---|---|
| Accuracy | 44.0% |
| Cost | 13444 |
| Alternative 4 | |
|---|---|
| Accuracy | 44.0% |
| Cost | 13380 |
| Alternative 5 | |
|---|---|
| Accuracy | 44.0% |
| Cost | 13316 |
| Alternative 6 | |
|---|---|
| Accuracy | 44.0% |
| Cost | 13252 |
| Alternative 7 | |
|---|---|
| Accuracy | 3.1% |
| Cost | 12992 |
| Alternative 8 | |
|---|---|
| Accuracy | 27.7% |
| Cost | 12992 |
herbie shell --seed 2023159
(FPCore (re im)
:name "math.log10 on complex, real part"
:precision binary64
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))