| Alternative 1 | |
|---|---|
| Accuracy | 98.5% |
| Cost | 36168 |

(FPCore (x) :precision binary32 (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1.0)))) x))
(FPCore (x)
:precision binary32
(let* ((t_0 (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1.0)))) x)))
(if (<= t_0 -5.0)
(copysign (log (/ -0.5 x)) x)
(if (<= t_0 0.4000000059604645)
(copysign
(+
(* -0.16666666666666666 (pow x 3.0))
(+ (* 0.075 (pow x 5.0)) (+ x (* -0.044642857142857144 (pow x 7.0)))))
x)
(copysign (log (+ x (hypot 1.0 x))) x)))))float code(float x) {
return copysignf(logf((fabsf(x) + sqrtf(((x * x) + 1.0f)))), x);
}
float code(float x) {
float t_0 = copysignf(logf((fabsf(x) + sqrtf(((x * x) + 1.0f)))), x);
float tmp;
if (t_0 <= -5.0f) {
tmp = copysignf(logf((-0.5f / x)), x);
} else if (t_0 <= 0.4000000059604645f) {
tmp = copysignf(((-0.16666666666666666f * powf(x, 3.0f)) + ((0.075f * powf(x, 5.0f)) + (x + (-0.044642857142857144f * powf(x, 7.0f))))), x);
} else {
tmp = copysignf(logf((x + hypotf(1.0f, x))), x);
}
return tmp;
}
function code(x) return copysign(log(Float32(abs(x) + sqrt(Float32(Float32(x * x) + Float32(1.0))))), x) end
function code(x) t_0 = copysign(log(Float32(abs(x) + sqrt(Float32(Float32(x * x) + Float32(1.0))))), x) tmp = Float32(0.0) if (t_0 <= Float32(-5.0)) tmp = copysign(log(Float32(Float32(-0.5) / x)), x); elseif (t_0 <= Float32(0.4000000059604645)) tmp = copysign(Float32(Float32(Float32(-0.16666666666666666) * (x ^ Float32(3.0))) + Float32(Float32(Float32(0.075) * (x ^ Float32(5.0))) + Float32(x + Float32(Float32(-0.044642857142857144) * (x ^ Float32(7.0)))))), x); else tmp = copysign(log(Float32(x + hypot(Float32(1.0), x))), x); end return tmp end
function tmp = code(x) tmp = sign(x) * abs(log((abs(x) + sqrt(((x * x) + single(1.0)))))); end
function tmp_2 = code(x) t_0 = sign(x) * abs(log((abs(x) + sqrt(((x * x) + single(1.0)))))); tmp = single(0.0); if (t_0 <= single(-5.0)) tmp = sign(x) * abs(log((single(-0.5) / x))); elseif (t_0 <= single(0.4000000059604645)) tmp = sign(x) * abs(((single(-0.16666666666666666) * (x ^ single(3.0))) + ((single(0.075) * (x ^ single(5.0))) + (x + (single(-0.044642857142857144) * (x ^ single(7.0))))))); else tmp = sign(x) * abs(log((x + hypot(single(1.0), x)))); end tmp_2 = tmp; end
\mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{x \cdot x + 1}\right), x\right)
\begin{array}{l}
t_0 := \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{x \cdot x + 1}\right), x\right)\\
\mathbf{if}\;t_0 \leq -5:\\
\;\;\;\;\mathsf{copysign}\left(\log \left(\frac{-0.5}{x}\right), x\right)\\
\mathbf{elif}\;t_0 \leq 0.4000000059604645:\\
\;\;\;\;\mathsf{copysign}\left(-0.16666666666666666 \cdot {x}^{3} + \left(0.075 \cdot {x}^{5} + \left(x + -0.044642857142857144 \cdot {x}^{7}\right)\right), x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{copysign}\left(\log \left(x + \mathsf{hypot}\left(1, x\right)\right), x\right)\\
\end{array}
Herbie found 12 alternatives:
| Alternative | Accuracy | Speedup |
|---|
| Original | 37.9% |
|---|---|
| Target | 99.5% |
| Herbie | 98.6% |
if (copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) 1)))) x) < -5Initial program 40.0%
Simplified95.8%
[Start]40.0 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{x \cdot x + 1}\right), x\right)
\] |
|---|---|
+-commutative [=>]40.0 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{\color{blue}{1 + x \cdot x}}\right), x\right)
\] |
hypot-1-def [=>]95.8 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \color{blue}{\mathsf{hypot}\left(1, x\right)}\right), x\right)
\] |
Taylor expanded in x around -inf 95.8%
Simplified99.9%
[Start]95.8 | \[ \mathsf{copysign}\left(\log \left(\left(\left|x\right| + -1 \cdot x\right) - 0.5 \cdot \frac{1}{x}\right), x\right)
\] |
|---|---|
associate--l+ [=>]95.8 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(\left|x\right| + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right)}, x\right)
\] |
unpow1 [<=]95.8 | \[ \mathsf{copysign}\left(\log \left(\left|\color{blue}{{x}^{1}}\right| + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right), x\right)
\] |
sqr-pow [=>]-0.0 | \[ \mathsf{copysign}\left(\log \left(\left|\color{blue}{{x}^{\left(\frac{1}{2}\right)} \cdot {x}^{\left(\frac{1}{2}\right)}}\right| + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right), x\right)
\] |
fabs-sqr [=>]-0.0 | \[ \mathsf{copysign}\left(\log \left(\color{blue}{{x}^{\left(\frac{1}{2}\right)} \cdot {x}^{\left(\frac{1}{2}\right)}} + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right), x\right)
\] |
sqr-pow [<=]8.6 | \[ \mathsf{copysign}\left(\log \left(\color{blue}{{x}^{1}} + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right), x\right)
\] |
unpow1 [=>]8.6 | \[ \mathsf{copysign}\left(\log \left(\color{blue}{x} + \left(-1 \cdot x - 0.5 \cdot \frac{1}{x}\right)\right), x\right)
\] |
associate-+r- [=>]99.9 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(\left(x + -1 \cdot x\right) - 0.5 \cdot \frac{1}{x}\right)}, x\right)
\] |
mul-1-neg [=>]99.9 | \[ \mathsf{copysign}\left(\log \left(\left(x + \color{blue}{\left(-x\right)}\right) - 0.5 \cdot \frac{1}{x}\right), x\right)
\] |
sub-neg [<=]99.9 | \[ \mathsf{copysign}\left(\log \left(\color{blue}{\left(x - x\right)} - 0.5 \cdot \frac{1}{x}\right), x\right)
\] |
+-inverses [=>]99.9 | \[ \mathsf{copysign}\left(\log \left(\color{blue}{0} - 0.5 \cdot \frac{1}{x}\right), x\right)
\] |
neg-sub0 [<=]99.9 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(-0.5 \cdot \frac{1}{x}\right)}, x\right)
\] |
associate-*r/ [=>]99.9 | \[ \mathsf{copysign}\left(\log \left(-\color{blue}{\frac{0.5 \cdot 1}{x}}\right), x\right)
\] |
metadata-eval [=>]99.9 | \[ \mathsf{copysign}\left(\log \left(-\frac{\color{blue}{0.5}}{x}\right), x\right)
\] |
distribute-neg-frac [=>]99.9 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(\frac{-0.5}{x}\right)}, x\right)
\] |
metadata-eval [=>]99.9 | \[ \mathsf{copysign}\left(\log \left(\frac{\color{blue}{-0.5}}{x}\right), x\right)
\] |
if -5 < (copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) 1)))) x) < 0.400000006Initial program 19.2%
Simplified19.4%
[Start]19.2 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{x \cdot x + 1}\right), x\right)
\] |
|---|---|
+-commutative [=>]19.2 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{\color{blue}{1 + x \cdot x}}\right), x\right)
\] |
hypot-1-def [=>]19.4 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \color{blue}{\mathsf{hypot}\left(1, x\right)}\right), x\right)
\] |
Applied egg-rr18.5%
[Start]19.4 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
|---|---|
add-sqr-sqrt [=>]18.6 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(\sqrt{\left|x\right| + \mathsf{hypot}\left(1, x\right)} \cdot \sqrt{\left|x\right| + \mathsf{hypot}\left(1, x\right)}\right)}, x\right)
\] |
pow2 [=>]18.6 | \[ \mathsf{copysign}\left(\log \color{blue}{\left({\left(\sqrt{\left|x\right| + \mathsf{hypot}\left(1, x\right)}\right)}^{2}\right)}, x\right)
\] |
add-sqr-sqrt [=>]8.5 | \[ \mathsf{copysign}\left(\log \left({\left(\sqrt{\left|\color{blue}{\sqrt{x} \cdot \sqrt{x}}\right| + \mathsf{hypot}\left(1, x\right)}\right)}^{2}\right), x\right)
\] |
fabs-sqr [=>]8.5 | \[ \mathsf{copysign}\left(\log \left({\left(\sqrt{\color{blue}{\sqrt{x} \cdot \sqrt{x}} + \mathsf{hypot}\left(1, x\right)}\right)}^{2}\right), x\right)
\] |
add-sqr-sqrt [<=]18.5 | \[ \mathsf{copysign}\left(\log \left({\left(\sqrt{\color{blue}{x} + \mathsf{hypot}\left(1, x\right)}\right)}^{2}\right), x\right)
\] |
Taylor expanded in x around 0 99.0%
if 0.400000006 < (copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) 1)))) x) Initial program 51.9%
Simplified100.0%
[Start]51.9 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{x \cdot x + 1}\right), x\right)
\] |
|---|---|
+-commutative [=>]51.9 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \sqrt{\color{blue}{1 + x \cdot x}}\right), x\right)
\] |
hypot-1-def [=>]100.0 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \color{blue}{\mathsf{hypot}\left(1, x\right)}\right), x\right)
\] |
Applied egg-rr100.0%
[Start]100.0 | \[ \mathsf{copysign}\left(\log \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
|---|---|
*-un-lft-identity [=>]100.0 | \[ \mathsf{copysign}\left(\log \color{blue}{\left(1 \cdot \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right)\right)}, x\right)
\] |
log-prod [=>]100.0 | \[ \mathsf{copysign}\left(\color{blue}{\log 1 + \log \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right)}, x\right)
\] |
metadata-eval [=>]100.0 | \[ \mathsf{copysign}\left(\color{blue}{0} + \log \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
*-un-lft-identity [=>]100.0 | \[ \mathsf{copysign}\left(0 + \log \color{blue}{\left(1 \cdot \left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right)\right)}, x\right)
\] |
*-un-lft-identity [<=]100.0 | \[ \mathsf{copysign}\left(0 + \log \color{blue}{\left(\left|x\right| + \mathsf{hypot}\left(1, x\right)\right)}, x\right)
\] |
add-sqr-sqrt [=>]100.0 | \[ \mathsf{copysign}\left(0 + \log \left(\left|\color{blue}{\sqrt{x} \cdot \sqrt{x}}\right| + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
fabs-sqr [=>]100.0 | \[ \mathsf{copysign}\left(0 + \log \left(\color{blue}{\sqrt{x} \cdot \sqrt{x}} + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
add-sqr-sqrt [<=]100.0 | \[ \mathsf{copysign}\left(0 + \log \left(\color{blue}{x} + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
Simplified100.0%
[Start]100.0 | \[ \mathsf{copysign}\left(0 + \log \left(x + \mathsf{hypot}\left(1, x\right)\right), x\right)
\] |
|---|---|
+-lft-identity [=>]100.0 | \[ \mathsf{copysign}\left(\color{blue}{\log \left(x + \mathsf{hypot}\left(1, x\right)\right)}, x\right)
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 98.5% |
| Cost | 36168 |
| Alternative 2 | |
|---|---|
| Accuracy | 97.7% |
| Cost | 9896 |
| Alternative 3 | |
|---|---|
| Accuracy | 97.5% |
| Cost | 6856 |
| Alternative 4 | |
|---|---|
| Accuracy | 97.5% |
| Cost | 6792 |
| Alternative 5 | |
|---|---|
| Accuracy | 97.4% |
| Cost | 6760 |
| Alternative 6 | |
|---|---|
| Accuracy | 97.4% |
| Cost | 6696 |
| Alternative 7 | |
|---|---|
| Accuracy | 84.2% |
| Cost | 6664 |
| Alternative 8 | |
|---|---|
| Accuracy | 97.2% |
| Cost | 6664 |
| Alternative 9 | |
|---|---|
| Accuracy | 68.6% |
| Cost | 6564 |
| Alternative 10 | |
|---|---|
| Accuracy | 62.1% |
| Cost | 6532 |
| Alternative 11 | |
|---|---|
| Accuracy | 53.7% |
| Cost | 3264 |
herbie shell --seed 2023161
(FPCore (x)
:name "Rust f32::asinh"
:precision binary32
:herbie-target
(copysign (log1p (+ (fabs x) (/ (fabs x) (+ (hypot 1.0 (/ 1.0 (fabs x))) (/ 1.0 (fabs x)))))) x)
(copysign (log (+ (fabs x) (sqrt (+ (* x x) 1.0)))) x))