
(FPCore (x s) :precision binary32 (/ 1.0 (+ 1.0 (exp (/ (- x) s)))))
float code(float x, float s) {
return 1.0f / (1.0f + expf((-x / s)));
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
code = 1.0e0 / (1.0e0 + exp((-x / s)))
end function
function code(x, s) return Float32(Float32(1.0) / Float32(Float32(1.0) + exp(Float32(Float32(-x) / s)))) end
function tmp = code(x, s) tmp = single(1.0) / (single(1.0) + exp((-x / s))); end
\begin{array}{l}
\\
\frac{1}{1 + e^{\frac{-x}{s}}}
\end{array}
Sampling outcomes in binary32 precision:
Herbie found 12 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x s) :precision binary32 (/ 1.0 (+ 1.0 (exp (/ (- x) s)))))
float code(float x, float s) {
return 1.0f / (1.0f + expf((-x / s)));
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
code = 1.0e0 / (1.0e0 + exp((-x / s)))
end function
function code(x, s) return Float32(Float32(1.0) / Float32(Float32(1.0) + exp(Float32(Float32(-x) / s)))) end
function tmp = code(x, s) tmp = single(1.0) / (single(1.0) + exp((-x / s))); end
\begin{array}{l}
\\
\frac{1}{1 + e^{\frac{-x}{s}}}
\end{array}
(FPCore (x s) :precision binary32 (/ 1.0 (+ 1.0 (pow E (- 0.0 (/ x s))))))
float code(float x, float s) {
return 1.0f / (1.0f + powf(((float) M_E), (0.0f - (x / s))));
}
function code(x, s) return Float32(Float32(1.0) / Float32(Float32(1.0) + (Float32(exp(1)) ^ Float32(Float32(0.0) - Float32(x / s))))) end
function tmp = code(x, s) tmp = single(1.0) / (single(1.0) + (single(2.71828182845904523536) ^ (single(0.0) - (x / s)))); end
\begin{array}{l}
\\
\frac{1}{1 + {e}^{\left(0 - \frac{x}{s}\right)}}
\end{array}
Initial program 99.9%
*-lft-identityN/A
exp-prodN/A
pow-lowering-pow.f32N/A
exp-1-eN/A
E-lowering-E.f32N/A
clear-numN/A
frac-2negN/A
metadata-evalN/A
/-lowering-/.f32N/A
distribute-frac-neg2N/A
remove-double-negN/A
/-lowering-/.f3299.9%
Applied egg-rr99.9%
associate-/r/N/A
associate-*l/N/A
neg-mul-1N/A
/-lowering-/.f32N/A
neg-lowering-neg.f3299.9%
Applied egg-rr99.9%
Final simplification99.9%
(FPCore (x s) :precision binary32 (/ 1.0 (+ 1.0 (/ 1.0 (exp (/ x s))))))
float code(float x, float s) {
return 1.0f / (1.0f + (1.0f / expf((x / s))));
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
code = 1.0e0 / (1.0e0 + (1.0e0 / exp((x / s))))
end function
function code(x, s) return Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / exp(Float32(x / s))))) end
function tmp = code(x, s) tmp = single(1.0) / (single(1.0) + (single(1.0) / exp((x / s)))); end
\begin{array}{l}
\\
\frac{1}{1 + \frac{1}{e^{\frac{x}{s}}}}
\end{array}
Initial program 99.9%
distribute-frac-negN/A
exp-negN/A
/-lowering-/.f32N/A
exp-lowering-exp.f32N/A
/-lowering-/.f3299.9%
Applied egg-rr99.9%
(FPCore (x s) :precision binary32 (/ 1.0 (+ 1.0 (exp (- 0.0 (/ x s))))))
float code(float x, float s) {
return 1.0f / (1.0f + expf((0.0f - (x / s))));
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
code = 1.0e0 / (1.0e0 + exp((0.0e0 - (x / s))))
end function
function code(x, s) return Float32(Float32(1.0) / Float32(Float32(1.0) + exp(Float32(Float32(0.0) - Float32(x / s))))) end
function tmp = code(x, s) tmp = single(1.0) / (single(1.0) + exp((single(0.0) - (x / s)))); end
\begin{array}{l}
\\
\frac{1}{1 + e^{0 - \frac{x}{s}}}
\end{array}
Initial program 99.9%
Final simplification99.9%
(FPCore (x s)
:precision binary32
(if (<= x -5.000000136226006e-28)
(/
1.0
(+
2.0
(*
x
(+
(* (/ x (* s s)) (+ (/ (* x -0.16666666666666666) s) 0.5))
(/ -1.0 s)))))
0.5))
float code(float x, float s) {
float tmp;
if (x <= -5.000000136226006e-28f) {
tmp = 1.0f / (2.0f + (x * (((x / (s * s)) * (((x * -0.16666666666666666f) / s) + 0.5f)) + (-1.0f / s))));
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-5.000000136226006e-28)) then
tmp = 1.0e0 / (2.0e0 + (x * (((x / (s * s)) * (((x * (-0.16666666666666666e0)) / s) + 0.5e0)) + ((-1.0e0) / s))))
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-5.000000136226006e-28)) tmp = Float32(Float32(1.0) / Float32(Float32(2.0) + Float32(x * Float32(Float32(Float32(x / Float32(s * s)) * Float32(Float32(Float32(x * Float32(-0.16666666666666666)) / s) + Float32(0.5))) + Float32(Float32(-1.0) / s))))); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-5.000000136226006e-28)) tmp = single(1.0) / (single(2.0) + (x * (((x / (s * s)) * (((x * single(-0.16666666666666666)) / s) + single(0.5))) + (single(-1.0) / s)))); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -5.000000136226006 \cdot 10^{-28}:\\
\;\;\;\;\frac{1}{2 + x \cdot \left(\frac{x}{s \cdot s} \cdot \left(\frac{x \cdot -0.16666666666666666}{s} + 0.5\right) + \frac{-1}{s}\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -5.00000014e-28Initial program 100.0%
Taylor expanded in x around 0
Simplified89.8%
if -5.00000014e-28 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified47.3%
(FPCore (x s)
:precision binary32
(if (<= x -1.0000000036274937e-15)
(/
1.0
(*
(* x (* x x))
(+ (/ 0.5 (* x (* s s))) (/ -0.16666666666666666 (* s (* s s))))))
0.5))
float code(float x, float s) {
float tmp;
if (x <= -1.0000000036274937e-15f) {
tmp = 1.0f / ((x * (x * x)) * ((0.5f / (x * (s * s))) + (-0.16666666666666666f / (s * (s * s)))));
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-1.0000000036274937e-15)) then
tmp = 1.0e0 / ((x * (x * x)) * ((0.5e0 / (x * (s * s))) + ((-0.16666666666666666e0) / (s * (s * s)))))
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-1.0000000036274937e-15)) tmp = Float32(Float32(1.0) / Float32(Float32(x * Float32(x * x)) * Float32(Float32(Float32(0.5) / Float32(x * Float32(s * s))) + Float32(Float32(-0.16666666666666666) / Float32(s * Float32(s * s)))))); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-1.0000000036274937e-15)) tmp = single(1.0) / ((x * (x * x)) * ((single(0.5) / (x * (s * s))) + (single(-0.16666666666666666) / (s * (s * s))))); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -1.0000000036274937 \cdot 10^{-15}:\\
\;\;\;\;\frac{1}{\left(x \cdot \left(x \cdot x\right)\right) \cdot \left(\frac{0.5}{x \cdot \left(s \cdot s\right)} + \frac{-0.16666666666666666}{s \cdot \left(s \cdot s\right)}\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -1e-15Initial program 100.0%
Taylor expanded in s around -inf
+-lowering-+.f32N/A
associate-*r/N/A
/-lowering-/.f32N/A
Simplified84.9%
Taylor expanded in x around inf
*-lowering-*.f32N/A
cube-multN/A
unpow2N/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f32N/A
sub-negN/A
associate-*r/N/A
metadata-evalN/A
+-lowering-+.f32N/A
/-lowering-/.f32N/A
*-commutativeN/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f32N/A
associate-*r/N/A
metadata-evalN/A
distribute-neg-fracN/A
metadata-evalN/A
/-lowering-/.f32N/A
cube-multN/A
unpow2N/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f3293.3%
Simplified93.3%
if -1e-15 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified48.5%
(FPCore (x s) :precision binary32 (if (<= x -1.0000000036274937e-15) (/ (* (* s s) (* s -6.0)) (* x (* x x))) 0.5))
float code(float x, float s) {
float tmp;
if (x <= -1.0000000036274937e-15f) {
tmp = ((s * s) * (s * -6.0f)) / (x * (x * x));
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-1.0000000036274937e-15)) then
tmp = ((s * s) * (s * (-6.0e0))) / (x * (x * x))
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-1.0000000036274937e-15)) tmp = Float32(Float32(Float32(s * s) * Float32(s * Float32(-6.0))) / Float32(x * Float32(x * x))); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-1.0000000036274937e-15)) tmp = ((s * s) * (s * single(-6.0))) / (x * (x * x)); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -1.0000000036274937 \cdot 10^{-15}:\\
\;\;\;\;\frac{\left(s \cdot s\right) \cdot \left(s \cdot -6\right)}{x \cdot \left(x \cdot x\right)}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -1e-15Initial program 100.0%
Taylor expanded in s around -inf
+-lowering-+.f32N/A
associate-*r/N/A
/-lowering-/.f32N/A
Simplified84.9%
Taylor expanded in x around inf
associate-*r/N/A
/-lowering-/.f32N/A
*-commutativeN/A
unpow3N/A
unpow2N/A
associate-*l*N/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f32N/A
*-lowering-*.f32N/A
cube-multN/A
unpow2N/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f3291.9%
Simplified91.9%
if -1e-15 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified48.5%
(FPCore (x s) :precision binary32 (if (<= x -9.99999983775159e-18) (/ (/ (* (* s s) -2.0) x) x) 0.5))
float code(float x, float s) {
float tmp;
if (x <= -9.99999983775159e-18f) {
tmp = (((s * s) * -2.0f) / x) / x;
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-9.99999983775159e-18)) then
tmp = (((s * s) * (-2.0e0)) / x) / x
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-9.99999983775159e-18)) tmp = Float32(Float32(Float32(Float32(s * s) * Float32(-2.0)) / x) / x); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-9.99999983775159e-18)) tmp = (((s * s) * single(-2.0)) / x) / x; else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -9.99999983775159 \cdot 10^{-18}:\\
\;\;\;\;\frac{\frac{\left(s \cdot s\right) \cdot -2}{x}}{x}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -9.99999984e-18Initial program 100.0%
Taylor expanded in x around 0
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
/-lowering-/.f3241.4%
Simplified41.4%
Taylor expanded in x around inf
+-commutativeN/A
metadata-evalN/A
cancel-sign-sub-invN/A
/-lowering-/.f32N/A
cancel-sign-sub-invN/A
metadata-evalN/A
+-commutativeN/A
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
associate-*r/N/A
metadata-evalN/A
/-lowering-/.f32N/A
metadata-evalN/A
*-commutativeN/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f3235.1%
Simplified35.1%
Taylor expanded in s around inf
associate-*r/N/A
/-lowering-/.f32N/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f3276.2%
Simplified76.2%
if -9.99999984e-18 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified49.2%
Final simplification57.8%
(FPCore (x s) :precision binary32 (if (<= x -1.0000000036274937e-15) (* -2.0 (* s (/ s (* x x)))) 0.5))
float code(float x, float s) {
float tmp;
if (x <= -1.0000000036274937e-15f) {
tmp = -2.0f * (s * (s / (x * x)));
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-1.0000000036274937e-15)) then
tmp = (-2.0e0) * (s * (s / (x * x)))
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-1.0000000036274937e-15)) tmp = Float32(Float32(-2.0) * Float32(s * Float32(s / Float32(x * x)))); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-1.0000000036274937e-15)) tmp = single(-2.0) * (s * (s / (x * x))); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -1.0000000036274937 \cdot 10^{-15}:\\
\;\;\;\;-2 \cdot \left(s \cdot \frac{s}{x \cdot x}\right)\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -1e-15Initial program 100.0%
Taylor expanded in x around 0
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
/-lowering-/.f3242.2%
Simplified42.2%
Taylor expanded in x around inf
+-commutativeN/A
metadata-evalN/A
cancel-sign-sub-invN/A
/-lowering-/.f32N/A
cancel-sign-sub-invN/A
metadata-evalN/A
+-commutativeN/A
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
associate-*r/N/A
metadata-evalN/A
/-lowering-/.f32N/A
metadata-evalN/A
*-commutativeN/A
*-lowering-*.f32N/A
unpow2N/A
*-lowering-*.f3236.6%
Simplified36.6%
Taylor expanded in s around inf
*-lowering-*.f32N/A
unpow2N/A
associate-/l*N/A
*-lowering-*.f32N/A
/-lowering-/.f32N/A
unpow2N/A
*-lowering-*.f3271.6%
Simplified71.6%
if -1e-15 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified48.5%
(FPCore (x s) :precision binary32 (if (<= x 4.999999943633011e-27) (/ 1.0 (- 2.0 (/ x s))) 0.5))
float code(float x, float s) {
float tmp;
if (x <= 4.999999943633011e-27f) {
tmp = 1.0f / (2.0f - (x / s));
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= 4.999999943633011e-27) then
tmp = 1.0e0 / (2.0e0 - (x / s))
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(4.999999943633011e-27)) tmp = Float32(Float32(1.0) / Float32(Float32(2.0) - Float32(x / s))); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(4.999999943633011e-27)) tmp = single(1.0) / (single(2.0) - (x / s)); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq 4.999999943633011 \cdot 10^{-27}:\\
\;\;\;\;\frac{1}{2 - \frac{x}{s}}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < 4.99999994e-27Initial program 99.8%
Taylor expanded in x around 0
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
/-lowering-/.f3258.7%
Simplified58.7%
if 4.99999994e-27 < x Initial program 100.0%
Taylor expanded in x around 0
Simplified35.1%
(FPCore (x s) :precision binary32 (if (<= x -1.0000000036274937e-15) (/ -1.0 (/ x s)) 0.5))
float code(float x, float s) {
float tmp;
if (x <= -1.0000000036274937e-15f) {
tmp = -1.0f / (x / s);
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-1.0000000036274937e-15)) then
tmp = (-1.0e0) / (x / s)
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-1.0000000036274937e-15)) tmp = Float32(Float32(-1.0) / Float32(x / s)); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-1.0000000036274937e-15)) tmp = single(-1.0) / (x / s); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -1.0000000036274937 \cdot 10^{-15}:\\
\;\;\;\;\frac{-1}{\frac{x}{s}}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -1e-15Initial program 100.0%
Taylor expanded in x around 0
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
/-lowering-/.f3242.2%
Simplified42.2%
Taylor expanded in x around inf
mul-1-negN/A
neg-sub0N/A
--lowering--.f32N/A
/-lowering-/.f3237.2%
Simplified37.2%
sub0-negN/A
clear-numN/A
distribute-neg-fracN/A
metadata-evalN/A
/-lowering-/.f32N/A
/-lowering-/.f3241.8%
Applied egg-rr41.8%
if -1e-15 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified48.5%
(FPCore (x s) :precision binary32 (if (<= x -1.0000000036274937e-15) (- 0.0 (/ s x)) 0.5))
float code(float x, float s) {
float tmp;
if (x <= -1.0000000036274937e-15f) {
tmp = 0.0f - (s / x);
} else {
tmp = 0.5f;
}
return tmp;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
real(4) :: tmp
if (x <= (-1.0000000036274937e-15)) then
tmp = 0.0e0 - (s / x)
else
tmp = 0.5e0
end if
code = tmp
end function
function code(x, s) tmp = Float32(0.0) if (x <= Float32(-1.0000000036274937e-15)) tmp = Float32(Float32(0.0) - Float32(s / x)); else tmp = Float32(0.5); end return tmp end
function tmp_2 = code(x, s) tmp = single(0.0); if (x <= single(-1.0000000036274937e-15)) tmp = single(0.0) - (s / x); else tmp = single(0.5); end tmp_2 = tmp; end
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -1.0000000036274937 \cdot 10^{-15}:\\
\;\;\;\;0 - \frac{s}{x}\\
\mathbf{else}:\\
\;\;\;\;0.5\\
\end{array}
\end{array}
if x < -1e-15Initial program 100.0%
Taylor expanded in x around 0
mul-1-negN/A
unsub-negN/A
--lowering--.f32N/A
/-lowering-/.f3242.2%
Simplified42.2%
Taylor expanded in x around inf
mul-1-negN/A
neg-sub0N/A
--lowering--.f32N/A
/-lowering-/.f3237.2%
Simplified37.2%
sub0-negN/A
distribute-neg-fracN/A
/-lowering-/.f32N/A
neg-lowering-neg.f3237.2%
Applied egg-rr37.2%
if -1e-15 < x Initial program 99.9%
Taylor expanded in x around 0
Simplified48.5%
Final simplification45.1%
(FPCore (x s) :precision binary32 0.5)
float code(float x, float s) {
return 0.5f;
}
real(4) function code(x, s)
real(4), intent (in) :: x
real(4), intent (in) :: s
code = 0.5e0
end function
function code(x, s) return Float32(0.5) end
function tmp = code(x, s) tmp = single(0.5); end
\begin{array}{l}
\\
0.5
\end{array}
Initial program 99.9%
Taylor expanded in x around 0
Simplified36.0%
herbie shell --seed 2024191
(FPCore (x s)
:name "Logistic function"
:precision binary32
:pre (and (<= 0.0 s) (<= s 1.0651631))
(/ 1.0 (+ 1.0 (exp (/ (- x) s)))))