Maksimov and Kolovsky, Equation (32)

Percentage Accurate: 75.4% → 96.8%
Time: 12.1s
Alternatives: 8
Speedup: 2.6×

Specification

?
\[\begin{array}{l} \\ \cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \end{array} \]
(FPCore (K m n M l)
 :precision binary64
 (*
  (cos (- (/ (* K (+ m n)) 2.0) M))
  (exp (- (- (pow (- (/ (+ m n) 2.0) M) 2.0)) (- l (fabs (- m n)))))))
double code(double K, double m, double n, double M, double l) {
	return cos((((K * (m + n)) / 2.0) - M)) * exp((-pow((((m + n) / 2.0) - M), 2.0) - (l - fabs((m - n)))));
}
real(8) function code(k, m, n, m_1, l)
    real(8), intent (in) :: k
    real(8), intent (in) :: m
    real(8), intent (in) :: n
    real(8), intent (in) :: m_1
    real(8), intent (in) :: l
    code = cos((((k * (m + n)) / 2.0d0) - m_1)) * exp((-((((m + n) / 2.0d0) - m_1) ** 2.0d0) - (l - abs((m - n)))))
end function
public static double code(double K, double m, double n, double M, double l) {
	return Math.cos((((K * (m + n)) / 2.0) - M)) * Math.exp((-Math.pow((((m + n) / 2.0) - M), 2.0) - (l - Math.abs((m - n)))));
}
def code(K, m, n, M, l):
	return math.cos((((K * (m + n)) / 2.0) - M)) * math.exp((-math.pow((((m + n) / 2.0) - M), 2.0) - (l - math.fabs((m - n)))))
function code(K, m, n, M, l)
	return Float64(cos(Float64(Float64(Float64(K * Float64(m + n)) / 2.0) - M)) * exp(Float64(Float64(-(Float64(Float64(Float64(m + n) / 2.0) - M) ^ 2.0)) - Float64(l - abs(Float64(m - n))))))
end
function tmp = code(K, m, n, M, l)
	tmp = cos((((K * (m + n)) / 2.0) - M)) * exp((-((((m + n) / 2.0) - M) ^ 2.0) - (l - abs((m - n)))));
end
code[K_, m_, n_, M_, l_] := N[(N[Cos[N[(N[(N[(K * N[(m + n), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision] - M), $MachinePrecision]], $MachinePrecision] * N[Exp[N[((-N[Power[N[(N[(N[(m + n), $MachinePrecision] / 2.0), $MachinePrecision] - M), $MachinePrecision], 2.0], $MachinePrecision]) - N[(l - N[Abs[N[(m - n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)}
\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 8 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: 75.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \end{array} \]
(FPCore (K m n M l)
 :precision binary64
 (*
  (cos (- (/ (* K (+ m n)) 2.0) M))
  (exp (- (- (pow (- (/ (+ m n) 2.0) M) 2.0)) (- l (fabs (- m n)))))))
double code(double K, double m, double n, double M, double l) {
	return cos((((K * (m + n)) / 2.0) - M)) * exp((-pow((((m + n) / 2.0) - M), 2.0) - (l - fabs((m - n)))));
}
real(8) function code(k, m, n, m_1, l)
    real(8), intent (in) :: k
    real(8), intent (in) :: m
    real(8), intent (in) :: n
    real(8), intent (in) :: m_1
    real(8), intent (in) :: l
    code = cos((((k * (m + n)) / 2.0d0) - m_1)) * exp((-((((m + n) / 2.0d0) - m_1) ** 2.0d0) - (l - abs((m - n)))))
end function
public static double code(double K, double m, double n, double M, double l) {
	return Math.cos((((K * (m + n)) / 2.0) - M)) * Math.exp((-Math.pow((((m + n) / 2.0) - M), 2.0) - (l - Math.abs((m - n)))));
}
def code(K, m, n, M, l):
	return math.cos((((K * (m + n)) / 2.0) - M)) * math.exp((-math.pow((((m + n) / 2.0) - M), 2.0) - (l - math.fabs((m - n)))))
function code(K, m, n, M, l)
	return Float64(cos(Float64(Float64(Float64(K * Float64(m + n)) / 2.0) - M)) * exp(Float64(Float64(-(Float64(Float64(Float64(m + n) / 2.0) - M) ^ 2.0)) - Float64(l - abs(Float64(m - n))))))
end
function tmp = code(K, m, n, M, l)
	tmp = cos((((K * (m + n)) / 2.0) - M)) * exp((-((((m + n) / 2.0) - M) ^ 2.0) - (l - abs((m - n)))));
end
code[K_, m_, n_, M_, l_] := N[(N[Cos[N[(N[(N[(K * N[(m + n), $MachinePrecision]), $MachinePrecision] / 2.0), $MachinePrecision] - M), $MachinePrecision]], $MachinePrecision] * N[Exp[N[((-N[Power[N[(N[(N[(m + n), $MachinePrecision] / 2.0), $MachinePrecision] - M), $MachinePrecision], 2.0], $MachinePrecision]) - N[(l - N[Abs[N[(m - n), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}

\\
\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)}
\end{array}

Alternative 1: 96.8% accurate, 1.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \mathsf{fma}\left(0.5, m + n, -M\right)\\ \cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(t\_0, t\_0, \ell\right)} \end{array} \end{array} \]
(FPCore (K m n M l)
 :precision binary64
 (let* ((t_0 (fma 0.5 (+ m n) (- M))))
   (* (cos M) (exp (- (fabs (- n m)) (fma t_0 t_0 l))))))
double code(double K, double m, double n, double M, double l) {
	double t_0 = fma(0.5, (m + n), -M);
	return cos(M) * exp((fabs((n - m)) - fma(t_0, t_0, l)));
}
function code(K, m, n, M, l)
	t_0 = fma(0.5, Float64(m + n), Float64(-M))
	return Float64(cos(M) * exp(Float64(abs(Float64(n - m)) - fma(t_0, t_0, l))))
end
code[K_, m_, n_, M_, l_] := Block[{t$95$0 = N[(0.5 * N[(m + n), $MachinePrecision] + (-M)), $MachinePrecision]}, N[(N[Cos[M], $MachinePrecision] * N[Exp[N[(N[Abs[N[(n - m), $MachinePrecision]], $MachinePrecision] - N[(t$95$0 * t$95$0 + l), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(0.5, m + n, -M\right)\\
\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(t\_0, t\_0, \ell\right)}
\end{array}
\end{array}
Derivation
  1. Initial program 75.6%

    \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
  2. Add Preprocessing
  3. Taylor expanded in K around 0

    \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
  4. Step-by-step derivation
    1. lower-*.f64N/A

      \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    2. cos-negN/A

      \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    3. lower-cos.f64N/A

      \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    4. lower-exp.f64N/A

      \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    5. lower--.f64N/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    6. fabs-subN/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    7. sub-negN/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    8. mul-1-negN/A

      \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    9. lower-fabs.f64N/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    10. mul-1-negN/A

      \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    11. sub-negN/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    12. lower--.f64N/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    13. +-commutativeN/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
    14. unpow2N/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
    15. lower-fma.f64N/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
  5. Applied rewrites97.7%

    \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
  6. Final simplification97.7%

    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, m + n, -M\right), \mathsf{fma}\left(0.5, m + n, -M\right), \ell\right)} \]
  7. Add Preprocessing

Alternative 2: 96.4% accurate, 2.5× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \mathsf{fma}\left(0.5, m + n, -M\right)\\ e^{\left|n - m\right| - \mathsf{fma}\left(t\_0, t\_0, \ell\right)} \cdot 1 \end{array} \end{array} \]
(FPCore (K m n M l)
 :precision binary64
 (let* ((t_0 (fma 0.5 (+ m n) (- M))))
   (* (exp (- (fabs (- n m)) (fma t_0 t_0 l))) 1.0)))
double code(double K, double m, double n, double M, double l) {
	double t_0 = fma(0.5, (m + n), -M);
	return exp((fabs((n - m)) - fma(t_0, t_0, l))) * 1.0;
}
function code(K, m, n, M, l)
	t_0 = fma(0.5, Float64(m + n), Float64(-M))
	return Float64(exp(Float64(abs(Float64(n - m)) - fma(t_0, t_0, l))) * 1.0)
end
code[K_, m_, n_, M_, l_] := Block[{t$95$0 = N[(0.5 * N[(m + n), $MachinePrecision] + (-M)), $MachinePrecision]}, N[(N[Exp[N[(N[Abs[N[(n - m), $MachinePrecision]], $MachinePrecision] - N[(t$95$0 * t$95$0 + l), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] * 1.0), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(0.5, m + n, -M\right)\\
e^{\left|n - m\right| - \mathsf{fma}\left(t\_0, t\_0, \ell\right)} \cdot 1
\end{array}
\end{array}
Derivation
  1. Initial program 75.6%

    \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
  2. Add Preprocessing
  3. Taylor expanded in K around 0

    \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
  4. Step-by-step derivation
    1. lower-*.f64N/A

      \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    2. cos-negN/A

      \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    3. lower-cos.f64N/A

      \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    4. lower-exp.f64N/A

      \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    5. lower--.f64N/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
    6. fabs-subN/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    7. sub-negN/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    8. mul-1-negN/A

      \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    9. lower-fabs.f64N/A

      \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    10. mul-1-negN/A

      \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    11. sub-negN/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    12. lower--.f64N/A

      \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
    13. +-commutativeN/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
    14. unpow2N/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
    15. lower-fma.f64N/A

      \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
  5. Applied rewrites97.7%

    \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
  6. Taylor expanded in M around 0

    \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \ell\right)}} \]
  7. Step-by-step derivation
    1. Applied rewrites97.7%

      \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
    2. Final simplification97.7%

      \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, m + n, -M\right), \mathsf{fma}\left(0.5, m + n, -M\right), \ell\right)} \cdot 1 \]
    3. Add Preprocessing

    Alternative 3: 92.2% accurate, 2.6× speedup?

    \[\begin{array}{l} \\ \begin{array}{l} t_0 := \left|n - m\right|\\ t_1 := 1 \cdot e^{t\_0 - M \cdot M}\\ \mathbf{if}\;M \leq -6.5 \cdot 10^{+167}:\\ \;\;\;\;t\_1\\ \mathbf{elif}\;M \leq 2 \cdot 10^{+151}:\\ \;\;\;\;e^{t\_0 - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)}\\ \mathbf{else}:\\ \;\;\;\;t\_1\\ \end{array} \end{array} \]
    (FPCore (K m n M l)
     :precision binary64
     (let* ((t_0 (fabs (- n m))) (t_1 (* 1.0 (exp (- t_0 (* M M))))))
       (if (<= M -6.5e+167)
         t_1
         (if (<= M 2e+151) (exp (- t_0 (fma 0.25 (* (+ m n) (+ m n)) l))) t_1))))
    double code(double K, double m, double n, double M, double l) {
    	double t_0 = fabs((n - m));
    	double t_1 = 1.0 * exp((t_0 - (M * M)));
    	double tmp;
    	if (M <= -6.5e+167) {
    		tmp = t_1;
    	} else if (M <= 2e+151) {
    		tmp = exp((t_0 - fma(0.25, ((m + n) * (m + n)), l)));
    	} else {
    		tmp = t_1;
    	}
    	return tmp;
    }
    
    function code(K, m, n, M, l)
    	t_0 = abs(Float64(n - m))
    	t_1 = Float64(1.0 * exp(Float64(t_0 - Float64(M * M))))
    	tmp = 0.0
    	if (M <= -6.5e+167)
    		tmp = t_1;
    	elseif (M <= 2e+151)
    		tmp = exp(Float64(t_0 - fma(0.25, Float64(Float64(m + n) * Float64(m + n)), l)));
    	else
    		tmp = t_1;
    	end
    	return tmp
    end
    
    code[K_, m_, n_, M_, l_] := Block[{t$95$0 = N[Abs[N[(n - m), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(1.0 * N[Exp[N[(t$95$0 - N[(M * M), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[M, -6.5e+167], t$95$1, If[LessEqual[M, 2e+151], N[Exp[N[(t$95$0 - N[(0.25 * N[(N[(m + n), $MachinePrecision] * N[(m + n), $MachinePrecision]), $MachinePrecision] + l), $MachinePrecision]), $MachinePrecision]], $MachinePrecision], t$95$1]]]]
    
    \begin{array}{l}
    
    \\
    \begin{array}{l}
    t_0 := \left|n - m\right|\\
    t_1 := 1 \cdot e^{t\_0 - M \cdot M}\\
    \mathbf{if}\;M \leq -6.5 \cdot 10^{+167}:\\
    \;\;\;\;t\_1\\
    
    \mathbf{elif}\;M \leq 2 \cdot 10^{+151}:\\
    \;\;\;\;e^{t\_0 - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)}\\
    
    \mathbf{else}:\\
    \;\;\;\;t\_1\\
    
    
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 2 regimes
    2. if M < -6.5e167 or 2.00000000000000003e151 < M

      1. Initial program 75.0%

        \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
      2. Add Preprocessing
      3. Taylor expanded in K around 0

        \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
      4. Step-by-step derivation
        1. lower-*.f64N/A

          \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
        2. cos-negN/A

          \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        3. lower-cos.f64N/A

          \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        4. lower-exp.f64N/A

          \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
        5. lower--.f64N/A

          \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
        6. fabs-subN/A

          \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        7. sub-negN/A

          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        8. mul-1-negN/A

          \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        9. lower-fabs.f64N/A

          \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        10. mul-1-negN/A

          \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        11. sub-negN/A

          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        12. lower--.f64N/A

          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
        13. +-commutativeN/A

          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
        14. unpow2N/A

          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
        15. lower-fma.f64N/A

          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
      5. Applied rewrites100.0%

        \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
      6. Taylor expanded in M around 0

        \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \ell\right)}} \]
      7. Step-by-step derivation
        1. Applied rewrites100.0%

          \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
        2. Taylor expanded in M around inf

          \[\leadsto 1 \cdot e^{\left|n - m\right| - {M}^{2}} \]
        3. Step-by-step derivation
          1. Applied rewrites100.0%

            \[\leadsto 1 \cdot e^{\left|n - m\right| - M \cdot M} \]

          if -6.5e167 < M < 2.00000000000000003e151

          1. Initial program 75.7%

            \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
          2. Add Preprocessing
          3. Taylor expanded in K around 0

            \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
          4. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
            2. cos-negN/A

              \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            3. lower-cos.f64N/A

              \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            4. lower-exp.f64N/A

              \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
            5. lower--.f64N/A

              \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
            6. fabs-subN/A

              \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            7. sub-negN/A

              \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            8. mul-1-negN/A

              \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            9. lower-fabs.f64N/A

              \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            10. mul-1-negN/A

              \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            11. sub-negN/A

              \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            12. lower--.f64N/A

              \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
            13. +-commutativeN/A

              \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
            14. unpow2N/A

              \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
            15. lower-fma.f64N/A

              \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
          5. Applied rewrites97.2%

            \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
          6. Taylor expanded in M around 0

            \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
          7. Step-by-step derivation
            1. Applied rewrites93.3%

              \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
          8. Recombined 2 regimes into one program.
          9. Add Preprocessing

          Alternative 4: 63.1% accurate, 2.6× speedup?

          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;m \leq -53:\\ \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{elif}\;m \leq -1.55 \cdot 10^{-165}:\\ \;\;\;\;e^{-\ell}\\ \mathbf{elif}\;m \leq -5.2 \cdot 10^{-299}:\\ \;\;\;\;1 \cdot e^{\left|n - m\right| - M \cdot M}\\ \mathbf{else}:\\ \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\ \end{array} \end{array} \]
          (FPCore (K m n M l)
           :precision binary64
           (if (<= m -53.0)
             (exp (* (* m m) -0.25))
             (if (<= m -1.55e-165)
               (exp (- l))
               (if (<= m -5.2e-299)
                 (* 1.0 (exp (- (fabs (- n m)) (* M M))))
                 (exp (* -0.25 (* n n)))))))
          double code(double K, double m, double n, double M, double l) {
          	double tmp;
          	if (m <= -53.0) {
          		tmp = exp(((m * m) * -0.25));
          	} else if (m <= -1.55e-165) {
          		tmp = exp(-l);
          	} else if (m <= -5.2e-299) {
          		tmp = 1.0 * exp((fabs((n - m)) - (M * M)));
          	} else {
          		tmp = exp((-0.25 * (n * n)));
          	}
          	return tmp;
          }
          
          real(8) function code(k, m, n, m_1, l)
              real(8), intent (in) :: k
              real(8), intent (in) :: m
              real(8), intent (in) :: n
              real(8), intent (in) :: m_1
              real(8), intent (in) :: l
              real(8) :: tmp
              if (m <= (-53.0d0)) then
                  tmp = exp(((m * m) * (-0.25d0)))
              else if (m <= (-1.55d-165)) then
                  tmp = exp(-l)
              else if (m <= (-5.2d-299)) then
                  tmp = 1.0d0 * exp((abs((n - m)) - (m_1 * m_1)))
              else
                  tmp = exp(((-0.25d0) * (n * n)))
              end if
              code = tmp
          end function
          
          public static double code(double K, double m, double n, double M, double l) {
          	double tmp;
          	if (m <= -53.0) {
          		tmp = Math.exp(((m * m) * -0.25));
          	} else if (m <= -1.55e-165) {
          		tmp = Math.exp(-l);
          	} else if (m <= -5.2e-299) {
          		tmp = 1.0 * Math.exp((Math.abs((n - m)) - (M * M)));
          	} else {
          		tmp = Math.exp((-0.25 * (n * n)));
          	}
          	return tmp;
          }
          
          def code(K, m, n, M, l):
          	tmp = 0
          	if m <= -53.0:
          		tmp = math.exp(((m * m) * -0.25))
          	elif m <= -1.55e-165:
          		tmp = math.exp(-l)
          	elif m <= -5.2e-299:
          		tmp = 1.0 * math.exp((math.fabs((n - m)) - (M * M)))
          	else:
          		tmp = math.exp((-0.25 * (n * n)))
          	return tmp
          
          function code(K, m, n, M, l)
          	tmp = 0.0
          	if (m <= -53.0)
          		tmp = exp(Float64(Float64(m * m) * -0.25));
          	elseif (m <= -1.55e-165)
          		tmp = exp(Float64(-l));
          	elseif (m <= -5.2e-299)
          		tmp = Float64(1.0 * exp(Float64(abs(Float64(n - m)) - Float64(M * M))));
          	else
          		tmp = exp(Float64(-0.25 * Float64(n * n)));
          	end
          	return tmp
          end
          
          function tmp_2 = code(K, m, n, M, l)
          	tmp = 0.0;
          	if (m <= -53.0)
          		tmp = exp(((m * m) * -0.25));
          	elseif (m <= -1.55e-165)
          		tmp = exp(-l);
          	elseif (m <= -5.2e-299)
          		tmp = 1.0 * exp((abs((n - m)) - (M * M)));
          	else
          		tmp = exp((-0.25 * (n * n)));
          	end
          	tmp_2 = tmp;
          end
          
          code[K_, m_, n_, M_, l_] := If[LessEqual[m, -53.0], N[Exp[N[(N[(m * m), $MachinePrecision] * -0.25), $MachinePrecision]], $MachinePrecision], If[LessEqual[m, -1.55e-165], N[Exp[(-l)], $MachinePrecision], If[LessEqual[m, -5.2e-299], N[(1.0 * N[Exp[N[(N[Abs[N[(n - m), $MachinePrecision]], $MachinePrecision] - N[(M * M), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[Exp[N[(-0.25 * N[(n * n), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]]
          
          \begin{array}{l}
          
          \\
          \begin{array}{l}
          \mathbf{if}\;m \leq -53:\\
          \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\
          
          \mathbf{elif}\;m \leq -1.55 \cdot 10^{-165}:\\
          \;\;\;\;e^{-\ell}\\
          
          \mathbf{elif}\;m \leq -5.2 \cdot 10^{-299}:\\
          \;\;\;\;1 \cdot e^{\left|n - m\right| - M \cdot M}\\
          
          \mathbf{else}:\\
          \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\
          
          
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 4 regimes
          2. if m < -53

            1. Initial program 77.3%

              \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
            2. Add Preprocessing
            3. Taylor expanded in K around 0

              \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
            4. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
              2. cos-negN/A

                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              3. lower-cos.f64N/A

                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              4. lower-exp.f64N/A

                \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
              5. lower--.f64N/A

                \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
              6. fabs-subN/A

                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              7. sub-negN/A

                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              8. mul-1-negN/A

                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              9. lower-fabs.f64N/A

                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              10. mul-1-negN/A

                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              11. sub-negN/A

                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              12. lower--.f64N/A

                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
              13. +-commutativeN/A

                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
              14. unpow2N/A

                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
              15. lower-fma.f64N/A

                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
            5. Applied rewrites100.0%

              \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
            6. Taylor expanded in M around 0

              \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
            7. Step-by-step derivation
              1. Applied rewrites98.5%

                \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
              2. Taylor expanded in m around inf

                \[\leadsto e^{\frac{-1}{4} \cdot {m}^{2}} \]
              3. Step-by-step derivation
                1. Applied rewrites98.5%

                  \[\leadsto e^{\left(m \cdot m\right) \cdot -0.25} \]

                if -53 < m < -1.54999999999999998e-165

                1. Initial program 97.3%

                  \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                2. Add Preprocessing
                3. Taylor expanded in K around 0

                  \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                4. Step-by-step derivation
                  1. lower-*.f64N/A

                    \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                  2. cos-negN/A

                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  3. lower-cos.f64N/A

                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  4. lower-exp.f64N/A

                    \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                  5. lower--.f64N/A

                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                  6. fabs-subN/A

                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  7. sub-negN/A

                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  8. mul-1-negN/A

                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  9. lower-fabs.f64N/A

                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  10. mul-1-negN/A

                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  11. sub-negN/A

                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  12. lower--.f64N/A

                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                  13. +-commutativeN/A

                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                  14. unpow2N/A

                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                  15. lower-fma.f64N/A

                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                5. Applied rewrites93.2%

                  \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                6. Taylor expanded in M around 0

                  \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                7. Step-by-step derivation
                  1. Applied rewrites86.4%

                    \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                  2. Taylor expanded in l around inf

                    \[\leadsto e^{-1 \cdot \ell} \]
                  3. Step-by-step derivation
                    1. Applied rewrites56.1%

                      \[\leadsto e^{-\ell} \]

                    if -1.54999999999999998e-165 < m < -5.1999999999999998e-299

                    1. Initial program 92.1%

                      \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                    2. Add Preprocessing
                    3. Taylor expanded in K around 0

                      \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                    4. Step-by-step derivation
                      1. lower-*.f64N/A

                        \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                      2. cos-negN/A

                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      3. lower-cos.f64N/A

                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      4. lower-exp.f64N/A

                        \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                      5. lower--.f64N/A

                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                      6. fabs-subN/A

                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      7. sub-negN/A

                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      8. mul-1-negN/A

                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      9. lower-fabs.f64N/A

                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      10. mul-1-negN/A

                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      11. sub-negN/A

                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      12. lower--.f64N/A

                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                      13. +-commutativeN/A

                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                      14. unpow2N/A

                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                      15. lower-fma.f64N/A

                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                    5. Applied rewrites96.1%

                      \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                    6. Taylor expanded in M around 0

                      \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \mathsf{fma}\left(\frac{1}{2}, n + m, \mathsf{neg}\left(M\right)\right), \ell\right)}} \]
                    7. Step-by-step derivation
                      1. Applied rewrites96.1%

                        \[\leadsto 1 \cdot e^{\color{blue}{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                      2. Taylor expanded in M around inf

                        \[\leadsto 1 \cdot e^{\left|n - m\right| - {M}^{2}} \]
                      3. Step-by-step derivation
                        1. Applied rewrites56.8%

                          \[\leadsto 1 \cdot e^{\left|n - m\right| - M \cdot M} \]

                        if -5.1999999999999998e-299 < m

                        1. Initial program 67.0%

                          \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                        2. Add Preprocessing
                        3. Taylor expanded in K around 0

                          \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                        4. Step-by-step derivation
                          1. lower-*.f64N/A

                            \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                          2. cos-negN/A

                            \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          3. lower-cos.f64N/A

                            \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          4. lower-exp.f64N/A

                            \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                          5. lower--.f64N/A

                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                          6. fabs-subN/A

                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          7. sub-negN/A

                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          8. mul-1-negN/A

                            \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          9. lower-fabs.f64N/A

                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          10. mul-1-negN/A

                            \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          11. sub-negN/A

                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          12. lower--.f64N/A

                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                          13. +-commutativeN/A

                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                          14. unpow2N/A

                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                          15. lower-fma.f64N/A

                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                        5. Applied rewrites97.9%

                          \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                        6. Taylor expanded in M around 0

                          \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                        7. Step-by-step derivation
                          1. Applied rewrites92.2%

                            \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                          2. Taylor expanded in n around inf

                            \[\leadsto e^{\frac{-1}{4} \cdot {n}^{2}} \]
                          3. Step-by-step derivation
                            1. Applied rewrites61.0%

                              \[\leadsto e^{\left(n \cdot n\right) \cdot -0.25} \]
                          4. Recombined 4 regimes into one program.
                          5. Final simplification69.7%

                            \[\leadsto \begin{array}{l} \mathbf{if}\;m \leq -53:\\ \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{elif}\;m \leq -1.55 \cdot 10^{-165}:\\ \;\;\;\;e^{-\ell}\\ \mathbf{elif}\;m \leq -5.2 \cdot 10^{-299}:\\ \;\;\;\;1 \cdot e^{\left|n - m\right| - M \cdot M}\\ \mathbf{else}:\\ \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\ \end{array} \]
                          6. Add Preprocessing

                          Alternative 5: 74.0% accurate, 2.8× speedup?

                          \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;m \leq -2 \cdot 10^{+20}:\\ \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{else}:\\ \;\;\;\;e^{\left|n - m\right| - \mathsf{fma}\left(0.25, n \cdot n, \ell\right)}\\ \end{array} \end{array} \]
                          (FPCore (K m n M l)
                           :precision binary64
                           (if (<= m -2e+20)
                             (exp (* (* m m) -0.25))
                             (exp (- (fabs (- n m)) (fma 0.25 (* n n) l)))))
                          double code(double K, double m, double n, double M, double l) {
                          	double tmp;
                          	if (m <= -2e+20) {
                          		tmp = exp(((m * m) * -0.25));
                          	} else {
                          		tmp = exp((fabs((n - m)) - fma(0.25, (n * n), l)));
                          	}
                          	return tmp;
                          }
                          
                          function code(K, m, n, M, l)
                          	tmp = 0.0
                          	if (m <= -2e+20)
                          		tmp = exp(Float64(Float64(m * m) * -0.25));
                          	else
                          		tmp = exp(Float64(abs(Float64(n - m)) - fma(0.25, Float64(n * n), l)));
                          	end
                          	return tmp
                          end
                          
                          code[K_, m_, n_, M_, l_] := If[LessEqual[m, -2e+20], N[Exp[N[(N[(m * m), $MachinePrecision] * -0.25), $MachinePrecision]], $MachinePrecision], N[Exp[N[(N[Abs[N[(n - m), $MachinePrecision]], $MachinePrecision] - N[(0.25 * N[(n * n), $MachinePrecision] + l), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]
                          
                          \begin{array}{l}
                          
                          \\
                          \begin{array}{l}
                          \mathbf{if}\;m \leq -2 \cdot 10^{+20}:\\
                          \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\
                          
                          \mathbf{else}:\\
                          \;\;\;\;e^{\left|n - m\right| - \mathsf{fma}\left(0.25, n \cdot n, \ell\right)}\\
                          
                          
                          \end{array}
                          \end{array}
                          
                          Derivation
                          1. Split input into 2 regimes
                          2. if m < -2e20

                            1. Initial program 76.9%

                              \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                            2. Add Preprocessing
                            3. Taylor expanded in K around 0

                              \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                            4. Step-by-step derivation
                              1. lower-*.f64N/A

                                \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                              2. cos-negN/A

                                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              3. lower-cos.f64N/A

                                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              4. lower-exp.f64N/A

                                \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                              5. lower--.f64N/A

                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                              6. fabs-subN/A

                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              7. sub-negN/A

                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              8. mul-1-negN/A

                                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              9. lower-fabs.f64N/A

                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              10. mul-1-negN/A

                                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              11. sub-negN/A

                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              12. lower--.f64N/A

                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                              13. +-commutativeN/A

                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                              14. unpow2N/A

                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                              15. lower-fma.f64N/A

                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                            5. Applied rewrites100.0%

                              \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                            6. Taylor expanded in M around 0

                              \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                            7. Step-by-step derivation
                              1. Applied rewrites98.5%

                                \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                              2. Taylor expanded in m around inf

                                \[\leadsto e^{\frac{-1}{4} \cdot {m}^{2}} \]
                              3. Step-by-step derivation
                                1. Applied rewrites98.5%

                                  \[\leadsto e^{\left(m \cdot m\right) \cdot -0.25} \]

                                if -2e20 < m

                                1. Initial program 75.1%

                                  \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                2. Add Preprocessing
                                3. Taylor expanded in K around 0

                                  \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                4. Step-by-step derivation
                                  1. lower-*.f64N/A

                                    \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                  2. cos-negN/A

                                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  3. lower-cos.f64N/A

                                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  4. lower-exp.f64N/A

                                    \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                  5. lower--.f64N/A

                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                  6. fabs-subN/A

                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  7. sub-negN/A

                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  8. mul-1-negN/A

                                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  9. lower-fabs.f64N/A

                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  10. mul-1-negN/A

                                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  11. sub-negN/A

                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  12. lower--.f64N/A

                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                  13. +-commutativeN/A

                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                  14. unpow2N/A

                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                  15. lower-fma.f64N/A

                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                5. Applied rewrites97.0%

                                  \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                6. Taylor expanded in M around 0

                                  \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                7. Step-by-step derivation
                                  1. Applied rewrites87.3%

                                    \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                  2. Taylor expanded in m around 0

                                    \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(\frac{1}{4}, {n}^{2}, \ell\right)} \]
                                  3. Step-by-step derivation
                                    1. Applied rewrites68.2%

                                      \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, n \cdot n, \ell\right)} \]
                                  4. Recombined 2 regimes into one program.
                                  5. Add Preprocessing

                                  Alternative 6: 62.8% accurate, 2.9× speedup?

                                  \[\begin{array}{l} \\ \begin{array}{l} \mathbf{if}\;m \leq -53:\\ \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{elif}\;m \leq -1.12 \cdot 10^{-272}:\\ \;\;\;\;e^{-\ell}\\ \mathbf{else}:\\ \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\ \end{array} \end{array} \]
                                  (FPCore (K m n M l)
                                   :precision binary64
                                   (if (<= m -53.0)
                                     (exp (* (* m m) -0.25))
                                     (if (<= m -1.12e-272) (exp (- l)) (exp (* -0.25 (* n n))))))
                                  double code(double K, double m, double n, double M, double l) {
                                  	double tmp;
                                  	if (m <= -53.0) {
                                  		tmp = exp(((m * m) * -0.25));
                                  	} else if (m <= -1.12e-272) {
                                  		tmp = exp(-l);
                                  	} else {
                                  		tmp = exp((-0.25 * (n * n)));
                                  	}
                                  	return tmp;
                                  }
                                  
                                  real(8) function code(k, m, n, m_1, l)
                                      real(8), intent (in) :: k
                                      real(8), intent (in) :: m
                                      real(8), intent (in) :: n
                                      real(8), intent (in) :: m_1
                                      real(8), intent (in) :: l
                                      real(8) :: tmp
                                      if (m <= (-53.0d0)) then
                                          tmp = exp(((m * m) * (-0.25d0)))
                                      else if (m <= (-1.12d-272)) then
                                          tmp = exp(-l)
                                      else
                                          tmp = exp(((-0.25d0) * (n * n)))
                                      end if
                                      code = tmp
                                  end function
                                  
                                  public static double code(double K, double m, double n, double M, double l) {
                                  	double tmp;
                                  	if (m <= -53.0) {
                                  		tmp = Math.exp(((m * m) * -0.25));
                                  	} else if (m <= -1.12e-272) {
                                  		tmp = Math.exp(-l);
                                  	} else {
                                  		tmp = Math.exp((-0.25 * (n * n)));
                                  	}
                                  	return tmp;
                                  }
                                  
                                  def code(K, m, n, M, l):
                                  	tmp = 0
                                  	if m <= -53.0:
                                  		tmp = math.exp(((m * m) * -0.25))
                                  	elif m <= -1.12e-272:
                                  		tmp = math.exp(-l)
                                  	else:
                                  		tmp = math.exp((-0.25 * (n * n)))
                                  	return tmp
                                  
                                  function code(K, m, n, M, l)
                                  	tmp = 0.0
                                  	if (m <= -53.0)
                                  		tmp = exp(Float64(Float64(m * m) * -0.25));
                                  	elseif (m <= -1.12e-272)
                                  		tmp = exp(Float64(-l));
                                  	else
                                  		tmp = exp(Float64(-0.25 * Float64(n * n)));
                                  	end
                                  	return tmp
                                  end
                                  
                                  function tmp_2 = code(K, m, n, M, l)
                                  	tmp = 0.0;
                                  	if (m <= -53.0)
                                  		tmp = exp(((m * m) * -0.25));
                                  	elseif (m <= -1.12e-272)
                                  		tmp = exp(-l);
                                  	else
                                  		tmp = exp((-0.25 * (n * n)));
                                  	end
                                  	tmp_2 = tmp;
                                  end
                                  
                                  code[K_, m_, n_, M_, l_] := If[LessEqual[m, -53.0], N[Exp[N[(N[(m * m), $MachinePrecision] * -0.25), $MachinePrecision]], $MachinePrecision], If[LessEqual[m, -1.12e-272], N[Exp[(-l)], $MachinePrecision], N[Exp[N[(-0.25 * N[(n * n), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]]]
                                  
                                  \begin{array}{l}
                                  
                                  \\
                                  \begin{array}{l}
                                  \mathbf{if}\;m \leq -53:\\
                                  \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\
                                  
                                  \mathbf{elif}\;m \leq -1.12 \cdot 10^{-272}:\\
                                  \;\;\;\;e^{-\ell}\\
                                  
                                  \mathbf{else}:\\
                                  \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\
                                  
                                  
                                  \end{array}
                                  \end{array}
                                  
                                  Derivation
                                  1. Split input into 3 regimes
                                  2. if m < -53

                                    1. Initial program 77.3%

                                      \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                    2. Add Preprocessing
                                    3. Taylor expanded in K around 0

                                      \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                    4. Step-by-step derivation
                                      1. lower-*.f64N/A

                                        \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                      2. cos-negN/A

                                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      3. lower-cos.f64N/A

                                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      4. lower-exp.f64N/A

                                        \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                      5. lower--.f64N/A

                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                      6. fabs-subN/A

                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      7. sub-negN/A

                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      8. mul-1-negN/A

                                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      9. lower-fabs.f64N/A

                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      10. mul-1-negN/A

                                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      11. sub-negN/A

                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      12. lower--.f64N/A

                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                      13. +-commutativeN/A

                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                      14. unpow2N/A

                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                      15. lower-fma.f64N/A

                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                    5. Applied rewrites100.0%

                                      \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                    6. Taylor expanded in M around 0

                                      \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                    7. Step-by-step derivation
                                      1. Applied rewrites98.5%

                                        \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                      2. Taylor expanded in m around inf

                                        \[\leadsto e^{\frac{-1}{4} \cdot {m}^{2}} \]
                                      3. Step-by-step derivation
                                        1. Applied rewrites98.5%

                                          \[\leadsto e^{\left(m \cdot m\right) \cdot -0.25} \]

                                        if -53 < m < -1.11999999999999994e-272

                                        1. Initial program 96.5%

                                          \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                        2. Add Preprocessing
                                        3. Taylor expanded in K around 0

                                          \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                        4. Step-by-step derivation
                                          1. lower-*.f64N/A

                                            \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                          2. cos-negN/A

                                            \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          3. lower-cos.f64N/A

                                            \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          4. lower-exp.f64N/A

                                            \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                          5. lower--.f64N/A

                                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                          6. fabs-subN/A

                                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          7. sub-negN/A

                                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          8. mul-1-negN/A

                                            \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          9. lower-fabs.f64N/A

                                            \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          10. mul-1-negN/A

                                            \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          11. sub-negN/A

                                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          12. lower--.f64N/A

                                            \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                          13. +-commutativeN/A

                                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                          14. unpow2N/A

                                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                          15. lower-fma.f64N/A

                                            \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                        5. Applied rewrites94.1%

                                          \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                        6. Taylor expanded in M around 0

                                          \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                        7. Step-by-step derivation
                                          1. Applied rewrites74.5%

                                            \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                          2. Taylor expanded in l around inf

                                            \[\leadsto e^{-1 \cdot \ell} \]
                                          3. Step-by-step derivation
                                            1. Applied rewrites49.3%

                                              \[\leadsto e^{-\ell} \]

                                            if -1.11999999999999994e-272 < m

                                            1. Initial program 67.3%

                                              \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                            2. Add Preprocessing
                                            3. Taylor expanded in K around 0

                                              \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                            4. Step-by-step derivation
                                              1. lower-*.f64N/A

                                                \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                              2. cos-negN/A

                                                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              3. lower-cos.f64N/A

                                                \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              4. lower-exp.f64N/A

                                                \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                              5. lower--.f64N/A

                                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                              6. fabs-subN/A

                                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              7. sub-negN/A

                                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              8. mul-1-negN/A

                                                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              9. lower-fabs.f64N/A

                                                \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              10. mul-1-negN/A

                                                \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              11. sub-negN/A

                                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              12. lower--.f64N/A

                                                \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                              13. +-commutativeN/A

                                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                              14. unpow2N/A

                                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                              15. lower-fma.f64N/A

                                                \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                            5. Applied rewrites98.0%

                                              \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                            6. Taylor expanded in M around 0

                                              \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                            7. Step-by-step derivation
                                              1. Applied rewrites91.7%

                                                \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                              2. Taylor expanded in n around inf

                                                \[\leadsto e^{\frac{-1}{4} \cdot {n}^{2}} \]
                                              3. Step-by-step derivation
                                                1. Applied rewrites61.5%

                                                  \[\leadsto e^{\left(n \cdot n\right) \cdot -0.25} \]
                                              4. Recombined 3 regimes into one program.
                                              5. Final simplification68.6%

                                                \[\leadsto \begin{array}{l} \mathbf{if}\;m \leq -53:\\ \;\;\;\;e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{elif}\;m \leq -1.12 \cdot 10^{-272}:\\ \;\;\;\;e^{-\ell}\\ \mathbf{else}:\\ \;\;\;\;e^{-0.25 \cdot \left(n \cdot n\right)}\\ \end{array} \]
                                              6. Add Preprocessing

                                              Alternative 7: 67.9% accurate, 2.9× speedup?

                                              \[\begin{array}{l} \\ \begin{array}{l} t_0 := e^{\left(m \cdot m\right) \cdot -0.25}\\ \mathbf{if}\;m \leq -53:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;m \leq 1.5 \cdot 10^{-62}:\\ \;\;\;\;e^{-\ell}\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \]
                                              (FPCore (K m n M l)
                                               :precision binary64
                                               (let* ((t_0 (exp (* (* m m) -0.25))))
                                                 (if (<= m -53.0) t_0 (if (<= m 1.5e-62) (exp (- l)) t_0))))
                                              double code(double K, double m, double n, double M, double l) {
                                              	double t_0 = exp(((m * m) * -0.25));
                                              	double tmp;
                                              	if (m <= -53.0) {
                                              		tmp = t_0;
                                              	} else if (m <= 1.5e-62) {
                                              		tmp = exp(-l);
                                              	} else {
                                              		tmp = t_0;
                                              	}
                                              	return tmp;
                                              }
                                              
                                              real(8) function code(k, m, n, m_1, l)
                                                  real(8), intent (in) :: k
                                                  real(8), intent (in) :: m
                                                  real(8), intent (in) :: n
                                                  real(8), intent (in) :: m_1
                                                  real(8), intent (in) :: l
                                                  real(8) :: t_0
                                                  real(8) :: tmp
                                                  t_0 = exp(((m * m) * (-0.25d0)))
                                                  if (m <= (-53.0d0)) then
                                                      tmp = t_0
                                                  else if (m <= 1.5d-62) then
                                                      tmp = exp(-l)
                                                  else
                                                      tmp = t_0
                                                  end if
                                                  code = tmp
                                              end function
                                              
                                              public static double code(double K, double m, double n, double M, double l) {
                                              	double t_0 = Math.exp(((m * m) * -0.25));
                                              	double tmp;
                                              	if (m <= -53.0) {
                                              		tmp = t_0;
                                              	} else if (m <= 1.5e-62) {
                                              		tmp = Math.exp(-l);
                                              	} else {
                                              		tmp = t_0;
                                              	}
                                              	return tmp;
                                              }
                                              
                                              def code(K, m, n, M, l):
                                              	t_0 = math.exp(((m * m) * -0.25))
                                              	tmp = 0
                                              	if m <= -53.0:
                                              		tmp = t_0
                                              	elif m <= 1.5e-62:
                                              		tmp = math.exp(-l)
                                              	else:
                                              		tmp = t_0
                                              	return tmp
                                              
                                              function code(K, m, n, M, l)
                                              	t_0 = exp(Float64(Float64(m * m) * -0.25))
                                              	tmp = 0.0
                                              	if (m <= -53.0)
                                              		tmp = t_0;
                                              	elseif (m <= 1.5e-62)
                                              		tmp = exp(Float64(-l));
                                              	else
                                              		tmp = t_0;
                                              	end
                                              	return tmp
                                              end
                                              
                                              function tmp_2 = code(K, m, n, M, l)
                                              	t_0 = exp(((m * m) * -0.25));
                                              	tmp = 0.0;
                                              	if (m <= -53.0)
                                              		tmp = t_0;
                                              	elseif (m <= 1.5e-62)
                                              		tmp = exp(-l);
                                              	else
                                              		tmp = t_0;
                                              	end
                                              	tmp_2 = tmp;
                                              end
                                              
                                              code[K_, m_, n_, M_, l_] := Block[{t$95$0 = N[Exp[N[(N[(m * m), $MachinePrecision] * -0.25), $MachinePrecision]], $MachinePrecision]}, If[LessEqual[m, -53.0], t$95$0, If[LessEqual[m, 1.5e-62], N[Exp[(-l)], $MachinePrecision], t$95$0]]]
                                              
                                              \begin{array}{l}
                                              
                                              \\
                                              \begin{array}{l}
                                              t_0 := e^{\left(m \cdot m\right) \cdot -0.25}\\
                                              \mathbf{if}\;m \leq -53:\\
                                              \;\;\;\;t\_0\\
                                              
                                              \mathbf{elif}\;m \leq 1.5 \cdot 10^{-62}:\\
                                              \;\;\;\;e^{-\ell}\\
                                              
                                              \mathbf{else}:\\
                                              \;\;\;\;t\_0\\
                                              
                                              
                                              \end{array}
                                              \end{array}
                                              
                                              Derivation
                                              1. Split input into 2 regimes
                                              2. if m < -53 or 1.5000000000000001e-62 < m

                                                1. Initial program 68.9%

                                                  \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                                2. Add Preprocessing
                                                3. Taylor expanded in K around 0

                                                  \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                4. Step-by-step derivation
                                                  1. lower-*.f64N/A

                                                    \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                  2. cos-negN/A

                                                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  3. lower-cos.f64N/A

                                                    \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  4. lower-exp.f64N/A

                                                    \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                  5. lower--.f64N/A

                                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                  6. fabs-subN/A

                                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  7. sub-negN/A

                                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  8. mul-1-negN/A

                                                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  9. lower-fabs.f64N/A

                                                    \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  10. mul-1-negN/A

                                                    \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  11. sub-negN/A

                                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  12. lower--.f64N/A

                                                    \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                  13. +-commutativeN/A

                                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                                  14. unpow2N/A

                                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                                  15. lower-fma.f64N/A

                                                    \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                                5. Applied rewrites100.0%

                                                  \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                                6. Taylor expanded in M around 0

                                                  \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                                7. Step-by-step derivation
                                                  1. Applied rewrites98.0%

                                                    \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                                  2. Taylor expanded in m around inf

                                                    \[\leadsto e^{\frac{-1}{4} \cdot {m}^{2}} \]
                                                  3. Step-by-step derivation
                                                    1. Applied rewrites91.4%

                                                      \[\leadsto e^{\left(m \cdot m\right) \cdot -0.25} \]

                                                    if -53 < m < 1.5000000000000001e-62

                                                    1. Initial program 85.2%

                                                      \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                                    2. Add Preprocessing
                                                    3. Taylor expanded in K around 0

                                                      \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                    4. Step-by-step derivation
                                                      1. lower-*.f64N/A

                                                        \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                      2. cos-negN/A

                                                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      3. lower-cos.f64N/A

                                                        \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      4. lower-exp.f64N/A

                                                        \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                      5. lower--.f64N/A

                                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                      6. fabs-subN/A

                                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      7. sub-negN/A

                                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      8. mul-1-negN/A

                                                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      9. lower-fabs.f64N/A

                                                        \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      10. mul-1-negN/A

                                                        \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      11. sub-negN/A

                                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      12. lower--.f64N/A

                                                        \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                      13. +-commutativeN/A

                                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                                      14. unpow2N/A

                                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                                      15. lower-fma.f64N/A

                                                        \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                                    5. Applied rewrites94.5%

                                                      \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                                    6. Taylor expanded in M around 0

                                                      \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                                    7. Step-by-step derivation
                                                      1. Applied rewrites78.7%

                                                        \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                                      2. Taylor expanded in l around inf

                                                        \[\leadsto e^{-1 \cdot \ell} \]
                                                      3. Step-by-step derivation
                                                        1. Applied rewrites49.9%

                                                          \[\leadsto e^{-\ell} \]
                                                      4. Recombined 2 regimes into one program.
                                                      5. Add Preprocessing

                                                      Alternative 8: 35.8% accurate, 3.5× speedup?

                                                      \[\begin{array}{l} \\ e^{-\ell} \end{array} \]
                                                      (FPCore (K m n M l) :precision binary64 (exp (- l)))
                                                      double code(double K, double m, double n, double M, double l) {
                                                      	return exp(-l);
                                                      }
                                                      
                                                      real(8) function code(k, m, n, m_1, l)
                                                          real(8), intent (in) :: k
                                                          real(8), intent (in) :: m
                                                          real(8), intent (in) :: n
                                                          real(8), intent (in) :: m_1
                                                          real(8), intent (in) :: l
                                                          code = exp(-l)
                                                      end function
                                                      
                                                      public static double code(double K, double m, double n, double M, double l) {
                                                      	return Math.exp(-l);
                                                      }
                                                      
                                                      def code(K, m, n, M, l):
                                                      	return math.exp(-l)
                                                      
                                                      function code(K, m, n, M, l)
                                                      	return exp(Float64(-l))
                                                      end
                                                      
                                                      function tmp = code(K, m, n, M, l)
                                                      	tmp = exp(-l);
                                                      end
                                                      
                                                      code[K_, m_, n_, M_, l_] := N[Exp[(-l)], $MachinePrecision]
                                                      
                                                      \begin{array}{l}
                                                      
                                                      \\
                                                      e^{-\ell}
                                                      \end{array}
                                                      
                                                      Derivation
                                                      1. Initial program 75.6%

                                                        \[\cos \left(\frac{K \cdot \left(m + n\right)}{2} - M\right) \cdot e^{\left(-{\left(\frac{m + n}{2} - M\right)}^{2}\right) - \left(\ell - \left|m - n\right|\right)} \]
                                                      2. Add Preprocessing
                                                      3. Taylor expanded in K around 0

                                                        \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                      4. Step-by-step derivation
                                                        1. lower-*.f64N/A

                                                          \[\leadsto \color{blue}{\cos \left(\mathsf{neg}\left(M\right)\right) \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                        2. cos-negN/A

                                                          \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        3. lower-cos.f64N/A

                                                          \[\leadsto \color{blue}{\cos M} \cdot e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        4. lower-exp.f64N/A

                                                          \[\leadsto \cos M \cdot \color{blue}{e^{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                        5. lower--.f64N/A

                                                          \[\leadsto \cos M \cdot e^{\color{blue}{\left|m - n\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)}} \]
                                                        6. fabs-subN/A

                                                          \[\leadsto \cos M \cdot e^{\color{blue}{\left|n - m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        7. sub-negN/A

                                                          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n + \left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        8. mul-1-negN/A

                                                          \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{-1 \cdot m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        9. lower-fabs.f64N/A

                                                          \[\leadsto \cos M \cdot e^{\color{blue}{\left|n + -1 \cdot m\right|} - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        10. mul-1-negN/A

                                                          \[\leadsto \cos M \cdot e^{\left|n + \color{blue}{\left(\mathsf{neg}\left(m\right)\right)}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        11. sub-negN/A

                                                          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        12. lower--.f64N/A

                                                          \[\leadsto \cos M \cdot e^{\left|\color{blue}{n - m}\right| - \left(\ell + {\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2}\right)} \]
                                                        13. +-commutativeN/A

                                                          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\left({\left(\frac{1}{2} \cdot \left(m + n\right) - M\right)}^{2} + \ell\right)}} \]
                                                        14. unpow2N/A

                                                          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \left(\color{blue}{\left(\frac{1}{2} \cdot \left(m + n\right) - M\right) \cdot \left(\frac{1}{2} \cdot \left(m + n\right) - M\right)} + \ell\right)} \]
                                                        15. lower-fma.f64N/A

                                                          \[\leadsto \cos M \cdot e^{\left|n - m\right| - \color{blue}{\mathsf{fma}\left(\frac{1}{2} \cdot \left(m + n\right) - M, \frac{1}{2} \cdot \left(m + n\right) - M, \ell\right)}} \]
                                                      5. Applied rewrites97.7%

                                                        \[\leadsto \color{blue}{\cos M \cdot e^{\left|n - m\right| - \mathsf{fma}\left(\mathsf{fma}\left(0.5, n + m, -M\right), \mathsf{fma}\left(0.5, n + m, -M\right), \ell\right)}} \]
                                                      6. Taylor expanded in M around 0

                                                        \[\leadsto e^{\left|n - m\right| - \left(\ell + \frac{1}{4} \cdot {\left(m + n\right)}^{2}\right)} \]
                                                      7. Step-by-step derivation
                                                        1. Applied rewrites90.1%

                                                          \[\leadsto e^{\left|n - m\right| - \mathsf{fma}\left(0.25, \left(m + n\right) \cdot \left(m + n\right), \ell\right)} \]
                                                        2. Taylor expanded in l around inf

                                                          \[\leadsto e^{-1 \cdot \ell} \]
                                                        3. Step-by-step derivation
                                                          1. Applied rewrites36.7%

                                                            \[\leadsto e^{-\ell} \]
                                                          2. Add Preprocessing

                                                          Reproduce

                                                          ?
                                                          herbie shell --seed 2024227 
                                                          (FPCore (K m n M l)
                                                            :name "Maksimov and Kolovsky, Equation (32)"
                                                            :precision binary64
                                                            (* (cos (- (/ (* K (+ m n)) 2.0) M)) (exp (- (- (pow (- (/ (+ m n) 2.0) M) 2.0)) (- l (fabs (- m n)))))))