| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32320 |
\[\log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \sqrt[3]{{\log 10}^{-3}}
\]

(FPCore (re im) :precision binary64 (/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))
(FPCore (re im) :precision binary64 (* (log (hypot re im)) (cbrt (pow (log 10.0) -3.0))))
double code(double re, double im) {
return log(sqrt(((re * re) + (im * im)))) / log(10.0);
}
double code(double re, double im) {
return log(hypot(re, im)) * cbrt(pow(log(10.0), -3.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) {
return Math.log(Math.hypot(re, im)) * Math.cbrt(Math.pow(Math.log(10.0), -3.0));
}
function code(re, im) return Float64(log(sqrt(Float64(Float64(re * re) + Float64(im * im)))) / log(10.0)) end
function code(re, im) return Float64(log(hypot(re, im)) * cbrt((log(10.0) ^ -3.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_] := N[(N[Log[N[Sqrt[re ^ 2 + im ^ 2], $MachinePrecision]], $MachinePrecision] * N[Power[N[Power[N[Log[10.0], $MachinePrecision], -3.0], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision]
\frac{\log \left(\sqrt{re \cdot re + im \cdot im}\right)}{\log 10}
\log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \sqrt[3]{{\log 10}^{-3}}
Herbie found 5 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Results
Initial program 50.3%
Simplified99.1%
[Start]50.3% | \[ \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-rr98.8%
[Start]99.1% | \[ \frac{\log \left(\mathsf{hypot}\left(re, im\right)\right)}{\log 10}
\] |
|---|---|
add-cbrt-cube [=>]99.0% | \[ \frac{\color{blue}{\sqrt[3]{\left(\log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)}}}{\log 10}
\] |
add-cbrt-cube [=>]98.0% | \[ \frac{\sqrt[3]{\left(\log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)}}{\color{blue}{\sqrt[3]{\left(\log 10 \cdot \log 10\right) \cdot \log 10}}}
\] |
cbrt-undiv [=>]98.9% | \[ \color{blue}{\sqrt[3]{\frac{\left(\log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)\right) \cdot \log \left(\mathsf{hypot}\left(re, im\right)\right)}{\left(\log 10 \cdot \log 10\right) \cdot \log 10}}}
\] |
pow3 [=>]98.8% | \[ \sqrt[3]{\frac{\color{blue}{{\log \left(\mathsf{hypot}\left(re, im\right)\right)}^{3}}}{\left(\log 10 \cdot \log 10\right) \cdot \log 10}}
\] |
pow3 [=>]98.8% | \[ \sqrt[3]{\frac{{\log \left(\mathsf{hypot}\left(re, im\right)\right)}^{3}}{\color{blue}{{\log 10}^{3}}}}
\] |
Applied egg-rr99.5%
[Start]98.8% | \[ \sqrt[3]{\frac{{\log \left(\mathsf{hypot}\left(re, im\right)\right)}^{3}}{{\log 10}^{3}}}
\] |
|---|---|
div-inv [=>]98.8% | \[ \sqrt[3]{\color{blue}{{\log \left(\mathsf{hypot}\left(re, im\right)\right)}^{3} \cdot \frac{1}{{\log 10}^{3}}}}
\] |
cbrt-prod [=>]98.7% | \[ \color{blue}{\sqrt[3]{{\log \left(\mathsf{hypot}\left(re, im\right)\right)}^{3}} \cdot \sqrt[3]{\frac{1}{{\log 10}^{3}}}}
\] |
rem-cbrt-cube [=>]98.5% | \[ \color{blue}{\log \left(\mathsf{hypot}\left(re, im\right)\right)} \cdot \sqrt[3]{\frac{1}{{\log 10}^{3}}}
\] |
pow-flip [=>]99.5% | \[ \log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \sqrt[3]{\color{blue}{{\log 10}^{\left(-3\right)}}}
\] |
metadata-eval [=>]99.5% | \[ \log \left(\mathsf{hypot}\left(re, im\right)\right) \cdot \sqrt[3]{{\log 10}^{\color{blue}{-3}}}
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32320 |
| Alternative 2 | |
|---|---|
| Accuracy | 99.1% |
| Cost | 19456 |
| Alternative 3 | |
|---|---|
| Accuracy | 43.6% |
| Cost | 13316 |
| Alternative 4 | |
|---|---|
| Accuracy | 3.0% |
| Cost | 12992 |
| Alternative 5 | |
|---|---|
| Accuracy | 27.0% |
| Cost | 12992 |
herbie shell --seed 2023263
(FPCore (re im)
:name "math.log10 on complex, real part"
:precision binary64
(/ (log (sqrt (+ (* re re) (* im im)))) (log 10.0)))