Logistic function

Percentage Accurate: 99.8% → 99.8%
Time: 11.4s
Alternatives: 17
Speedup: 1.0×

Specification

?
\[0 \leq s \land s \leq 1.0651631\]
\[\begin{array}{l} \\ \frac{1}{1 + e^{\frac{-x}{s}}} \end{array} \]
(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:

Local Percentage Accuracy vs ?

The average percentage accuracy by input value. Horizontal axis shows value of an input variable; the variable is choosen in the title. Vertical axis is accuracy; higher is better. Red represent the original program, while blue represents Herbie's suggestion. These can be toggled with buttons below the plot. The line is an average while dots represent individual samples.

Accuracy vs Speed?

Herbie found 17 alternatives:

AlternativeAccuracySpeedup
The accuracy (vertical axis) and speed (horizontal axis) of each alternatives. Up and to the right is better. The red square shows the initial program, and each blue circle shows an alternative.The line shows the best available speed-accuracy tradeoffs.

Initial Program: 99.8% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{1}{1 + e^{\frac{-x}{s}}} \end{array} \]
(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}

Alternative 1: 99.8% accurate, 0.3× speedup?

\[\begin{array}{l} \\ \frac{1}{1 + e^{\frac{1}{\frac{s}{x} \cdot -1.5}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \end{array} \]
(FPCore (x s)
 :precision binary32
 (/
  1.0
  (+ 1.0 (* (exp (/ 1.0 (* (/ s x) -1.5))) (pow (cbrt (exp -1.0)) (/ x s))))))
float code(float x, float s) {
	return 1.0f / (1.0f + (expf((1.0f / ((s / x) * -1.5f))) * powf(cbrtf(expf(-1.0f)), (x / s))));
}
function code(x, s)
	return Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(exp(Float32(Float32(1.0) / Float32(Float32(s / x) * Float32(-1.5)))) * (cbrt(exp(Float32(-1.0))) ^ Float32(x / s)))))
end
\begin{array}{l}

\\
\frac{1}{1 + e^{\frac{1}{\frac{s}{x} \cdot -1.5}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}}
\end{array}
Derivation
  1. Initial program 99.8%

    \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
  2. Step-by-step derivation
    1. distribute-frac-neg99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
    2. exp-neg99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. add-sqr-sqrt45.7%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
    4. sqrt-unprod54.1%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
    5. sqr-neg54.1%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
    6. sqrt-unprod9.9%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
    7. add-sqr-sqrt22.7%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
    8. add-cube-cbrt22.7%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
    9. pow322.7%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
    10. pow-flip22.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
    11. add-sqr-sqrt9.9%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
    12. sqrt-unprod54.1%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
    13. sqr-neg54.1%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
    14. sqrt-unprod45.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
    15. add-sqr-sqrt99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
    16. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
  3. Applied egg-rr99.7%

    \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
  4. Step-by-step derivation
    1. pow1/399.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left({\left(e^{\frac{x}{s}}\right)}^{0.3333333333333333}\right)}}^{-3}} \]
    2. pow-pow99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(e^{\frac{x}{s}}\right)}^{\left(0.3333333333333333 \cdot -3\right)}}} \]
    3. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(e^{\frac{x}{s}}\right)}^{\color{blue}{-1}}} \]
    4. pow-exp99.8%

      \[\leadsto \frac{1}{1 + \color{blue}{e^{\frac{x}{s} \cdot -1}}} \]
    5. *-commutative99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{-1 \cdot \frac{x}{s}}}} \]
    6. pow-exp99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(e^{-1}\right)}^{\left(\frac{x}{s}\right)}}} \]
    7. add-cube-cbrt99.6%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(\left(\sqrt[3]{e^{-1}} \cdot \sqrt[3]{e^{-1}}\right) \cdot \sqrt[3]{e^{-1}}\right)}}^{\left(\frac{x}{s}\right)}} \]
    8. unpow-prod-down99.6%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{-1}} \cdot \sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}}} \]
    9. cbrt-unprod99.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(\sqrt[3]{e^{-1} \cdot e^{-1}}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    10. prod-exp99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{\color{blue}{e^{-1 + -1}}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    11. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\color{blue}{-2}}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  5. Applied egg-rr99.7%

    \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{-2}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}}} \]
  6. Step-by-step derivation
    1. pow1/399.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left({\left(e^{-2}\right)}^{0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    2. pow-exp99.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(e^{-2 \cdot 0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    3. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(e^{\color{blue}{-0.6666666666666666}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    4. exp-prod99.8%

      \[\leadsto \frac{1}{1 + \color{blue}{e^{-0.6666666666666666 \cdot \frac{x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    5. associate-*r/99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  7. Applied egg-rr99.8%

    \[\leadsto \frac{1}{1 + \color{blue}{e^{\frac{-0.6666666666666666 \cdot x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  8. Step-by-step derivation
    1. clear-num99.7%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{\frac{1}{\frac{s}{-0.6666666666666666 \cdot x}}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    2. inv-pow99.7%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{{\left(\frac{s}{-0.6666666666666666 \cdot x}\right)}^{-1}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  9. Applied egg-rr99.7%

    \[\leadsto \frac{1}{1 + e^{\color{blue}{{\left(\frac{s}{-0.6666666666666666 \cdot x}\right)}^{-1}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  10. Step-by-step derivation
    1. unpow-199.7%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{\frac{1}{\frac{s}{-0.6666666666666666 \cdot x}}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    2. *-rgt-identity99.7%

      \[\leadsto \frac{1}{1 + e^{\frac{1}{\frac{\color{blue}{s \cdot 1}}{-0.6666666666666666 \cdot x}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    3. *-commutative99.7%

      \[\leadsto \frac{1}{1 + e^{\frac{1}{\frac{s \cdot 1}{\color{blue}{x \cdot -0.6666666666666666}}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    4. times-frac99.8%

      \[\leadsto \frac{1}{1 + e^{\frac{1}{\color{blue}{\frac{s}{x} \cdot \frac{1}{-0.6666666666666666}}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    5. metadata-eval99.8%

      \[\leadsto \frac{1}{1 + e^{\frac{1}{\frac{s}{x} \cdot \color{blue}{-1.5}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  11. Simplified99.8%

    \[\leadsto \frac{1}{1 + e^{\color{blue}{\frac{1}{\frac{s}{x} \cdot -1.5}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  12. Final simplification99.8%

    \[\leadsto \frac{1}{1 + e^{\frac{1}{\frac{s}{x} \cdot -1.5}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]

Alternative 2: 99.8% accurate, 0.5× speedup?

\[\begin{array}{l} \\ \frac{1}{1 + e^{\frac{x \cdot -0.6666666666666666}{s}} \cdot e^{\frac{x}{s} \cdot -0.3333333333333333}} \end{array} \]
(FPCore (x s)
 :precision binary32
 (/
  1.0
  (+
   1.0
   (*
    (exp (/ (* x -0.6666666666666666) s))
    (exp (* (/ x s) -0.3333333333333333))))))
float code(float x, float s) {
	return 1.0f / (1.0f + (expf(((x * -0.6666666666666666f) / s)) * expf(((x / s) * -0.3333333333333333f))));
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    code = 1.0e0 / (1.0e0 + (exp(((x * (-0.6666666666666666e0)) / s)) * exp(((x / s) * (-0.3333333333333333e0)))))
end function
function code(x, s)
	return Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(exp(Float32(Float32(x * Float32(-0.6666666666666666)) / s)) * exp(Float32(Float32(x / s) * Float32(-0.3333333333333333))))))
end
function tmp = code(x, s)
	tmp = single(1.0) / (single(1.0) + (exp(((x * single(-0.6666666666666666)) / s)) * exp(((x / s) * single(-0.3333333333333333)))));
end
\begin{array}{l}

\\
\frac{1}{1 + e^{\frac{x \cdot -0.6666666666666666}{s}} \cdot e^{\frac{x}{s} \cdot -0.3333333333333333}}
\end{array}
Derivation
  1. Initial program 99.8%

    \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
  2. Step-by-step derivation
    1. distribute-frac-neg99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
    2. exp-neg99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. add-sqr-sqrt45.7%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
    4. sqrt-unprod54.1%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
    5. sqr-neg54.1%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
    6. sqrt-unprod9.9%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
    7. add-sqr-sqrt22.7%

      \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
    8. add-cube-cbrt22.7%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
    9. pow322.7%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
    10. pow-flip22.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
    11. add-sqr-sqrt9.9%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
    12. sqrt-unprod54.1%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
    13. sqr-neg54.1%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
    14. sqrt-unprod45.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
    15. add-sqr-sqrt99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
    16. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
  3. Applied egg-rr99.7%

    \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
  4. Step-by-step derivation
    1. pow1/399.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left({\left(e^{\frac{x}{s}}\right)}^{0.3333333333333333}\right)}}^{-3}} \]
    2. pow-pow99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(e^{\frac{x}{s}}\right)}^{\left(0.3333333333333333 \cdot -3\right)}}} \]
    3. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(e^{\frac{x}{s}}\right)}^{\color{blue}{-1}}} \]
    4. pow-exp99.8%

      \[\leadsto \frac{1}{1 + \color{blue}{e^{\frac{x}{s} \cdot -1}}} \]
    5. *-commutative99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{-1 \cdot \frac{x}{s}}}} \]
    6. pow-exp99.7%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(e^{-1}\right)}^{\left(\frac{x}{s}\right)}}} \]
    7. add-cube-cbrt99.6%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(\left(\sqrt[3]{e^{-1}} \cdot \sqrt[3]{e^{-1}}\right) \cdot \sqrt[3]{e^{-1}}\right)}}^{\left(\frac{x}{s}\right)}} \]
    8. unpow-prod-down99.6%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{-1}} \cdot \sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}}} \]
    9. cbrt-unprod99.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(\sqrt[3]{e^{-1} \cdot e^{-1}}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    10. prod-exp99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{\color{blue}{e^{-1 + -1}}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    11. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\color{blue}{-2}}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  5. Applied egg-rr99.7%

    \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{-2}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}}} \]
  6. Step-by-step derivation
    1. pow1/399.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left({\left(e^{-2}\right)}^{0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    2. pow-exp99.7%

      \[\leadsto \frac{1}{1 + {\color{blue}{\left(e^{-2 \cdot 0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    3. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + {\left(e^{\color{blue}{-0.6666666666666666}}\right)}^{\left(\frac{x}{s}\right)} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    4. exp-prod99.8%

      \[\leadsto \frac{1}{1 + \color{blue}{e^{-0.6666666666666666 \cdot \frac{x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
    5. associate-*r/99.8%

      \[\leadsto \frac{1}{1 + e^{\color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  7. Applied egg-rr99.8%

    \[\leadsto \frac{1}{1 + \color{blue}{e^{\frac{-0.6666666666666666 \cdot x}{s}}} \cdot {\left(\sqrt[3]{e^{-1}}\right)}^{\left(\frac{x}{s}\right)}} \]
  8. Step-by-step derivation
    1. pow1/399.8%

      \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot {\color{blue}{\left({\left(e^{-1}\right)}^{0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)}} \]
    2. pow-exp99.7%

      \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot {\color{blue}{\left(e^{-1 \cdot 0.3333333333333333}\right)}}^{\left(\frac{x}{s}\right)}} \]
    3. metadata-eval99.7%

      \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot {\left(e^{\color{blue}{-0.3333333333333333}}\right)}^{\left(\frac{x}{s}\right)}} \]
    4. exp-prod99.8%

      \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot \color{blue}{e^{-0.3333333333333333 \cdot \frac{x}{s}}}} \]
    5. *-commutative99.8%

      \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot e^{\color{blue}{\frac{x}{s} \cdot -0.3333333333333333}}} \]
  9. Applied egg-rr99.8%

    \[\leadsto \frac{1}{1 + e^{\frac{-0.6666666666666666 \cdot x}{s}} \cdot \color{blue}{e^{\frac{x}{s} \cdot -0.3333333333333333}}} \]
  10. Final simplification99.8%

    \[\leadsto \frac{1}{1 + e^{\frac{x \cdot -0.6666666666666666}{s}} \cdot e^{\frac{x}{s} \cdot -0.3333333333333333}} \]

Alternative 3: 99.8% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \frac{1}{1 + e^{\frac{-x}{s}}} \end{array} \]
(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}
Derivation
  1. Initial program 99.8%

    \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
  2. Final simplification99.8%

    \[\leadsto \frac{1}{1 + e^{\frac{-x}{s}}} \]

Alternative 4: 88.0% accurate, 2.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{s}{x \cdot -0.3333333333333333}\\ t_1 := \frac{-x}{s}\\ \mathbf{if}\;t_1 \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;t_1 \leq 200000000753664:\\ \;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\ \mathbf{elif}\;t_1 \leq 9.999999616903162 \cdot 10^{+35}:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + \frac{s + \left(x \cdot -0.6666666666666666\right) \cdot t_0}{s \cdot t_0}\right)}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ s (* x -0.3333333333333333))) (t_1 (/ (- x) s)))
   (if (<= t_1 0.20000000298023224)
     (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
     (if (<= t_1 200000000753664.0)
       (/
        1.0
        (+
         1.0
         (-
          1.0
          (*
           x
           (/
            (- (* s -0.3333333333333333) (* s 0.6666666666666666))
            (* s (- s)))))))
       (if (<= t_1 9.999999616903162e+35)
         (/ 1.0 (/ (- 4.0 (* (/ x s) (/ x s))) (+ (/ x s) 2.0)))
         (/
          1.0
          (+
           1.0
           (+ 1.0 (/ (+ s (* (* x -0.6666666666666666) t_0)) (* s t_0))))))))))
float code(float x, float s) {
	float t_0 = s / (x * -0.3333333333333333f);
	float t_1 = -x / s;
	float tmp;
	if (t_1 <= 0.20000000298023224f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else if (t_1 <= 200000000753664.0f) {
		tmp = 1.0f / (1.0f + (1.0f - (x * (((s * -0.3333333333333333f) - (s * 0.6666666666666666f)) / (s * -s)))));
	} else if (t_1 <= 9.999999616903162e+35f) {
		tmp = 1.0f / ((4.0f - ((x / s) * (x / s))) / ((x / s) + 2.0f));
	} else {
		tmp = 1.0f / (1.0f + (1.0f + ((s + ((x * -0.6666666666666666f) * t_0)) / (s * t_0))));
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: t_0
    real(4) :: t_1
    real(4) :: tmp
    t_0 = s / (x * (-0.3333333333333333e0))
    t_1 = -x / s
    if (t_1 <= 0.20000000298023224e0) then
        tmp = 1.0e0 / (1.0e0 + (1.0e0 / (1.0e0 + (x / s))))
    else if (t_1 <= 200000000753664.0e0) then
        tmp = 1.0e0 / (1.0e0 + (1.0e0 - (x * (((s * (-0.3333333333333333e0)) - (s * 0.6666666666666666e0)) / (s * -s)))))
    else if (t_1 <= 9.999999616903162e+35) then
        tmp = 1.0e0 / ((4.0e0 - ((x / s) * (x / s))) / ((x / s) + 2.0e0))
    else
        tmp = 1.0e0 / (1.0e0 + (1.0e0 + ((s + ((x * (-0.6666666666666666e0)) * t_0)) / (s * t_0))))
    end if
    code = tmp
end function
function code(x, s)
	t_0 = Float32(s / Float32(x * Float32(-0.3333333333333333)))
	t_1 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_1 <= Float32(0.20000000298023224))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	elseif (t_1 <= Float32(200000000753664.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) - Float32(x * Float32(Float32(Float32(s * Float32(-0.3333333333333333)) - Float32(s * Float32(0.6666666666666666))) / Float32(s * Float32(-s)))))));
	elseif (t_1 <= Float32(9.999999616903162e+35))
		tmp = Float32(Float32(1.0) / Float32(Float32(Float32(4.0) - Float32(Float32(x / s) * Float32(x / s))) / Float32(Float32(x / s) + Float32(2.0))));
	else
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) + Float32(Float32(s + Float32(Float32(x * Float32(-0.6666666666666666)) * t_0)) / Float32(s * t_0)))));
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = s / (x * single(-0.3333333333333333));
	t_1 = -x / s;
	tmp = single(0.0);
	if (t_1 <= single(0.20000000298023224))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	elseif (t_1 <= single(200000000753664.0))
		tmp = single(1.0) / (single(1.0) + (single(1.0) - (x * (((s * single(-0.3333333333333333)) - (s * single(0.6666666666666666))) / (s * -s)))));
	elseif (t_1 <= single(9.999999616903162e+35))
		tmp = single(1.0) / ((single(4.0) - ((x / s) * (x / s))) / ((x / s) + single(2.0)));
	else
		tmp = single(1.0) / (single(1.0) + (single(1.0) + ((s + ((x * single(-0.6666666666666666)) * t_0)) / (s * t_0))));
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{s}{x \cdot -0.3333333333333333}\\
t_1 := \frac{-x}{s}\\
\mathbf{if}\;t_1 \leq 0.20000000298023224:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{elif}\;t_1 \leq 200000000753664:\\
\;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\

\mathbf{elif}\;t_1 \leq 9.999999616903162 \cdot 10^{+35}:\\
\;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{1 + \left(1 + \frac{s + \left(x \cdot -0.6666666666666666\right) \cdot t_0}{s \cdot t_0}\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 4 regimes
  2. if (/.f32 (neg.f32 x) s) < 0.200000003

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.9%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr99.9%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.2%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if 0.200000003 < (/.f32 (neg.f32 x) s) < 2.00000001e14

    1. Initial program 98.7%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg98.7%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg98.7%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt-0.0%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow37.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip7.2%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod-0.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt98.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval98.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr98.8%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 8.3%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr8.3%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified8.3%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
    8. Step-by-step derivation
      1. frac-2neg8.3%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \left(\color{blue}{\frac{--0.6666666666666666}{-s}} + \frac{-0.3333333333333333}{s}\right)\right)} \]
      2. frac-add42.2%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{\left(--0.6666666666666666\right) \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}}\right)} \]
      3. metadata-eval42.2%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{\color{blue}{0.6666666666666666} \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}\right)} \]
    9. Applied egg-rr42.2%

      \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{0.6666666666666666 \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}}\right)} \]

    if 2.00000001e14 < (/.f32 (neg.f32 x) s) < 9.99999962e35

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 12.5%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg12.5%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg12.5%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified12.5%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Step-by-step derivation
      1. sub-neg12.5%

        \[\leadsto \frac{1}{\color{blue}{2 + \left(-\frac{x}{s}\right)}} \]
      2. flip-+88.0%

        \[\leadsto \frac{1}{\color{blue}{\frac{2 \cdot 2 - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}}} \]
      3. metadata-eval88.0%

        \[\leadsto \frac{1}{\frac{\color{blue}{4} - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      4. distribute-neg-frac88.0%

        \[\leadsto \frac{1}{\frac{4 - \color{blue}{\frac{-x}{s}} \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      5. distribute-neg-frac88.0%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \color{blue}{\frac{-x}{s}}}{2 - \left(-\frac{x}{s}\right)}} \]
      6. distribute-neg-frac88.0%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \color{blue}{\frac{-x}{s}}}} \]
    6. Applied egg-rr88.0%

      \[\leadsto \frac{1}{\color{blue}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \frac{-x}{s}}}} \]

    if 9.99999962e35 < (/.f32 (neg.f32 x) s)

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt-0.0%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod6.3%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg6.3%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod6.3%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt6.3%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt6.3%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow36.3%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip6.3%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt6.3%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod6.3%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg6.3%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod-0.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt100.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval100.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 92.7%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. associate-*r/92.7%

        \[\leadsto \frac{1}{1 + \left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + \color{blue}{\frac{-0.3333333333333333 \cdot x}{s}}\right)\right)} \]
      2. clear-num92.7%

        \[\leadsto \frac{1}{1 + \left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + \color{blue}{\frac{1}{\frac{s}{-0.3333333333333333 \cdot x}}}\right)\right)} \]
    6. Applied egg-rr92.7%

      \[\leadsto \frac{1}{1 + \left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + \color{blue}{\frac{1}{\frac{s}{-0.3333333333333333 \cdot x}}}\right)\right)} \]
    7. Step-by-step derivation
      1. associate-/r*92.7%

        \[\leadsto \frac{1}{1 + \left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + \frac{1}{\color{blue}{\frac{\frac{s}{-0.3333333333333333}}{x}}}\right)\right)} \]
    8. Simplified92.7%

      \[\leadsto \frac{1}{1 + \left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + \color{blue}{\frac{1}{\frac{\frac{s}{-0.3333333333333333}}{x}}}\right)\right)} \]
    9. Step-by-step derivation
      1. +-commutative92.7%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(\frac{1}{\frac{\frac{s}{-0.3333333333333333}}{x}} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. associate-*r/92.7%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\frac{1}{\frac{\frac{s}{-0.3333333333333333}}{x}} + \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
      3. frac-add100.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\frac{1 \cdot s + \frac{\frac{s}{-0.3333333333333333}}{x} \cdot \left(-0.6666666666666666 \cdot x\right)}{\frac{\frac{s}{-0.3333333333333333}}{x} \cdot s}}\right)} \]
      4. *-un-lft-identity100.0%

        \[\leadsto \frac{1}{1 + \left(1 + \frac{\color{blue}{s} + \frac{\frac{s}{-0.3333333333333333}}{x} \cdot \left(-0.6666666666666666 \cdot x\right)}{\frac{\frac{s}{-0.3333333333333333}}{x} \cdot s}\right)} \]
      5. associate-/l/100.0%

        \[\leadsto \frac{1}{1 + \left(1 + \frac{s + \color{blue}{\frac{s}{x \cdot -0.3333333333333333}} \cdot \left(-0.6666666666666666 \cdot x\right)}{\frac{\frac{s}{-0.3333333333333333}}{x} \cdot s}\right)} \]
      6. associate-/l/100.0%

        \[\leadsto \frac{1}{1 + \left(1 + \frac{s + \frac{s}{x \cdot -0.3333333333333333} \cdot \left(-0.6666666666666666 \cdot x\right)}{\color{blue}{\frac{s}{x \cdot -0.3333333333333333}} \cdot s}\right)} \]
    10. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\frac{s + \frac{s}{x \cdot -0.3333333333333333} \cdot \left(-0.6666666666666666 \cdot x\right)}{\frac{s}{x \cdot -0.3333333333333333} \cdot s}}\right)} \]
  3. Recombined 4 regimes into one program.
  4. Final simplification86.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;\frac{-x}{s} \leq 200000000753664:\\ \;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\ \mathbf{elif}\;\frac{-x}{s} \leq 9.999999616903162 \cdot 10^{+35}:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + \frac{s + \left(x \cdot -0.6666666666666666\right) \cdot \frac{s}{x \cdot -0.3333333333333333}}{s \cdot \frac{s}{x \cdot -0.3333333333333333}}\right)}\\ \end{array} \]

Alternative 5: 76.5% accurate, 3.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;t_0 \leq 499999992153374700:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{s + -0.6666666666666666 \cdot \left(s \cdot -3\right)}{s \cdot \left(s \cdot -3\right)}\right)}\\ \mathbf{elif}\;t_0 \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 0.20000000298023224)
     (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
     (if (<= t_0 499999992153374700.0)
       (/
        1.0
        (+
         1.0
         (+
          1.0
          (*
           x
           (/ (+ s (* -0.6666666666666666 (* s -3.0))) (* s (* s -3.0)))))))
       (if (<= t_0 INFINITY)
         (/ 1.0 (/ (- 4.0 (* (/ x s) (/ x s))) (+ (/ x s) 2.0)))
         (/ 1.0 t_0))))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= 0.20000000298023224f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else if (t_0 <= 499999992153374700.0f) {
		tmp = 1.0f / (1.0f + (1.0f + (x * ((s + (-0.6666666666666666f * (s * -3.0f))) / (s * (s * -3.0f))))));
	} else if (t_0 <= ((float) INFINITY)) {
		tmp = 1.0f / ((4.0f - ((x / s) * (x / s))) / ((x / s) + 2.0f));
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(0.20000000298023224))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	elseif (t_0 <= Float32(499999992153374700.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) + Float32(x * Float32(Float32(s + Float32(Float32(-0.6666666666666666) * Float32(s * Float32(-3.0)))) / Float32(s * Float32(s * Float32(-3.0))))))));
	elseif (t_0 <= Float32(Inf))
		tmp = Float32(Float32(1.0) / Float32(Float32(Float32(4.0) - Float32(Float32(x / s) * Float32(x / s))) / Float32(Float32(x / s) + Float32(2.0))));
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(0.20000000298023224))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	elseif (t_0 <= single(499999992153374700.0))
		tmp = single(1.0) / (single(1.0) + (single(1.0) + (x * ((s + (single(-0.6666666666666666) * (s * single(-3.0)))) / (s * (s * single(-3.0)))))));
	elseif (t_0 <= single(Inf))
		tmp = single(1.0) / ((single(4.0) - ((x / s) * (x / s))) / ((x / s) + single(2.0)));
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq 0.20000000298023224:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{elif}\;t_0 \leq 499999992153374700:\\
\;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{s + -0.6666666666666666 \cdot \left(s \cdot -3\right)}{s \cdot \left(s \cdot -3\right)}\right)}\\

\mathbf{elif}\;t_0 \leq \infty:\\
\;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 4 regimes
  2. if (/.f32 (neg.f32 x) s) < 0.200000003

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.9%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr99.9%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.2%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if 0.200000003 < (/.f32 (neg.f32 x) s) < 4.99999992e17

    1. Initial program 98.8%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg98.8%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg98.8%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt-0.0%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod7.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg7.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod7.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt7.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt7.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow37.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip7.1%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt7.1%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod7.1%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg7.1%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod-0.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt98.9%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval98.9%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr98.9%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 8.4%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative8.4%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative8.4%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def8.4%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/8.4%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr8.4%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified8.4%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
    8. Step-by-step derivation
      1. +-commutative8.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\left(\frac{-0.3333333333333333}{s} + \frac{-0.6666666666666666}{s}\right)}\right)} \]
      2. clear-num8.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \left(\color{blue}{\frac{1}{\frac{s}{-0.3333333333333333}}} + \frac{-0.6666666666666666}{s}\right)\right)} \]
      3. frac-add39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{1 \cdot s + \frac{s}{-0.3333333333333333} \cdot -0.6666666666666666}{\frac{s}{-0.3333333333333333} \cdot s}}\right)} \]
      4. *-un-lft-identity39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{\color{blue}{s} + \frac{s}{-0.3333333333333333} \cdot -0.6666666666666666}{\frac{s}{-0.3333333333333333} \cdot s}\right)} \]
      5. div-inv39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{s + \color{blue}{\left(s \cdot \frac{1}{-0.3333333333333333}\right)} \cdot -0.6666666666666666}{\frac{s}{-0.3333333333333333} \cdot s}\right)} \]
      6. metadata-eval39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{s + \left(s \cdot \color{blue}{-3}\right) \cdot -0.6666666666666666}{\frac{s}{-0.3333333333333333} \cdot s}\right)} \]
      7. div-inv39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{s + \left(s \cdot -3\right) \cdot -0.6666666666666666}{\color{blue}{\left(s \cdot \frac{1}{-0.3333333333333333}\right)} \cdot s}\right)} \]
      8. metadata-eval39.4%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{s + \left(s \cdot -3\right) \cdot -0.6666666666666666}{\left(s \cdot \color{blue}{-3}\right) \cdot s}\right)} \]
    9. Applied egg-rr39.4%

      \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{s + \left(s \cdot -3\right) \cdot -0.6666666666666666}{\left(s \cdot -3\right) \cdot s}}\right)} \]

    if 4.99999992e17 < (/.f32 (neg.f32 x) s) < +inf.0

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 55.1%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg55.1%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg55.1%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified55.1%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Step-by-step derivation
      1. sub-neg55.1%

        \[\leadsto \frac{1}{\color{blue}{2 + \left(-\frac{x}{s}\right)}} \]
      2. flip-+51.5%

        \[\leadsto \frac{1}{\color{blue}{\frac{2 \cdot 2 - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}}} \]
      3. metadata-eval51.5%

        \[\leadsto \frac{1}{\frac{\color{blue}{4} - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      4. distribute-neg-frac51.5%

        \[\leadsto \frac{1}{\frac{4 - \color{blue}{\frac{-x}{s}} \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      5. distribute-neg-frac51.5%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \color{blue}{\frac{-x}{s}}}{2 - \left(-\frac{x}{s}\right)}} \]
      6. distribute-neg-frac51.5%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \color{blue}{\frac{-x}{s}}}} \]
    6. Applied egg-rr51.5%

      \[\leadsto \frac{1}{\color{blue}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \frac{-x}{s}}}} \]

    if +inf.0 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.8%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 37.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg37.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg37.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified37.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 19.8%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified19.8%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 4 regimes into one program.
  4. Final simplification73.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;\frac{-x}{s} \leq 499999992153374700:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{s + -0.6666666666666666 \cdot \left(s \cdot -3\right)}{s \cdot \left(s \cdot -3\right)}\right)}\\ \mathbf{elif}\;\frac{-x}{s} \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 6: 75.7% accurate, 3.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;t_0 \leq 200000000753664:\\ \;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\ \mathbf{elif}\;t_0 \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 0.20000000298023224)
     (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
     (if (<= t_0 200000000753664.0)
       (/
        1.0
        (+
         1.0
         (-
          1.0
          (*
           x
           (/
            (- (* s -0.3333333333333333) (* s 0.6666666666666666))
            (* s (- s)))))))
       (if (<= t_0 INFINITY)
         (/ 1.0 (/ (- 4.0 (* (/ x s) (/ x s))) (+ (/ x s) 2.0)))
         (/ 1.0 t_0))))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= 0.20000000298023224f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else if (t_0 <= 200000000753664.0f) {
		tmp = 1.0f / (1.0f + (1.0f - (x * (((s * -0.3333333333333333f) - (s * 0.6666666666666666f)) / (s * -s)))));
	} else if (t_0 <= ((float) INFINITY)) {
		tmp = 1.0f / ((4.0f - ((x / s) * (x / s))) / ((x / s) + 2.0f));
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(0.20000000298023224))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	elseif (t_0 <= Float32(200000000753664.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) - Float32(x * Float32(Float32(Float32(s * Float32(-0.3333333333333333)) - Float32(s * Float32(0.6666666666666666))) / Float32(s * Float32(-s)))))));
	elseif (t_0 <= Float32(Inf))
		tmp = Float32(Float32(1.0) / Float32(Float32(Float32(4.0) - Float32(Float32(x / s) * Float32(x / s))) / Float32(Float32(x / s) + Float32(2.0))));
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(0.20000000298023224))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	elseif (t_0 <= single(200000000753664.0))
		tmp = single(1.0) / (single(1.0) + (single(1.0) - (x * (((s * single(-0.3333333333333333)) - (s * single(0.6666666666666666))) / (s * -s)))));
	elseif (t_0 <= single(Inf))
		tmp = single(1.0) / ((single(4.0) - ((x / s) * (x / s))) / ((x / s) + single(2.0)));
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq 0.20000000298023224:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{elif}\;t_0 \leq 200000000753664:\\
\;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\

\mathbf{elif}\;t_0 \leq \infty:\\
\;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 4 regimes
  2. if (/.f32 (neg.f32 x) s) < 0.200000003

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.9%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr99.9%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.2%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if 0.200000003 < (/.f32 (neg.f32 x) s) < 2.00000001e14

    1. Initial program 98.7%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg98.7%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg98.7%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt-0.0%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt7.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow37.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip7.2%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg7.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod-0.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt98.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval98.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr98.8%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 8.3%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/8.3%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr8.3%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified8.3%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
    8. Step-by-step derivation
      1. frac-2neg8.3%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \left(\color{blue}{\frac{--0.6666666666666666}{-s}} + \frac{-0.3333333333333333}{s}\right)\right)} \]
      2. frac-add42.2%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{\left(--0.6666666666666666\right) \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}}\right)} \]
      3. metadata-eval42.2%

        \[\leadsto \frac{1}{1 + \left(1 + x \cdot \frac{\color{blue}{0.6666666666666666} \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}\right)} \]
    9. Applied egg-rr42.2%

      \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{0.6666666666666666 \cdot s + \left(-s\right) \cdot -0.3333333333333333}{\left(-s\right) \cdot s}}\right)} \]

    if 2.00000001e14 < (/.f32 (neg.f32 x) s) < +inf.0

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 52.6%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg52.6%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg52.6%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified52.6%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Step-by-step derivation
      1. sub-neg52.6%

        \[\leadsto \frac{1}{\color{blue}{2 + \left(-\frac{x}{s}\right)}} \]
      2. flip-+49.3%

        \[\leadsto \frac{1}{\color{blue}{\frac{2 \cdot 2 - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}}} \]
      3. metadata-eval49.3%

        \[\leadsto \frac{1}{\frac{\color{blue}{4} - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      4. distribute-neg-frac49.3%

        \[\leadsto \frac{1}{\frac{4 - \color{blue}{\frac{-x}{s}} \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      5. distribute-neg-frac49.3%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \color{blue}{\frac{-x}{s}}}{2 - \left(-\frac{x}{s}\right)}} \]
      6. distribute-neg-frac49.3%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \color{blue}{\frac{-x}{s}}}} \]
    6. Applied egg-rr49.3%

      \[\leadsto \frac{1}{\color{blue}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \frac{-x}{s}}}} \]

    if +inf.0 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.8%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 37.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg37.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg37.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified37.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 19.8%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified19.8%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 4 regimes into one program.
  4. Final simplification73.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq 0.20000000298023224:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;\frac{-x}{s} \leq 200000000753664:\\ \;\;\;\;\frac{1}{1 + \left(1 - x \cdot \frac{s \cdot -0.3333333333333333 - s \cdot 0.6666666666666666}{s \cdot \left(-s\right)}\right)}\\ \mathbf{elif}\;\frac{-x}{s} \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 7: 73.1% accurate, 4.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;t_0 \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 -0.019999999552965164)
     (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
     (if (<= t_0 INFINITY)
       (/ 1.0 (/ (- 4.0 (* (/ x s) (/ x s))) (+ (/ x s) 2.0)))
       (/ 1.0 t_0)))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= -0.019999999552965164f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else if (t_0 <= ((float) INFINITY)) {
		tmp = 1.0f / ((4.0f - ((x / s) * (x / s))) / ((x / s) + 2.0f));
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(-0.019999999552965164))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	elseif (t_0 <= Float32(Inf))
		tmp = Float32(Float32(1.0) / Float32(Float32(Float32(4.0) - Float32(Float32(x / s) * Float32(x / s))) / Float32(Float32(x / s) + Float32(2.0))));
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(-0.019999999552965164))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	elseif (t_0 <= single(Inf))
		tmp = single(1.0) / ((single(4.0) - ((x / s) * (x / s))) / ((x / s) + single(2.0)));
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq -0.019999999552965164:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{elif}\;t_0 \leq \infty:\\
\;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (/.f32 (neg.f32 x) s) < -0.0199999996

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.0%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if -0.0199999996 < (/.f32 (neg.f32 x) s) < +inf.0

    1. Initial program 99.6%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 53.9%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg53.9%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg53.9%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified53.9%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Step-by-step derivation
      1. sub-neg53.9%

        \[\leadsto \frac{1}{\color{blue}{2 + \left(-\frac{x}{s}\right)}} \]
      2. flip-+52.4%

        \[\leadsto \frac{1}{\color{blue}{\frac{2 \cdot 2 - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}}} \]
      3. metadata-eval52.4%

        \[\leadsto \frac{1}{\frac{\color{blue}{4} - \left(-\frac{x}{s}\right) \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      4. distribute-neg-frac52.4%

        \[\leadsto \frac{1}{\frac{4 - \color{blue}{\frac{-x}{s}} \cdot \left(-\frac{x}{s}\right)}{2 - \left(-\frac{x}{s}\right)}} \]
      5. distribute-neg-frac52.4%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \color{blue}{\frac{-x}{s}}}{2 - \left(-\frac{x}{s}\right)}} \]
      6. distribute-neg-frac52.4%

        \[\leadsto \frac{1}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \color{blue}{\frac{-x}{s}}}} \]
    6. Applied egg-rr52.4%

      \[\leadsto \frac{1}{\color{blue}{\frac{4 - \frac{-x}{s} \cdot \frac{-x}{s}}{2 - \frac{-x}{s}}}} \]

    if +inf.0 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.8%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 37.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg37.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg37.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified37.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 19.8%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg19.8%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified19.8%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification67.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{elif}\;\frac{-x}{s} \leq \infty:\\ \;\;\;\;\frac{1}{\frac{4 - \frac{x}{s} \cdot \frac{x}{s}}{\frac{x}{s} + 2}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 8: 75.0% accurate, 5.4× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)\right)}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= (/ (- x) s) -0.019999999552965164)
   (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
   (/
    1.0
    (+
     1.0
     (+ 1.0 (* x (+ (/ -0.6666666666666666 s) (/ -0.3333333333333333 s))))))))
float code(float x, float s) {
	float tmp;
	if ((-x / s) <= -0.019999999552965164f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else {
		tmp = 1.0f / (1.0f + (1.0f + (x * ((-0.6666666666666666f / s) + (-0.3333333333333333f / s)))));
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: tmp
    if ((-x / s) <= (-0.019999999552965164e0)) then
        tmp = 1.0e0 / (1.0e0 + (1.0e0 / (1.0e0 + (x / s))))
    else
        tmp = 1.0e0 / (1.0e0 + (1.0e0 + (x * (((-0.6666666666666666e0) / s) + ((-0.3333333333333333e0) / s)))))
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (Float32(Float32(-x) / s) <= Float32(-0.019999999552965164))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	else
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) + Float32(x * Float32(Float32(Float32(-0.6666666666666666) / s) + Float32(Float32(-0.3333333333333333) / s))))));
	end
	return tmp
end
function tmp_2 = code(x, s)
	tmp = single(0.0);
	if ((-x / s) <= single(-0.019999999552965164))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	else
		tmp = single(1.0) / (single(1.0) + (single(1.0) + (x * ((single(-0.6666666666666666) / s) + (single(-0.3333333333333333) / s)))));
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{1 + \left(1 + x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f32 (neg.f32 x) s) < -0.0199999996

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.0%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if -0.0199999996 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.6%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg99.6%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.6%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt17.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod31.6%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg31.6%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod15.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt31.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt31.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow331.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip31.1%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt15.1%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod31.7%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg31.7%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod17.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr99.6%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 54.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification68.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)\right)}\\ \end{array} \]

Alternative 9: 75.4% accurate, 6.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq -200:\\ \;\;\;\;1 - \frac{s}{x}\\ \mathbf{elif}\;t_0 \leq 1:\\ \;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 -200.0)
     (- 1.0 (/ s x))
     (if (<= t_0 1.0) (+ 0.5 (/ (* x 0.25) s)) (/ 1.0 t_0)))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= -200.0f) {
		tmp = 1.0f - (s / x);
	} else if (t_0 <= 1.0f) {
		tmp = 0.5f + ((x * 0.25f) / s);
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: t_0
    real(4) :: tmp
    t_0 = -x / s
    if (t_0 <= (-200.0e0)) then
        tmp = 1.0e0 - (s / x)
    else if (t_0 <= 1.0e0) then
        tmp = 0.5e0 + ((x * 0.25e0) / s)
    else
        tmp = 1.0e0 / t_0
    end if
    code = tmp
end function
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(-200.0))
		tmp = Float32(Float32(1.0) - Float32(s / x));
	elseif (t_0 <= Float32(1.0))
		tmp = Float32(Float32(0.5) + Float32(Float32(x * Float32(0.25)) / s));
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(-200.0))
		tmp = single(1.0) - (s / x);
	elseif (t_0 <= single(1.0))
		tmp = single(0.5) + ((x * single(0.25)) / s);
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq -200:\\
\;\;\;\;1 - \frac{s}{x}\\

\mathbf{elif}\;t_0 \leq 1:\\
\;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (/.f32 (neg.f32 x) s) < -200

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.3%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 97.2%

      \[\leadsto \color{blue}{1 + -1 \cdot \frac{s}{x}} \]
    6. Step-by-step derivation
      1. mul-1-neg97.2%

        \[\leadsto 1 + \color{blue}{\left(-\frac{s}{x}\right)} \]
      2. unsub-neg97.2%

        \[\leadsto \color{blue}{1 - \frac{s}{x}} \]
    7. Simplified97.2%

      \[\leadsto \color{blue}{1 - \frac{s}{x}} \]

    if -200 < (/.f32 (neg.f32 x) s) < 1

    1. Initial program 99.9%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 98.0%

      \[\leadsto \color{blue}{0.5 + 0.25 \cdot \frac{x}{s}} \]
    3. Step-by-step derivation
      1. associate-*r/98.0%

        \[\leadsto 0.5 + \color{blue}{\frac{0.25 \cdot x}{s}} \]
    4. Simplified98.0%

      \[\leadsto \color{blue}{0.5 + \frac{0.25 \cdot x}{s}} \]

    if 1 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.5%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 36.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 36.4%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification69.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;1 - \frac{s}{x}\\ \mathbf{elif}\;\frac{-x}{s} \leq 1:\\ \;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 10: 75.4% accurate, 6.3× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{elif}\;t_0 \leq 1:\\ \;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 -200.0)
     (/ 1.0 (+ 1.0 (/ s x)))
     (if (<= t_0 1.0) (+ 0.5 (/ (* x 0.25) s)) (/ 1.0 t_0)))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= -200.0f) {
		tmp = 1.0f / (1.0f + (s / x));
	} else if (t_0 <= 1.0f) {
		tmp = 0.5f + ((x * 0.25f) / s);
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: t_0
    real(4) :: tmp
    t_0 = -x / s
    if (t_0 <= (-200.0e0)) then
        tmp = 1.0e0 / (1.0e0 + (s / x))
    else if (t_0 <= 1.0e0) then
        tmp = 0.5e0 + ((x * 0.25e0) / s)
    else
        tmp = 1.0e0 / t_0
    end if
    code = tmp
end function
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(-200.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(s / x)));
	elseif (t_0 <= Float32(1.0))
		tmp = Float32(Float32(0.5) + Float32(Float32(x * Float32(0.25)) / s));
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(-200.0))
		tmp = single(1.0) / (single(1.0) + (s / x));
	elseif (t_0 <= single(1.0))
		tmp = single(0.5) + ((x * single(0.25)) / s);
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq -200:\\
\;\;\;\;\frac{1}{1 + \frac{s}{x}}\\

\mathbf{elif}\;t_0 \leq 1:\\
\;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (/.f32 (neg.f32 x) s) < -200

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.3%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 97.3%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{s}{x}}} \]

    if -200 < (/.f32 (neg.f32 x) s) < 1

    1. Initial program 99.9%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 98.0%

      \[\leadsto \color{blue}{0.5 + 0.25 \cdot \frac{x}{s}} \]
    3. Step-by-step derivation
      1. associate-*r/98.0%

        \[\leadsto 0.5 + \color{blue}{\frac{0.25 \cdot x}{s}} \]
    4. Simplified98.0%

      \[\leadsto \color{blue}{0.5 + \frac{0.25 \cdot x}{s}} \]

    if 1 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.5%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 36.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 36.4%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification69.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{elif}\;\frac{-x}{s} \leq 1:\\ \;\;\;\;0.5 + \frac{x \cdot 0.25}{s}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 11: 73.3% accurate, 6.6× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{-x}{s}\\ \mathbf{if}\;t_0 \leq -200:\\ \;\;\;\;1 - \frac{s}{x}\\ \mathbf{elif}\;t_0 \leq 1:\\ \;\;\;\;0.5\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{t_0}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (let* ((t_0 (/ (- x) s)))
   (if (<= t_0 -200.0) (- 1.0 (/ s x)) (if (<= t_0 1.0) 0.5 (/ 1.0 t_0)))))
float code(float x, float s) {
	float t_0 = -x / s;
	float tmp;
	if (t_0 <= -200.0f) {
		tmp = 1.0f - (s / x);
	} else if (t_0 <= 1.0f) {
		tmp = 0.5f;
	} else {
		tmp = 1.0f / t_0;
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: t_0
    real(4) :: tmp
    t_0 = -x / s
    if (t_0 <= (-200.0e0)) then
        tmp = 1.0e0 - (s / x)
    else if (t_0 <= 1.0e0) then
        tmp = 0.5e0
    else
        tmp = 1.0e0 / t_0
    end if
    code = tmp
end function
function code(x, s)
	t_0 = Float32(Float32(-x) / s)
	tmp = Float32(0.0)
	if (t_0 <= Float32(-200.0))
		tmp = Float32(Float32(1.0) - Float32(s / x));
	elseif (t_0 <= Float32(1.0))
		tmp = Float32(0.5);
	else
		tmp = Float32(Float32(1.0) / t_0);
	end
	return tmp
end
function tmp_2 = code(x, s)
	t_0 = -x / s;
	tmp = single(0.0);
	if (t_0 <= single(-200.0))
		tmp = single(1.0) - (s / x);
	elseif (t_0 <= single(1.0))
		tmp = single(0.5);
	else
		tmp = single(1.0) / t_0;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{-x}{s}\\
\mathbf{if}\;t_0 \leq -200:\\
\;\;\;\;1 - \frac{s}{x}\\

\mathbf{elif}\;t_0 \leq 1:\\
\;\;\;\;0.5\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{t_0}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (/.f32 (neg.f32 x) s) < -200

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.3%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 97.2%

      \[\leadsto \color{blue}{1 + -1 \cdot \frac{s}{x}} \]
    6. Step-by-step derivation
      1. mul-1-neg97.2%

        \[\leadsto 1 + \color{blue}{\left(-\frac{s}{x}\right)} \]
      2. unsub-neg97.2%

        \[\leadsto \color{blue}{1 - \frac{s}{x}} \]
    7. Simplified97.2%

      \[\leadsto \color{blue}{1 - \frac{s}{x}} \]

    if -200 < (/.f32 (neg.f32 x) s) < 1

    1. Initial program 99.9%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 91.0%

      \[\leadsto \color{blue}{0.5} \]

    if 1 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.5%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 36.4%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 36.4%

      \[\leadsto \frac{1}{\color{blue}{-1 \cdot \frac{x}{s}}} \]
    6. Step-by-step derivation
      1. mul-1-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{-\frac{x}{s}}} \]
      2. distribute-frac-neg36.4%

        \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
    7. Simplified36.4%

      \[\leadsto \frac{1}{\color{blue}{\frac{-x}{s}}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification67.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;1 - \frac{s}{x}\\ \mathbf{elif}\;\frac{-x}{s} \leq 1:\\ \;\;\;\;0.5\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\frac{-x}{s}}\\ \end{array} \]

Alternative 12: 74.5% accurate, 6.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= (/ (- x) s) -200.0)
   (/ 1.0 (+ 1.0 (/ s x)))
   (/ 1.0 (+ 1.0 (+ 1.0 (* x (/ -1.0 s)))))))
float code(float x, float s) {
	float tmp;
	if ((-x / s) <= -200.0f) {
		tmp = 1.0f / (1.0f + (s / x));
	} else {
		tmp = 1.0f / (1.0f + (1.0f + (x * (-1.0f / s))));
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: tmp
    if ((-x / s) <= (-200.0e0)) then
        tmp = 1.0e0 / (1.0e0 + (s / x))
    else
        tmp = 1.0e0 / (1.0e0 + (1.0e0 + (x * ((-1.0e0) / s))))
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (Float32(Float32(-x) / s) <= Float32(-200.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(s / x)));
	else
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) + Float32(x * Float32(Float32(-1.0) / s)))));
	end
	return tmp
end
function tmp_2 = code(x, s)
	tmp = single(0.0);
	if ((-x / s) <= single(-200.0))
		tmp = single(1.0) / (single(1.0) + (s / x));
	else
		tmp = single(1.0) / (single(1.0) + (single(1.0) + (x * (single(-1.0) / s))));
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{-x}{s} \leq -200:\\
\;\;\;\;\frac{1}{1 + \frac{s}{x}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f32 (neg.f32 x) s) < -200

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.3%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 97.3%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{s}{x}}} \]

    if -200 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.6%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg99.6%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.6%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt17.7%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod31.7%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg31.7%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod15.0%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt31.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt31.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow331.2%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip31.2%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt15.0%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod31.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg31.8%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod17.7%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr99.6%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 54.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
    8. Taylor expanded in s around 0 54.0%

      \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{-1}{s}}\right)} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification68.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\ \end{array} \]

Alternative 13: 75.0% accurate, 6.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= (/ (- x) s) -0.019999999552965164)
   (/ 1.0 (+ 1.0 (/ 1.0 (+ 1.0 (/ x s)))))
   (/ 1.0 (+ 1.0 (+ 1.0 (* x (/ -1.0 s)))))))
float code(float x, float s) {
	float tmp;
	if ((-x / s) <= -0.019999999552965164f) {
		tmp = 1.0f / (1.0f + (1.0f / (1.0f + (x / s))));
	} else {
		tmp = 1.0f / (1.0f + (1.0f + (x * (-1.0f / s))));
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: tmp
    if ((-x / s) <= (-0.019999999552965164e0)) then
        tmp = 1.0e0 / (1.0e0 + (1.0e0 / (1.0e0 + (x / s))))
    else
        tmp = 1.0e0 / (1.0e0 + (1.0e0 + (x * ((-1.0e0) / s))))
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (Float32(Float32(-x) / s) <= Float32(-0.019999999552965164))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(x / s)))));
	else
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(Float32(1.0) + Float32(x * Float32(Float32(-1.0) / s)))));
	end
	return tmp
end
function tmp_2 = code(x, s)
	tmp = single(0.0);
	if ((-x / s) <= single(-0.019999999552965164))
		tmp = single(1.0) / (single(1.0) + (single(1.0) / (single(1.0) + (x / s))));
	else
		tmp = single(1.0) / (single(1.0) + (single(1.0) + (x * (single(-1.0) / s))));
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\
\;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f32 (neg.f32 x) s) < -0.0199999996

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.0%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]

    if -0.0199999996 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.6%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg99.6%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg99.6%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
      3. add-sqr-sqrt17.2%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}} \]
      4. sqrt-unprod31.6%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{x \cdot x}}}{s}}}} \]
      5. sqr-neg31.6%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\sqrt{\color{blue}{\left(-x\right) \cdot \left(-x\right)}}}{s}}}} \]
      6. sqrt-unprod15.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}} \]
      7. add-sqr-sqrt31.1%

        \[\leadsto \frac{1}{1 + \frac{1}{e^{\frac{\color{blue}{-x}}{s}}}} \]
      8. add-cube-cbrt31.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{\left(\sqrt[3]{e^{\frac{-x}{s}}} \cdot \sqrt[3]{e^{\frac{-x}{s}}}\right) \cdot \sqrt[3]{e^{\frac{-x}{s}}}}}} \]
      9. pow331.1%

        \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{3}}}} \]
      10. pow-flip31.1%

        \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{-x}{s}}}\right)}^{\left(-3\right)}}} \]
      11. add-sqr-sqrt15.1%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{-x} \cdot \sqrt{-x}}}{s}}}\right)}^{\left(-3\right)}} \]
      12. sqrt-unprod31.7%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{\left(-x\right) \cdot \left(-x\right)}}}{s}}}\right)}^{\left(-3\right)}} \]
      13. sqr-neg31.7%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\sqrt{\color{blue}{x \cdot x}}}{s}}}\right)}^{\left(-3\right)}} \]
      14. sqrt-unprod17.2%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{\sqrt{x} \cdot \sqrt{x}}}{s}}}\right)}^{\left(-3\right)}} \]
      15. add-sqr-sqrt99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{\color{blue}{x}}{s}}}\right)}^{\left(-3\right)}} \]
      16. metadata-eval99.6%

        \[\leadsto \frac{1}{1 + {\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{\color{blue}{-3}}} \]
    3. Applied egg-rr99.6%

      \[\leadsto \frac{1}{1 + \color{blue}{{\left(\sqrt[3]{e^{\frac{x}{s}}}\right)}^{-3}}} \]
    4. Taylor expanded in s around inf 54.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\left(1 + \left(-0.6666666666666666 \cdot \frac{x}{s} + -0.3333333333333333 \cdot \frac{x}{s}\right)\right)}} \]
    5. Step-by-step derivation
      1. +-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\left(-0.3333333333333333 \cdot \frac{x}{s} + -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      2. *-commutative54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \left(\color{blue}{\frac{x}{s} \cdot -0.3333333333333333} + -0.6666666666666666 \cdot \frac{x}{s}\right)\right)} \]
      3. fma-def54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, -0.6666666666666666 \cdot \frac{x}{s}\right)}\right)} \]
      4. associate-*r/54.0%

        \[\leadsto \frac{1}{1 + \left(1 + \mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \color{blue}{\frac{-0.6666666666666666 \cdot x}{s}}\right)\right)} \]
    6. Applied egg-rr54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{\mathsf{fma}\left(\frac{x}{s}, -0.3333333333333333, \frac{-0.6666666666666666 \cdot x}{s}\right)}\right)} \]
    7. Simplified54.0%

      \[\leadsto \frac{1}{1 + \left(1 + \color{blue}{x \cdot \left(\frac{-0.6666666666666666}{s} + \frac{-0.3333333333333333}{s}\right)}\right)} \]
    8. Taylor expanded in s around 0 54.0%

      \[\leadsto \frac{1}{1 + \left(1 + x \cdot \color{blue}{\frac{-1}{s}}\right)} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification68.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -0.019999999552965164:\\ \;\;\;\;\frac{1}{1 + \frac{1}{1 + \frac{x}{s}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{1 + \left(1 + x \cdot \frac{-1}{s}\right)}\\ \end{array} \]

Alternative 14: 74.4% accurate, 8.9× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{2 - \frac{x}{s}}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= (/ (- x) s) -200.0) (/ 1.0 (+ 1.0 (/ s x))) (/ 1.0 (- 2.0 (/ x s)))))
float code(float x, float s) {
	float tmp;
	if ((-x / s) <= -200.0f) {
		tmp = 1.0f / (1.0f + (s / x));
	} else {
		tmp = 1.0f / (2.0f - (x / s));
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: tmp
    if ((-x / s) <= (-200.0e0)) then
        tmp = 1.0e0 / (1.0e0 + (s / x))
    else
        tmp = 1.0e0 / (2.0e0 - (x / s))
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (Float32(Float32(-x) / s) <= Float32(-200.0))
		tmp = Float32(Float32(1.0) / Float32(Float32(1.0) + Float32(s / x)));
	else
		tmp = Float32(Float32(1.0) / Float32(Float32(2.0) - Float32(x / s)));
	end
	return tmp
end
function tmp_2 = code(x, s)
	tmp = single(0.0);
	if ((-x / s) <= single(-200.0))
		tmp = single(1.0) / (single(1.0) + (s / x));
	else
		tmp = single(1.0) / (single(2.0) - (x / s));
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;\frac{-x}{s} \leq -200:\\
\;\;\;\;\frac{1}{1 + \frac{s}{x}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{2 - \frac{x}{s}}\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (/.f32 (neg.f32 x) s) < -200

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 97.3%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 97.3%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{s}{x}}} \]

    if -200 < (/.f32 (neg.f32 x) s)

    1. Initial program 99.6%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 54.0%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg54.0%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg54.0%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified54.0%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification68.7%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\frac{-x}{s} \leq -200:\\ \;\;\;\;\frac{1}{1 + \frac{s}{x}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{2 - \frac{x}{s}}\\ \end{array} \]

Alternative 15: 68.1% accurate, 11.7× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -0.0015999999595806003:\\ \;\;\;\;\frac{-s}{x}\\ \mathbf{elif}\;x \leq 2.00000009162741 \cdot 10^{-18}:\\ \;\;\;\;0.5\\ \mathbf{else}:\\ \;\;\;\;1 - \frac{s}{x}\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= x -0.0015999999595806003)
   (/ (- s) x)
   (if (<= x 2.00000009162741e-18) 0.5 (- 1.0 (/ s x)))))
float code(float x, float s) {
	float tmp;
	if (x <= -0.0015999999595806003f) {
		tmp = -s / x;
	} else if (x <= 2.00000009162741e-18f) {
		tmp = 0.5f;
	} else {
		tmp = 1.0f - (s / x);
	}
	return tmp;
}
real(4) function code(x, s)
    real(4), intent (in) :: x
    real(4), intent (in) :: s
    real(4) :: tmp
    if (x <= (-0.0015999999595806003e0)) then
        tmp = -s / x
    else if (x <= 2.00000009162741e-18) then
        tmp = 0.5e0
    else
        tmp = 1.0e0 - (s / x)
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (x <= Float32(-0.0015999999595806003))
		tmp = Float32(Float32(-s) / x);
	elseif (x <= Float32(2.00000009162741e-18))
		tmp = Float32(0.5);
	else
		tmp = Float32(Float32(1.0) - Float32(s / x));
	end
	return tmp
end
function tmp_2 = code(x, s)
	tmp = single(0.0);
	if (x <= single(-0.0015999999595806003))
		tmp = -s / x;
	elseif (x <= single(2.00000009162741e-18))
		tmp = single(0.5);
	else
		tmp = single(1.0) - (s / x);
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;x \leq -0.0015999999595806003:\\
\;\;\;\;\frac{-s}{x}\\

\mathbf{elif}\;x \leq 2.00000009162741 \cdot 10^{-18}:\\
\;\;\;\;0.5\\

\mathbf{else}:\\
\;\;\;\;1 - \frac{s}{x}\\


\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if x < -0.00159999996

    1. Initial program 99.9%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 51.1%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg51.1%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg51.1%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified51.1%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 45.8%

      \[\leadsto \color{blue}{-1 \cdot \frac{s}{x}} \]
    6. Step-by-step derivation
      1. associate-*r/45.8%

        \[\leadsto \color{blue}{\frac{-1 \cdot s}{x}} \]
      2. neg-mul-145.8%

        \[\leadsto \frac{\color{blue}{-s}}{x} \]
    7. Simplified45.8%

      \[\leadsto \color{blue}{\frac{-s}{x}} \]

    if -0.00159999996 < x < 2.00000009e-18

    1. Initial program 99.4%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 49.7%

      \[\leadsto \color{blue}{0.5} \]

    if 2.00000009e-18 < x

    1. Initial program 100.0%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Step-by-step derivation
      1. distribute-frac-neg100.0%

        \[\leadsto \frac{1}{1 + e^{\color{blue}{-\frac{x}{s}}}} \]
      2. exp-neg100.0%

        \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    3. Applied egg-rr100.0%

      \[\leadsto \frac{1}{1 + \color{blue}{\frac{1}{e^{\frac{x}{s}}}}} \]
    4. Taylor expanded in x around 0 98.1%

      \[\leadsto \frac{1}{1 + \frac{1}{\color{blue}{1 + \frac{x}{s}}}} \]
    5. Taylor expanded in x around inf 92.7%

      \[\leadsto \color{blue}{1 + -1 \cdot \frac{s}{x}} \]
    6. Step-by-step derivation
      1. mul-1-neg92.7%

        \[\leadsto 1 + \color{blue}{\left(-\frac{s}{x}\right)} \]
      2. unsub-neg92.7%

        \[\leadsto \color{blue}{1 - \frac{s}{x}} \]
    7. Simplified92.7%

      \[\leadsto \color{blue}{1 - \frac{s}{x}} \]
  3. Recombined 3 regimes into one program.
  4. Final simplification63.1%

    \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -0.0015999999595806003:\\ \;\;\;\;\frac{-s}{x}\\ \mathbf{elif}\;x \leq 2.00000009162741 \cdot 10^{-18}:\\ \;\;\;\;0.5\\ \mathbf{else}:\\ \;\;\;\;1 - \frac{s}{x}\\ \end{array} \]

Alternative 16: 47.0% accurate, 17.6× speedup?

\[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;x \leq -0.0015999999595806003:\\ \;\;\;\;\frac{-s}{x}\\ \mathbf{else}:\\ \;\;\;\;0.5\\ \end{array} \end{array} \]
(FPCore (x s)
 :precision binary32
 (if (<= x -0.0015999999595806003) (/ (- s) x) 0.5))
float code(float x, float s) {
	float tmp;
	if (x <= -0.0015999999595806003f) {
		tmp = -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 <= (-0.0015999999595806003e0)) then
        tmp = -s / x
    else
        tmp = 0.5e0
    end if
    code = tmp
end function
function code(x, s)
	tmp = Float32(0.0)
	if (x <= Float32(-0.0015999999595806003))
		tmp = Float32(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(-0.0015999999595806003))
		tmp = -s / x;
	else
		tmp = single(0.5);
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
\mathbf{if}\;x \leq -0.0015999999595806003:\\
\;\;\;\;\frac{-s}{x}\\

\mathbf{else}:\\
\;\;\;\;0.5\\


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if x < -0.00159999996

    1. Initial program 99.9%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 51.1%

      \[\leadsto \frac{1}{\color{blue}{2 + -1 \cdot \frac{x}{s}}} \]
    3. Step-by-step derivation
      1. mul-1-neg51.1%

        \[\leadsto \frac{1}{2 + \color{blue}{\left(-\frac{x}{s}\right)}} \]
      2. unsub-neg51.1%

        \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    4. Simplified51.1%

      \[\leadsto \frac{1}{\color{blue}{2 - \frac{x}{s}}} \]
    5. Taylor expanded in x around inf 45.8%

      \[\leadsto \color{blue}{-1 \cdot \frac{s}{x}} \]
    6. Step-by-step derivation
      1. associate-*r/45.8%

        \[\leadsto \color{blue}{\frac{-1 \cdot s}{x}} \]
      2. neg-mul-145.8%

        \[\leadsto \frac{\color{blue}{-s}}{x} \]
    7. Simplified45.8%

      \[\leadsto \color{blue}{\frac{-s}{x}} \]

    if -0.00159999996 < x

    1. Initial program 99.7%

      \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
    2. Taylor expanded in x around 0 40.8%

      \[\leadsto \color{blue}{0.5} \]
  3. Recombined 2 regimes into one program.
  4. Final simplification42.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq -0.0015999999595806003:\\ \;\;\;\;\frac{-s}{x}\\ \mathbf{else}:\\ \;\;\;\;0.5\\ \end{array} \]

Alternative 17: 35.6% accurate, 108.0× speedup?

\[\begin{array}{l} \\ 0.5 \end{array} \]
(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}
Derivation
  1. Initial program 99.8%

    \[\frac{1}{1 + e^{\frac{-x}{s}}} \]
  2. Taylor expanded in x around 0 30.4%

    \[\leadsto \color{blue}{0.5} \]
  3. Final simplification30.4%

    \[\leadsto 0.5 \]

Reproduce

?
herbie shell --seed 2023318 
(FPCore (x s)
  :name "Logistic function"
  :precision binary32
  :pre (and (<= 0.0 s) (<= s 1.0651631))
  (/ 1.0 (+ 1.0 (exp (/ (- x) s)))))