Jmat.Real.erf

Percentage Accurate: 79.1% → 98.9%
Time: 14.7s
Alternatives: 5
Speedup: 142.3×

Specification

?
\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{1 + 0.3275911 \cdot \left|x\right|}\\ 1 - \left(t\_0 \cdot \left(0.254829592 + t\_0 \cdot \left(-0.284496736 + t\_0 \cdot \left(1.421413741 + t\_0 \cdot \left(-1.453152027 + t\_0 \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \end{array} \end{array} \]
(FPCore (x)
 :precision binary64
 (let* ((t_0 (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x))))))
   (-
    1.0
    (*
     (*
      t_0
      (+
       0.254829592
       (*
        t_0
        (+
         -0.284496736
         (*
          t_0
          (+ 1.421413741 (* t_0 (+ -1.453152027 (* t_0 1.061405429)))))))))
     (exp (- (* (fabs x) (fabs x))))))))
double code(double x) {
	double t_0 = 1.0 / (1.0 + (0.3275911 * fabs(x)));
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * exp(-(fabs(x) * fabs(x))));
}
real(8) function code(x)
    real(8), intent (in) :: x
    real(8) :: t_0
    t_0 = 1.0d0 / (1.0d0 + (0.3275911d0 * abs(x)))
    code = 1.0d0 - ((t_0 * (0.254829592d0 + (t_0 * ((-0.284496736d0) + (t_0 * (1.421413741d0 + (t_0 * ((-1.453152027d0) + (t_0 * 1.061405429d0))))))))) * exp(-(abs(x) * abs(x))))
end function
public static double code(double x) {
	double t_0 = 1.0 / (1.0 + (0.3275911 * Math.abs(x)));
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * Math.exp(-(Math.abs(x) * Math.abs(x))));
}
def code(x):
	t_0 = 1.0 / (1.0 + (0.3275911 * math.fabs(x)))
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * math.exp(-(math.fabs(x) * math.fabs(x))))
function code(x)
	t_0 = Float64(1.0 / Float64(1.0 + Float64(0.3275911 * abs(x))))
	return Float64(1.0 - Float64(Float64(t_0 * Float64(0.254829592 + Float64(t_0 * Float64(-0.284496736 + Float64(t_0 * Float64(1.421413741 + Float64(t_0 * Float64(-1.453152027 + Float64(t_0 * 1.061405429))))))))) * exp(Float64(-Float64(abs(x) * abs(x))))))
end
function tmp = code(x)
	t_0 = 1.0 / (1.0 + (0.3275911 * abs(x)));
	tmp = 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * exp(-(abs(x) * abs(x))));
end
code[x_] := Block[{t$95$0 = N[(1.0 / N[(1.0 + N[(0.3275911 * N[Abs[x], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(1.0 - N[(N[(t$95$0 * N[(0.254829592 + N[(t$95$0 * N[(-0.284496736 + N[(t$95$0 * N[(1.421413741 + N[(t$95$0 * N[(-1.453152027 + N[(t$95$0 * 1.061405429), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Exp[(-N[(N[Abs[x], $MachinePrecision] * N[Abs[x], $MachinePrecision]), $MachinePrecision])], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{1}{1 + 0.3275911 \cdot \left|x\right|}\\
1 - \left(t\_0 \cdot \left(0.254829592 + t\_0 \cdot \left(-0.284496736 + t\_0 \cdot \left(1.421413741 + t\_0 \cdot \left(-1.453152027 + t\_0 \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|}
\end{array}
\end{array}

Sampling outcomes in binary64 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 5 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: 79.1% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \frac{1}{1 + 0.3275911 \cdot \left|x\right|}\\ 1 - \left(t\_0 \cdot \left(0.254829592 + t\_0 \cdot \left(-0.284496736 + t\_0 \cdot \left(1.421413741 + t\_0 \cdot \left(-1.453152027 + t\_0 \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \end{array} \end{array} \]
(FPCore (x)
 :precision binary64
 (let* ((t_0 (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x))))))
   (-
    1.0
    (*
     (*
      t_0
      (+
       0.254829592
       (*
        t_0
        (+
         -0.284496736
         (*
          t_0
          (+ 1.421413741 (* t_0 (+ -1.453152027 (* t_0 1.061405429)))))))))
     (exp (- (* (fabs x) (fabs x))))))))
double code(double x) {
	double t_0 = 1.0 / (1.0 + (0.3275911 * fabs(x)));
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * exp(-(fabs(x) * fabs(x))));
}
real(8) function code(x)
    real(8), intent (in) :: x
    real(8) :: t_0
    t_0 = 1.0d0 / (1.0d0 + (0.3275911d0 * abs(x)))
    code = 1.0d0 - ((t_0 * (0.254829592d0 + (t_0 * ((-0.284496736d0) + (t_0 * (1.421413741d0 + (t_0 * ((-1.453152027d0) + (t_0 * 1.061405429d0))))))))) * exp(-(abs(x) * abs(x))))
end function
public static double code(double x) {
	double t_0 = 1.0 / (1.0 + (0.3275911 * Math.abs(x)));
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * Math.exp(-(Math.abs(x) * Math.abs(x))));
}
def code(x):
	t_0 = 1.0 / (1.0 + (0.3275911 * math.fabs(x)))
	return 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * math.exp(-(math.fabs(x) * math.fabs(x))))
function code(x)
	t_0 = Float64(1.0 / Float64(1.0 + Float64(0.3275911 * abs(x))))
	return Float64(1.0 - Float64(Float64(t_0 * Float64(0.254829592 + Float64(t_0 * Float64(-0.284496736 + Float64(t_0 * Float64(1.421413741 + Float64(t_0 * Float64(-1.453152027 + Float64(t_0 * 1.061405429))))))))) * exp(Float64(-Float64(abs(x) * abs(x))))))
end
function tmp = code(x)
	t_0 = 1.0 / (1.0 + (0.3275911 * abs(x)));
	tmp = 1.0 - ((t_0 * (0.254829592 + (t_0 * (-0.284496736 + (t_0 * (1.421413741 + (t_0 * (-1.453152027 + (t_0 * 1.061405429))))))))) * exp(-(abs(x) * abs(x))));
end
code[x_] := Block[{t$95$0 = N[(1.0 / N[(1.0 + N[(0.3275911 * N[Abs[x], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, N[(1.0 - N[(N[(t$95$0 * N[(0.254829592 + N[(t$95$0 * N[(-0.284496736 + N[(t$95$0 * N[(1.421413741 + N[(t$95$0 * N[(-1.453152027 + N[(t$95$0 * 1.061405429), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[Exp[(-N[(N[Abs[x], $MachinePrecision] * N[Abs[x], $MachinePrecision]), $MachinePrecision])], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \frac{1}{1 + 0.3275911 \cdot \left|x\right|}\\
1 - \left(t\_0 \cdot \left(0.254829592 + t\_0 \cdot \left(-0.284496736 + t\_0 \cdot \left(1.421413741 + t\_0 \cdot \left(-1.453152027 + t\_0 \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|}
\end{array}
\end{array}

Alternative 1: 98.9% accurate, 7.3× speedup?

\[\begin{array}{l} x_m = \left|x\right| \\ \begin{array}{l} \mathbf{if}\;\left|x\_m\right| \leq 4 \cdot 10^{-7}:\\ \;\;\;\;10^{-9} + x\_m \cdot \left(1.128386358070218 + x\_m \cdot \left(x\_m \cdot -0.37545125292247583 - 0.00011824294398844343\right)\right)\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \end{array} \]
x_m = (fabs.f64 x)
(FPCore (x_m)
 :precision binary64
 (if (<= (fabs x_m) 4e-7)
   (+
    1e-9
    (*
     x_m
     (+
      1.128386358070218
      (* x_m (- (* x_m -0.37545125292247583) 0.00011824294398844343)))))
   1.0))
x_m = fabs(x);
double code(double x_m) {
	double tmp;
	if (fabs(x_m) <= 4e-7) {
		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * ((x_m * -0.37545125292247583) - 0.00011824294398844343))));
	} else {
		tmp = 1.0;
	}
	return tmp;
}
x_m = abs(x)
real(8) function code(x_m)
    real(8), intent (in) :: x_m
    real(8) :: tmp
    if (abs(x_m) <= 4d-7) then
        tmp = 1d-9 + (x_m * (1.128386358070218d0 + (x_m * ((x_m * (-0.37545125292247583d0)) - 0.00011824294398844343d0))))
    else
        tmp = 1.0d0
    end if
    code = tmp
end function
x_m = Math.abs(x);
public static double code(double x_m) {
	double tmp;
	if (Math.abs(x_m) <= 4e-7) {
		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * ((x_m * -0.37545125292247583) - 0.00011824294398844343))));
	} else {
		tmp = 1.0;
	}
	return tmp;
}
x_m = math.fabs(x)
def code(x_m):
	tmp = 0
	if math.fabs(x_m) <= 4e-7:
		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * ((x_m * -0.37545125292247583) - 0.00011824294398844343))))
	else:
		tmp = 1.0
	return tmp
x_m = abs(x)
function code(x_m)
	tmp = 0.0
	if (abs(x_m) <= 4e-7)
		tmp = Float64(1e-9 + Float64(x_m * Float64(1.128386358070218 + Float64(x_m * Float64(Float64(x_m * -0.37545125292247583) - 0.00011824294398844343)))));
	else
		tmp = 1.0;
	end
	return tmp
end
x_m = abs(x);
function tmp_2 = code(x_m)
	tmp = 0.0;
	if (abs(x_m) <= 4e-7)
		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * ((x_m * -0.37545125292247583) - 0.00011824294398844343))));
	else
		tmp = 1.0;
	end
	tmp_2 = tmp;
end
x_m = N[Abs[x], $MachinePrecision]
code[x$95$m_] := If[LessEqual[N[Abs[x$95$m], $MachinePrecision], 4e-7], N[(1e-9 + N[(x$95$m * N[(1.128386358070218 + N[(x$95$m * N[(N[(x$95$m * -0.37545125292247583), $MachinePrecision] - 0.00011824294398844343), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 1.0]
\begin{array}{l}
x_m = \left|x\right|

\\
\begin{array}{l}
\mathbf{if}\;\left|x\_m\right| \leq 4 \cdot 10^{-7}:\\
\;\;\;\;10^{-9} + x\_m \cdot \left(1.128386358070218 + x\_m \cdot \left(x\_m \cdot -0.37545125292247583 - 0.00011824294398844343\right)\right)\\

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


\end{array}
\end{array}
Derivation
  1. Split input into 2 regimes
  2. if (fabs.f64 x) < 3.9999999999999998e-7

    1. Initial program 57.8%

      \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
    2. Simplified57.8%

      \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
    3. Add Preprocessing
    4. Applied egg-rr57.4%

      \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
    5. Step-by-step derivation
      1. Simplified57.4%

        \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
      2. Taylor expanded in x around 0 98.6%

        \[\leadsto \color{blue}{10^{-9} + x \cdot \left(1.128386358070218 + x \cdot \left(-0.37545125292247583 \cdot x - 0.00011824294398844343\right)\right)} \]

      if 3.9999999999999998e-7 < (fabs.f64 x)

      1. Initial program 100.0%

        \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
      2. Simplified100.0%

        \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
      3. Add Preprocessing
      4. Applied egg-rr100.0%

        \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
      5. Step-by-step derivation
        1. Simplified100.0%

          \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
        2. Taylor expanded in x around inf 100.0%

          \[\leadsto \color{blue}{1} \]
      6. Recombined 2 regimes into one program.
      7. Final simplification99.3%

        \[\leadsto \begin{array}{l} \mathbf{if}\;\left|x\right| \leq 4 \cdot 10^{-7}:\\ \;\;\;\;10^{-9} + x \cdot \left(1.128386358070218 + x \cdot \left(x \cdot -0.37545125292247583 - 0.00011824294398844343\right)\right)\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \]
      8. Add Preprocessing

      Alternative 2: 99.3% accurate, 61.1× speedup?

      \[\begin{array}{l} x_m = \left|x\right| \\ \begin{array}{l} \mathbf{if}\;x\_m \leq 0.88:\\ \;\;\;\;10^{-9} + x\_m \cdot \left(1.128386358070218 + x\_m \cdot -0.00011824294398844343\right)\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \end{array} \]
      x_m = (fabs.f64 x)
      (FPCore (x_m)
       :precision binary64
       (if (<= x_m 0.88)
         (+ 1e-9 (* x_m (+ 1.128386358070218 (* x_m -0.00011824294398844343))))
         1.0))
      x_m = fabs(x);
      double code(double x_m) {
      	double tmp;
      	if (x_m <= 0.88) {
      		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * -0.00011824294398844343)));
      	} else {
      		tmp = 1.0;
      	}
      	return tmp;
      }
      
      x_m = abs(x)
      real(8) function code(x_m)
          real(8), intent (in) :: x_m
          real(8) :: tmp
          if (x_m <= 0.88d0) then
              tmp = 1d-9 + (x_m * (1.128386358070218d0 + (x_m * (-0.00011824294398844343d0))))
          else
              tmp = 1.0d0
          end if
          code = tmp
      end function
      
      x_m = Math.abs(x);
      public static double code(double x_m) {
      	double tmp;
      	if (x_m <= 0.88) {
      		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * -0.00011824294398844343)));
      	} else {
      		tmp = 1.0;
      	}
      	return tmp;
      }
      
      x_m = math.fabs(x)
      def code(x_m):
      	tmp = 0
      	if x_m <= 0.88:
      		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * -0.00011824294398844343)))
      	else:
      		tmp = 1.0
      	return tmp
      
      x_m = abs(x)
      function code(x_m)
      	tmp = 0.0
      	if (x_m <= 0.88)
      		tmp = Float64(1e-9 + Float64(x_m * Float64(1.128386358070218 + Float64(x_m * -0.00011824294398844343))));
      	else
      		tmp = 1.0;
      	end
      	return tmp
      end
      
      x_m = abs(x);
      function tmp_2 = code(x_m)
      	tmp = 0.0;
      	if (x_m <= 0.88)
      		tmp = 1e-9 + (x_m * (1.128386358070218 + (x_m * -0.00011824294398844343)));
      	else
      		tmp = 1.0;
      	end
      	tmp_2 = tmp;
      end
      
      x_m = N[Abs[x], $MachinePrecision]
      code[x$95$m_] := If[LessEqual[x$95$m, 0.88], N[(1e-9 + N[(x$95$m * N[(1.128386358070218 + N[(x$95$m * -0.00011824294398844343), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 1.0]
      
      \begin{array}{l}
      x_m = \left|x\right|
      
      \\
      \begin{array}{l}
      \mathbf{if}\;x\_m \leq 0.88:\\
      \;\;\;\;10^{-9} + x\_m \cdot \left(1.128386358070218 + x\_m \cdot -0.00011824294398844343\right)\\
      
      \mathbf{else}:\\
      \;\;\;\;1\\
      
      
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 2 regimes
      2. if x < 0.880000000000000004

        1. Initial program 70.6%

          \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
        2. Simplified70.6%

          \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
        3. Add Preprocessing
        4. Applied egg-rr70.3%

          \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
        5. Step-by-step derivation
          1. Simplified70.3%

            \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
          2. Taylor expanded in x around 0 68.9%

            \[\leadsto \color{blue}{10^{-9} + x \cdot \left(1.128386358070218 + -0.00011824294398844343 \cdot x\right)} \]
          3. Step-by-step derivation
            1. *-commutative68.9%

              \[\leadsto 10^{-9} + x \cdot \left(1.128386358070218 + \color{blue}{x \cdot -0.00011824294398844343}\right) \]
          4. Simplified68.9%

            \[\leadsto \color{blue}{10^{-9} + x \cdot \left(1.128386358070218 + x \cdot -0.00011824294398844343\right)} \]

          if 0.880000000000000004 < x

          1. Initial program 100.0%

            \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
          2. Simplified100.0%

            \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
          3. Add Preprocessing
          4. Applied egg-rr100.0%

            \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
          5. Step-by-step derivation
            1. Simplified100.0%

              \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
            2. Taylor expanded in x around inf 100.0%

              \[\leadsto \color{blue}{1} \]
          6. Recombined 2 regimes into one program.
          7. Add Preprocessing

          Alternative 3: 99.2% accurate, 85.5× speedup?

          \[\begin{array}{l} x_m = \left|x\right| \\ \begin{array}{l} \mathbf{if}\;x\_m \leq 0.88:\\ \;\;\;\;10^{-9} + x\_m \cdot 1.128386358070218\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \end{array} \]
          x_m = (fabs.f64 x)
          (FPCore (x_m)
           :precision binary64
           (if (<= x_m 0.88) (+ 1e-9 (* x_m 1.128386358070218)) 1.0))
          x_m = fabs(x);
          double code(double x_m) {
          	double tmp;
          	if (x_m <= 0.88) {
          		tmp = 1e-9 + (x_m * 1.128386358070218);
          	} else {
          		tmp = 1.0;
          	}
          	return tmp;
          }
          
          x_m = abs(x)
          real(8) function code(x_m)
              real(8), intent (in) :: x_m
              real(8) :: tmp
              if (x_m <= 0.88d0) then
                  tmp = 1d-9 + (x_m * 1.128386358070218d0)
              else
                  tmp = 1.0d0
              end if
              code = tmp
          end function
          
          x_m = Math.abs(x);
          public static double code(double x_m) {
          	double tmp;
          	if (x_m <= 0.88) {
          		tmp = 1e-9 + (x_m * 1.128386358070218);
          	} else {
          		tmp = 1.0;
          	}
          	return tmp;
          }
          
          x_m = math.fabs(x)
          def code(x_m):
          	tmp = 0
          	if x_m <= 0.88:
          		tmp = 1e-9 + (x_m * 1.128386358070218)
          	else:
          		tmp = 1.0
          	return tmp
          
          x_m = abs(x)
          function code(x_m)
          	tmp = 0.0
          	if (x_m <= 0.88)
          		tmp = Float64(1e-9 + Float64(x_m * 1.128386358070218));
          	else
          		tmp = 1.0;
          	end
          	return tmp
          end
          
          x_m = abs(x);
          function tmp_2 = code(x_m)
          	tmp = 0.0;
          	if (x_m <= 0.88)
          		tmp = 1e-9 + (x_m * 1.128386358070218);
          	else
          		tmp = 1.0;
          	end
          	tmp_2 = tmp;
          end
          
          x_m = N[Abs[x], $MachinePrecision]
          code[x$95$m_] := If[LessEqual[x$95$m, 0.88], N[(1e-9 + N[(x$95$m * 1.128386358070218), $MachinePrecision]), $MachinePrecision], 1.0]
          
          \begin{array}{l}
          x_m = \left|x\right|
          
          \\
          \begin{array}{l}
          \mathbf{if}\;x\_m \leq 0.88:\\
          \;\;\;\;10^{-9} + x\_m \cdot 1.128386358070218\\
          
          \mathbf{else}:\\
          \;\;\;\;1\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 2 regimes
          2. if x < 0.880000000000000004

            1. Initial program 70.6%

              \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
            2. Simplified70.6%

              \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
            3. Add Preprocessing
            4. Applied egg-rr70.3%

              \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
            5. Step-by-step derivation
              1. Simplified70.3%

                \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
              2. Taylor expanded in x around 0 68.9%

                \[\leadsto \color{blue}{10^{-9} + 1.128386358070218 \cdot x} \]

              if 0.880000000000000004 < x

              1. Initial program 100.0%

                \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
              2. Simplified100.0%

                \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
              3. Add Preprocessing
              4. Applied egg-rr100.0%

                \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
              5. Step-by-step derivation
                1. Simplified100.0%

                  \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
                2. Taylor expanded in x around inf 100.0%

                  \[\leadsto \color{blue}{1} \]
              6. Recombined 2 regimes into one program.
              7. Final simplification76.5%

                \[\leadsto \begin{array}{l} \mathbf{if}\;x \leq 0.88:\\ \;\;\;\;10^{-9} + x \cdot 1.128386358070218\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \]
              8. Add Preprocessing

              Alternative 4: 97.6% accurate, 142.3× speedup?

              \[\begin{array}{l} x_m = \left|x\right| \\ \begin{array}{l} \mathbf{if}\;x\_m \leq 2.8 \cdot 10^{-5}:\\ \;\;\;\;10^{-9}\\ \mathbf{else}:\\ \;\;\;\;1\\ \end{array} \end{array} \]
              x_m = (fabs.f64 x)
              (FPCore (x_m) :precision binary64 (if (<= x_m 2.8e-5) 1e-9 1.0))
              x_m = fabs(x);
              double code(double x_m) {
              	double tmp;
              	if (x_m <= 2.8e-5) {
              		tmp = 1e-9;
              	} else {
              		tmp = 1.0;
              	}
              	return tmp;
              }
              
              x_m = abs(x)
              real(8) function code(x_m)
                  real(8), intent (in) :: x_m
                  real(8) :: tmp
                  if (x_m <= 2.8d-5) then
                      tmp = 1d-9
                  else
                      tmp = 1.0d0
                  end if
                  code = tmp
              end function
              
              x_m = Math.abs(x);
              public static double code(double x_m) {
              	double tmp;
              	if (x_m <= 2.8e-5) {
              		tmp = 1e-9;
              	} else {
              		tmp = 1.0;
              	}
              	return tmp;
              }
              
              x_m = math.fabs(x)
              def code(x_m):
              	tmp = 0
              	if x_m <= 2.8e-5:
              		tmp = 1e-9
              	else:
              		tmp = 1.0
              	return tmp
              
              x_m = abs(x)
              function code(x_m)
              	tmp = 0.0
              	if (x_m <= 2.8e-5)
              		tmp = 1e-9;
              	else
              		tmp = 1.0;
              	end
              	return tmp
              end
              
              x_m = abs(x);
              function tmp_2 = code(x_m)
              	tmp = 0.0;
              	if (x_m <= 2.8e-5)
              		tmp = 1e-9;
              	else
              		tmp = 1.0;
              	end
              	tmp_2 = tmp;
              end
              
              x_m = N[Abs[x], $MachinePrecision]
              code[x$95$m_] := If[LessEqual[x$95$m, 2.8e-5], 1e-9, 1.0]
              
              \begin{array}{l}
              x_m = \left|x\right|
              
              \\
              \begin{array}{l}
              \mathbf{if}\;x\_m \leq 2.8 \cdot 10^{-5}:\\
              \;\;\;\;10^{-9}\\
              
              \mathbf{else}:\\
              \;\;\;\;1\\
              
              
              \end{array}
              \end{array}
              
              Derivation
              1. Split input into 2 regimes
              2. if x < 2.79999999999999996e-5

                1. Initial program 70.6%

                  \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
                2. Simplified70.6%

                  \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
                3. Add Preprocessing
                4. Applied egg-rr70.3%

                  \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
                5. Step-by-step derivation
                  1. Simplified70.3%

                    \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
                  2. Taylor expanded in x around 0 71.4%

                    \[\leadsto \color{blue}{10^{-9}} \]

                  if 2.79999999999999996e-5 < x

                  1. Initial program 100.0%

                    \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
                  2. Simplified100.0%

                    \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
                  3. Add Preprocessing
                  4. Applied egg-rr100.0%

                    \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
                  5. Step-by-step derivation
                    1. Simplified100.0%

                      \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
                    2. Taylor expanded in x around inf 100.0%

                      \[\leadsto \color{blue}{1} \]
                  6. Recombined 2 regimes into one program.
                  7. Add Preprocessing

                  Alternative 5: 53.3% accurate, 856.0× speedup?

                  \[\begin{array}{l} x_m = \left|x\right| \\ 10^{-9} \end{array} \]
                  x_m = (fabs.f64 x)
                  (FPCore (x_m) :precision binary64 1e-9)
                  x_m = fabs(x);
                  double code(double x_m) {
                  	return 1e-9;
                  }
                  
                  x_m = abs(x)
                  real(8) function code(x_m)
                      real(8), intent (in) :: x_m
                      code = 1d-9
                  end function
                  
                  x_m = Math.abs(x);
                  public static double code(double x_m) {
                  	return 1e-9;
                  }
                  
                  x_m = math.fabs(x)
                  def code(x_m):
                  	return 1e-9
                  
                  x_m = abs(x)
                  function code(x_m)
                  	return 1e-9
                  end
                  
                  x_m = abs(x);
                  function tmp = code(x_m)
                  	tmp = 1e-9;
                  end
                  
                  x_m = N[Abs[x], $MachinePrecision]
                  code[x$95$m_] := 1e-9
                  
                  \begin{array}{l}
                  x_m = \left|x\right|
                  
                  \\
                  10^{-9}
                  \end{array}
                  
                  Derivation
                  1. Initial program 77.7%

                    \[1 - \left(\frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(0.254829592 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-0.284496736 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(1.421413741 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot \left(-1.453152027 + \frac{1}{1 + 0.3275911 \cdot \left|x\right|} \cdot 1.061405429\right)\right)\right)\right)\right) \cdot e^{-\left|x\right| \cdot \left|x\right|} \]
                  2. Simplified77.7%

                    \[\leadsto \color{blue}{1 - \frac{\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{\mathsf{fma}\left(0.3275911, \left|x\right|, 1\right)}}{{\left(e^{x}\right)}^{x}}} \]
                  3. Add Preprocessing
                  4. Applied egg-rr77.5%

                    \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{3}}{1 + \left({\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}^{2} + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{\mathsf{fma}\left(0.3275911, x, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(0.3275911, x, 1\right)}\right)}} \]
                  5. Step-by-step derivation
                    1. Simplified77.5%

                      \[\leadsto \color{blue}{\frac{1 - {\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{3}}{{\left(\frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}^{2} + \left(1 + \frac{0.254829592 + \frac{-0.284496736 + \frac{1.421413741 + \frac{-1.453152027 + \frac{1.061405429}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{\mathsf{fma}\left(x, 0.3275911, 1\right)}}{e^{{x}^{2}} \cdot \mathsf{fma}\left(x, 0.3275911, 1\right)}\right)}} \]
                    2. Taylor expanded in x around 0 56.8%

                      \[\leadsto \color{blue}{10^{-9}} \]
                    3. Add Preprocessing

                    Reproduce

                    ?
                    herbie shell --seed 2024146 
                    (FPCore (x)
                      :name "Jmat.Real.erf"
                      :precision binary64
                      (- 1.0 (* (* (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x)))) (+ 0.254829592 (* (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x)))) (+ -0.284496736 (* (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x)))) (+ 1.421413741 (* (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x)))) (+ -1.453152027 (* (/ 1.0 (+ 1.0 (* 0.3275911 (fabs x)))) 1.061405429))))))))) (exp (- (* (fabs x) (fabs x)))))))