Maksimov and Kolovsky, Equation (3)

Percentage Accurate: 72.8% → 99.8%
Time: 7.0s
Alternatives: 15
Speedup: 0.6×

Specification

?
\[\begin{array}{l} \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ \left(\left(-2 \cdot J\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot t\_0}\right)}^{2}} \end{array} \end{array} \]
(FPCore (J K U)
 :precision binary64
 (let* ((t_0 (cos (/ K 2.0))))
   (* (* (* -2.0 J) t_0) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) t_0)) 2.0))))))
double code(double J, double K, double U) {
	double t_0 = cos((K / 2.0));
	return ((-2.0 * J) * t_0) * sqrt((1.0 + pow((U / ((2.0 * J) * t_0)), 2.0)));
}
module fmin_fmax_functions
    implicit none
    private
    public fmax
    public fmin

    interface fmax
        module procedure fmax88
        module procedure fmax44
        module procedure fmax84
        module procedure fmax48
    end interface
    interface fmin
        module procedure fmin88
        module procedure fmin44
        module procedure fmin84
        module procedure fmin48
    end interface
contains
    real(8) function fmax88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(4) function fmax44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(8) function fmax84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmax48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
    end function
    real(8) function fmin88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(4) function fmin44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(8) function fmin84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmin48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
    end function
end module

real(8) function code(j, k, u)
use fmin_fmax_functions
    real(8), intent (in) :: j
    real(8), intent (in) :: k
    real(8), intent (in) :: u
    real(8) :: t_0
    t_0 = cos((k / 2.0d0))
    code = (((-2.0d0) * j) * t_0) * sqrt((1.0d0 + ((u / ((2.0d0 * j) * t_0)) ** 2.0d0)))
end function
public static double code(double J, double K, double U) {
	double t_0 = Math.cos((K / 2.0));
	return ((-2.0 * J) * t_0) * Math.sqrt((1.0 + Math.pow((U / ((2.0 * J) * t_0)), 2.0)));
}
def code(J, K, U):
	t_0 = math.cos((K / 2.0))
	return ((-2.0 * J) * t_0) * math.sqrt((1.0 + math.pow((U / ((2.0 * J) * t_0)), 2.0)))
function code(J, K, U)
	t_0 = cos(Float64(K / 2.0))
	return Float64(Float64(Float64(-2.0 * J) * t_0) * sqrt(Float64(1.0 + (Float64(U / Float64(Float64(2.0 * J) * t_0)) ^ 2.0))))
end
function tmp = code(J, K, U)
	t_0 = cos((K / 2.0));
	tmp = ((-2.0 * J) * t_0) * sqrt((1.0 + ((U / ((2.0 * J) * t_0)) ^ 2.0)));
end
code[J_, K_, U_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, N[(N[(N[(-2.0 * J), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U / N[(N[(2.0 * J), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \cos \left(\frac{K}{2}\right)\\
\left(\left(-2 \cdot J\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot t\_0}\right)}^{2}}
\end{array}
\end{array}

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 15 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: 72.8% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ \left(\left(-2 \cdot J\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot t\_0}\right)}^{2}} \end{array} \end{array} \]
(FPCore (J K U)
 :precision binary64
 (let* ((t_0 (cos (/ K 2.0))))
   (* (* (* -2.0 J) t_0) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) t_0)) 2.0))))))
double code(double J, double K, double U) {
	double t_0 = cos((K / 2.0));
	return ((-2.0 * J) * t_0) * sqrt((1.0 + pow((U / ((2.0 * J) * t_0)), 2.0)));
}
module fmin_fmax_functions
    implicit none
    private
    public fmax
    public fmin

    interface fmax
        module procedure fmax88
        module procedure fmax44
        module procedure fmax84
        module procedure fmax48
    end interface
    interface fmin
        module procedure fmin88
        module procedure fmin44
        module procedure fmin84
        module procedure fmin48
    end interface
contains
    real(8) function fmax88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(4) function fmax44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
    end function
    real(8) function fmax84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmax48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
    end function
    real(8) function fmin88(x, y) result (res)
        real(8), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(4) function fmin44(x, y) result (res)
        real(4), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
    end function
    real(8) function fmin84(x, y) result(res)
        real(8), intent (in) :: x
        real(4), intent (in) :: y
        res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
    end function
    real(8) function fmin48(x, y) result(res)
        real(4), intent (in) :: x
        real(8), intent (in) :: y
        res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
    end function
end module

real(8) function code(j, k, u)
use fmin_fmax_functions
    real(8), intent (in) :: j
    real(8), intent (in) :: k
    real(8), intent (in) :: u
    real(8) :: t_0
    t_0 = cos((k / 2.0d0))
    code = (((-2.0d0) * j) * t_0) * sqrt((1.0d0 + ((u / ((2.0d0 * j) * t_0)) ** 2.0d0)))
end function
public static double code(double J, double K, double U) {
	double t_0 = Math.cos((K / 2.0));
	return ((-2.0 * J) * t_0) * Math.sqrt((1.0 + Math.pow((U / ((2.0 * J) * t_0)), 2.0)));
}
def code(J, K, U):
	t_0 = math.cos((K / 2.0))
	return ((-2.0 * J) * t_0) * math.sqrt((1.0 + math.pow((U / ((2.0 * J) * t_0)), 2.0)))
function code(J, K, U)
	t_0 = cos(Float64(K / 2.0))
	return Float64(Float64(Float64(-2.0 * J) * t_0) * sqrt(Float64(1.0 + (Float64(U / Float64(Float64(2.0 * J) * t_0)) ^ 2.0))))
end
function tmp = code(J, K, U)
	t_0 = cos((K / 2.0));
	tmp = ((-2.0 * J) * t_0) * sqrt((1.0 + ((U / ((2.0 * J) * t_0)) ^ 2.0)));
end
code[J_, K_, U_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, N[(N[(N[(-2.0 * J), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U / N[(N[(2.0 * J), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \cos \left(\frac{K}{2}\right)\\
\left(\left(-2 \cdot J\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot t\_0}\right)}^{2}}
\end{array}
\end{array}

Alternative 1: 99.8% accurate, 0.3× speedup?

\[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(-0.5 \cdot K\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -\infty:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U\_m}{\left(J\_m + J\_m\right) \cdot t\_0}\right)}^{-2}}}\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
U_m = (fabs.f64 U)
J\_m = (fabs.f64 J)
J\_s = (copysign.f64 #s(literal 1 binary64) J)
(FPCore (J_s J_m K U_m)
 :precision binary64
 (let* ((t_0 (cos (* -0.5 K)))
        (t_1 (cos (/ K 2.0)))
        (t_2
         (*
          (* (* -2.0 J_m) t_1)
          (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
   (*
    J_s
    (if (<= t_2 (- INFINITY))
      (* -2.0 (* U_m 0.5))
      (if (<= t_2 1e+307)
        (*
         (* (* t_0 J_m) -2.0)
         (sqrt (+ 1.0 (/ 1.0 (pow (/ U_m (* (+ J_m J_m) t_0)) -2.0)))))
        (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_0)) t_0) U_m)))))))
U_m = fabs(U);
J\_m = fabs(J);
J\_s = copysign(1.0, J);
double code(double J_s, double J_m, double K, double U_m) {
	double t_0 = cos((-0.5 * K));
	double t_1 = cos((K / 2.0));
	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
	double tmp;
	if (t_2 <= -((double) INFINITY)) {
		tmp = -2.0 * (U_m * 0.5);
	} else if (t_2 <= 1e+307) {
		tmp = ((t_0 * J_m) * -2.0) * sqrt((1.0 + (1.0 / pow((U_m / ((J_m + J_m) * t_0)), -2.0))));
	} else {
		tmp = -2.0 * (((sqrt(0.25) / fabs(t_0)) * t_0) * U_m);
	}
	return J_s * tmp;
}
U_m = Math.abs(U);
J\_m = Math.abs(J);
J\_s = Math.copySign(1.0, J);
public static double code(double J_s, double J_m, double K, double U_m) {
	double t_0 = Math.cos((-0.5 * K));
	double t_1 = Math.cos((K / 2.0));
	double t_2 = ((-2.0 * J_m) * t_1) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
	double tmp;
	if (t_2 <= -Double.POSITIVE_INFINITY) {
		tmp = -2.0 * (U_m * 0.5);
	} else if (t_2 <= 1e+307) {
		tmp = ((t_0 * J_m) * -2.0) * Math.sqrt((1.0 + (1.0 / Math.pow((U_m / ((J_m + J_m) * t_0)), -2.0))));
	} else {
		tmp = -2.0 * (((Math.sqrt(0.25) / Math.abs(t_0)) * t_0) * U_m);
	}
	return J_s * tmp;
}
U_m = math.fabs(U)
J\_m = math.fabs(J)
J\_s = math.copysign(1.0, J)
def code(J_s, J_m, K, U_m):
	t_0 = math.cos((-0.5 * K))
	t_1 = math.cos((K / 2.0))
	t_2 = ((-2.0 * J_m) * t_1) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)))
	tmp = 0
	if t_2 <= -math.inf:
		tmp = -2.0 * (U_m * 0.5)
	elif t_2 <= 1e+307:
		tmp = ((t_0 * J_m) * -2.0) * math.sqrt((1.0 + (1.0 / math.pow((U_m / ((J_m + J_m) * t_0)), -2.0))))
	else:
		tmp = -2.0 * (((math.sqrt(0.25) / math.fabs(t_0)) * t_0) * U_m)
	return J_s * tmp
U_m = abs(U)
J\_m = abs(J)
J\_s = copysign(1.0, J)
function code(J_s, J_m, K, U_m)
	t_0 = cos(Float64(-0.5 * K))
	t_1 = cos(Float64(K / 2.0))
	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
	tmp = 0.0
	if (t_2 <= Float64(-Inf))
		tmp = Float64(-2.0 * Float64(U_m * 0.5));
	elseif (t_2 <= 1e+307)
		tmp = Float64(Float64(Float64(t_0 * J_m) * -2.0) * sqrt(Float64(1.0 + Float64(1.0 / (Float64(U_m / Float64(Float64(J_m + J_m) * t_0)) ^ -2.0)))));
	else
		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_0)) * t_0) * U_m));
	end
	return Float64(J_s * tmp)
end
U_m = abs(U);
J\_m = abs(J);
J\_s = sign(J) * abs(1.0);
function tmp_2 = code(J_s, J_m, K, U_m)
	t_0 = cos((-0.5 * K));
	t_1 = cos((K / 2.0));
	t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_1)) ^ 2.0)));
	tmp = 0.0;
	if (t_2 <= -Inf)
		tmp = -2.0 * (U_m * 0.5);
	elseif (t_2 <= 1e+307)
		tmp = ((t_0 * J_m) * -2.0) * sqrt((1.0 + (1.0 / ((U_m / ((J_m + J_m) * t_0)) ^ -2.0))));
	else
		tmp = -2.0 * (((sqrt(0.25) / abs(t_0)) * t_0) * U_m);
	end
	tmp_2 = J_s * tmp;
end
U_m = N[Abs[U], $MachinePrecision]
J\_m = N[Abs[J], $MachinePrecision]
J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, (-Infinity)], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[(t$95$0 * J$95$m), $MachinePrecision] * -2.0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[(1.0 / N[Power[N[(U$95$m / N[(N[(J$95$m + J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], -2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$0], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
\begin{array}{l}
U_m = \left|U\right|
\\
J\_m = \left|J\right|
\\
J\_s = \mathsf{copysign}\left(1, J\right)

\\
\begin{array}{l}
t_0 := \cos \left(-0.5 \cdot K\right)\\
t_1 := \cos \left(\frac{K}{2}\right)\\
t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
J\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_2 \leq -\infty:\\
\;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\

\mathbf{elif}\;t\_2 \leq 10^{+307}:\\
\;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U\_m}{\left(J\_m + J\_m\right) \cdot t\_0}\right)}^{-2}}}\\

\mathbf{else}:\\
\;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\


\end{array}
\end{array}
\end{array}
Derivation
  1. Split input into 3 regimes
  2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -inf.0

    1. Initial program 72.8%

      \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
    2. Taylor expanded in U around inf

      \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
    3. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
      2. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
      3. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
      4. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
      5. lower-cos.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
      6. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      7. lower-sqrt.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      8. lower-/.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      9. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      10. lower-pow.f64N/A

        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
    4. Applied rewrites24.7%

      \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
    5. Taylor expanded in J around 0

      \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
    6. Step-by-step derivation
      1. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
      2. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      3. lower-cos.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      4. lower-*.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      5. lower-sqrt.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      6. lower-/.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      7. lower-pow.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      8. lower-cos.f64N/A

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
      9. lower-*.f6452.4

        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
    7. Applied rewrites52.4%

      \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
    8. Taylor expanded in K around 0

      \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
    9. Step-by-step derivation
      1. Applied rewrites40.0%

        \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

      if -inf.0 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

      1. Initial program 72.8%

        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
      2. Step-by-step derivation
        1. lift-pow.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
        2. metadata-evalN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{\color{blue}{\left(\mathsf{neg}\left(-2\right)\right)}}} \]
        3. pow-negN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
        4. lower-unsound-/.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
        5. lower-unsound-pow.f6472.7

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
        6. lift-*.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
        7. count-2-revN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
        8. lower-+.f6472.7

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
        9. lift-cos.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\frac{K}{2}\right)}}\right)}^{-2}}} \]
        10. cos-neg-revN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right)}^{-2}}} \]
        11. lower-cos.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right)}^{-2}}} \]
        12. lift-/.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\frac{K}{2}}\right)\right)}\right)}^{-2}}} \]
        13. distribute-neg-frac2N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{K}{\mathsf{neg}\left(2\right)}\right)}}\right)}^{-2}}} \]
        14. metadata-evalN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{K}{\color{blue}{-2}}\right)}\right)}^{-2}}} \]
        15. mult-flip-revN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot \frac{1}{-2}\right)}}\right)}^{-2}}} \]
        16. *-commutativeN/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right)}^{-2}}} \]
        17. lower-*.f64N/A

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right)}^{-2}}} \]
        18. metadata-eval72.7

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\color{blue}{-0.5} \cdot K\right)}\right)}^{-2}}} \]
      3. Applied rewrites72.7%

        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}}} \]
      4. Step-by-step derivation
        1. lift-*.f64N/A

          \[\leadsto \color{blue}{\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        2. lift-*.f64N/A

          \[\leadsto \left(\color{blue}{\left(-2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        3. associate-*l*N/A

          \[\leadsto \color{blue}{\left(-2 \cdot \left(J \cdot \cos \left(\frac{K}{2}\right)\right)\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        4. *-commutativeN/A

          \[\leadsto \color{blue}{\left(\left(J \cdot \cos \left(\frac{K}{2}\right)\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        5. lower-*.f64N/A

          \[\leadsto \color{blue}{\left(\left(J \cdot \cos \left(\frac{K}{2}\right)\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        6. lift-/.f64N/A

          \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{K}{2}\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        7. mult-flipN/A

          \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(K \cdot \frac{1}{2}\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        8. metadata-evalN/A

          \[\leadsto \left(\left(J \cdot \cos \left(K \cdot \color{blue}{\frac{1}{2}}\right)\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        9. *-commutativeN/A

          \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{1}{2} \cdot K\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        10. lift-*.f64N/A

          \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{1}{2} \cdot K\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        11. *-commutativeN/A

          \[\leadsto \left(\color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot J\right)} \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        12. lower-*.f6472.7

          \[\leadsto \left(\color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot J\right)} \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]
        13. lift-cos.f64N/A

          \[\leadsto \left(\left(\color{blue}{\cos \left(\frac{1}{2} \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        14. cos-neg-revN/A

          \[\leadsto \left(\left(\color{blue}{\cos \left(\mathsf{neg}\left(\frac{1}{2} \cdot K\right)\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        15. lift-*.f64N/A

          \[\leadsto \left(\left(\cos \left(\mathsf{neg}\left(\color{blue}{\frac{1}{2} \cdot K}\right)\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        16. distribute-lft-neg-inN/A

          \[\leadsto \left(\left(\cos \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{2}\right)\right) \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        17. metadata-evalN/A

          \[\leadsto \left(\left(\cos \left(\color{blue}{\frac{-1}{2}} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        18. lift-*.f64N/A

          \[\leadsto \left(\left(\cos \color{blue}{\left(\frac{-1}{2} \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
        19. lift-cos.f6472.7

          \[\leadsto \left(\left(\color{blue}{\cos \left(-0.5 \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]
      5. Applied rewrites72.7%

        \[\leadsto \color{blue}{\left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]

      if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

      1. Initial program 72.8%

        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
      2. Taylor expanded in U around inf

        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
      3. Step-by-step derivation
        1. lower-*.f64N/A

          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
        2. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
        3. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
        4. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
        5. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
        6. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        7. lower-sqrt.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        8. lower-/.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        9. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        10. lower-pow.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      4. Applied rewrites24.7%

        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
      5. Taylor expanded in J around 0

        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
      6. Step-by-step derivation
        1. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
        2. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        3. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        4. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        5. lower-sqrt.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        6. lower-/.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        7. lower-pow.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        8. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        9. lower-*.f6452.4

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
      7. Applied rewrites52.4%

        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
      8. Step-by-step derivation
        1. lift-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
        2. *-commutativeN/A

          \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
        3. lower-*.f6452.4

          \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
      9. Applied rewrites52.4%

        \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
    10. Recombined 3 regimes into one program.
    11. Add Preprocessing

    Alternative 2: 99.7% accurate, 0.3× speedup?

    \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(-0.5 \cdot K\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -\infty:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(J\_m + J\_m\right) \cdot \cos \left(K \cdot -0.5\right)}\right)}^{2}}\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
    U_m = (fabs.f64 U)
    J\_m = (fabs.f64 J)
    J\_s = (copysign.f64 #s(literal 1 binary64) J)
    (FPCore (J_s J_m K U_m)
     :precision binary64
     (let* ((t_0 (cos (* -0.5 K)))
            (t_1 (cos (/ K 2.0)))
            (t_2
             (*
              (* (* -2.0 J_m) t_1)
              (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
       (*
        J_s
        (if (<= t_2 (- INFINITY))
          (* -2.0 (* U_m 0.5))
          (if (<= t_2 1e+307)
            (*
             (* (* t_0 J_m) -2.0)
             (sqrt (+ 1.0 (pow (/ U_m (* (+ J_m J_m) (cos (* K -0.5)))) 2.0))))
            (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_0)) t_0) U_m)))))))
    U_m = fabs(U);
    J\_m = fabs(J);
    J\_s = copysign(1.0, J);
    double code(double J_s, double J_m, double K, double U_m) {
    	double t_0 = cos((-0.5 * K));
    	double t_1 = cos((K / 2.0));
    	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
    	double tmp;
    	if (t_2 <= -((double) INFINITY)) {
    		tmp = -2.0 * (U_m * 0.5);
    	} else if (t_2 <= 1e+307) {
    		tmp = ((t_0 * J_m) * -2.0) * sqrt((1.0 + pow((U_m / ((J_m + J_m) * cos((K * -0.5)))), 2.0)));
    	} else {
    		tmp = -2.0 * (((sqrt(0.25) / fabs(t_0)) * t_0) * U_m);
    	}
    	return J_s * tmp;
    }
    
    U_m = Math.abs(U);
    J\_m = Math.abs(J);
    J\_s = Math.copySign(1.0, J);
    public static double code(double J_s, double J_m, double K, double U_m) {
    	double t_0 = Math.cos((-0.5 * K));
    	double t_1 = Math.cos((K / 2.0));
    	double t_2 = ((-2.0 * J_m) * t_1) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
    	double tmp;
    	if (t_2 <= -Double.POSITIVE_INFINITY) {
    		tmp = -2.0 * (U_m * 0.5);
    	} else if (t_2 <= 1e+307) {
    		tmp = ((t_0 * J_m) * -2.0) * Math.sqrt((1.0 + Math.pow((U_m / ((J_m + J_m) * Math.cos((K * -0.5)))), 2.0)));
    	} else {
    		tmp = -2.0 * (((Math.sqrt(0.25) / Math.abs(t_0)) * t_0) * U_m);
    	}
    	return J_s * tmp;
    }
    
    U_m = math.fabs(U)
    J\_m = math.fabs(J)
    J\_s = math.copysign(1.0, J)
    def code(J_s, J_m, K, U_m):
    	t_0 = math.cos((-0.5 * K))
    	t_1 = math.cos((K / 2.0))
    	t_2 = ((-2.0 * J_m) * t_1) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)))
    	tmp = 0
    	if t_2 <= -math.inf:
    		tmp = -2.0 * (U_m * 0.5)
    	elif t_2 <= 1e+307:
    		tmp = ((t_0 * J_m) * -2.0) * math.sqrt((1.0 + math.pow((U_m / ((J_m + J_m) * math.cos((K * -0.5)))), 2.0)))
    	else:
    		tmp = -2.0 * (((math.sqrt(0.25) / math.fabs(t_0)) * t_0) * U_m)
    	return J_s * tmp
    
    U_m = abs(U)
    J\_m = abs(J)
    J\_s = copysign(1.0, J)
    function code(J_s, J_m, K, U_m)
    	t_0 = cos(Float64(-0.5 * K))
    	t_1 = cos(Float64(K / 2.0))
    	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
    	tmp = 0.0
    	if (t_2 <= Float64(-Inf))
    		tmp = Float64(-2.0 * Float64(U_m * 0.5));
    	elseif (t_2 <= 1e+307)
    		tmp = Float64(Float64(Float64(t_0 * J_m) * -2.0) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(J_m + J_m) * cos(Float64(K * -0.5)))) ^ 2.0))));
    	else
    		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_0)) * t_0) * U_m));
    	end
    	return Float64(J_s * tmp)
    end
    
    U_m = abs(U);
    J\_m = abs(J);
    J\_s = sign(J) * abs(1.0);
    function tmp_2 = code(J_s, J_m, K, U_m)
    	t_0 = cos((-0.5 * K));
    	t_1 = cos((K / 2.0));
    	t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_1)) ^ 2.0)));
    	tmp = 0.0;
    	if (t_2 <= -Inf)
    		tmp = -2.0 * (U_m * 0.5);
    	elseif (t_2 <= 1e+307)
    		tmp = ((t_0 * J_m) * -2.0) * sqrt((1.0 + ((U_m / ((J_m + J_m) * cos((K * -0.5)))) ^ 2.0)));
    	else
    		tmp = -2.0 * (((sqrt(0.25) / abs(t_0)) * t_0) * U_m);
    	end
    	tmp_2 = J_s * tmp;
    end
    
    U_m = N[Abs[U], $MachinePrecision]
    J\_m = N[Abs[J], $MachinePrecision]
    J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
    code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, (-Infinity)], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[(t$95$0 * J$95$m), $MachinePrecision] * -2.0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(J$95$m + J$95$m), $MachinePrecision] * N[Cos[N[(K * -0.5), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$0], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
    
    \begin{array}{l}
    U_m = \left|U\right|
    \\
    J\_m = \left|J\right|
    \\
    J\_s = \mathsf{copysign}\left(1, J\right)
    
    \\
    \begin{array}{l}
    t_0 := \cos \left(-0.5 \cdot K\right)\\
    t_1 := \cos \left(\frac{K}{2}\right)\\
    t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
    J\_s \cdot \begin{array}{l}
    \mathbf{if}\;t\_2 \leq -\infty:\\
    \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
    
    \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
    \;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(J\_m + J\_m\right) \cdot \cos \left(K \cdot -0.5\right)}\right)}^{2}}\\
    
    \mathbf{else}:\\
    \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\
    
    
    \end{array}
    \end{array}
    \end{array}
    
    Derivation
    1. Split input into 3 regimes
    2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -inf.0

      1. Initial program 72.8%

        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
      2. Taylor expanded in U around inf

        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
      3. Step-by-step derivation
        1. lower-*.f64N/A

          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
        2. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
        3. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
        4. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
        5. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
        6. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        7. lower-sqrt.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        8. lower-/.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        9. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        10. lower-pow.f64N/A

          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
      4. Applied rewrites24.7%

        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
      5. Taylor expanded in J around 0

        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
      6. Step-by-step derivation
        1. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
        2. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        3. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        4. lower-*.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        5. lower-sqrt.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        6. lower-/.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        7. lower-pow.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        8. lower-cos.f64N/A

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
        9. lower-*.f6452.4

          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
      7. Applied rewrites52.4%

        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
      8. Taylor expanded in K around 0

        \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
      9. Step-by-step derivation
        1. Applied rewrites40.0%

          \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

        if -inf.0 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

        1. Initial program 72.8%

          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
        2. Step-by-step derivation
          1. lift-pow.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
          2. metadata-evalN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{\color{blue}{\left(\mathsf{neg}\left(-2\right)\right)}}} \]
          3. pow-negN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
          4. lower-unsound-/.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
          5. lower-unsound-pow.f6472.7

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}}} \]
          6. lift-*.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
          7. count-2-revN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
          8. lower-+.f6472.7

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right)}^{-2}}} \]
          9. lift-cos.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\frac{K}{2}\right)}}\right)}^{-2}}} \]
          10. cos-neg-revN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right)}^{-2}}} \]
          11. lower-cos.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right)}^{-2}}} \]
          12. lift-/.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\frac{K}{2}}\right)\right)}\right)}^{-2}}} \]
          13. distribute-neg-frac2N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{K}{\mathsf{neg}\left(2\right)}\right)}}\right)}^{-2}}} \]
          14. metadata-evalN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{K}{\color{blue}{-2}}\right)}\right)}^{-2}}} \]
          15. mult-flip-revN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot \frac{1}{-2}\right)}}\right)}^{-2}}} \]
          16. *-commutativeN/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right)}^{-2}}} \]
          17. lower-*.f64N/A

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right)}^{-2}}} \]
          18. metadata-eval72.7

            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\color{blue}{-0.5} \cdot K\right)}\right)}^{-2}}} \]
        3. Applied rewrites72.7%

          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}}} \]
        4. Step-by-step derivation
          1. lift-*.f64N/A

            \[\leadsto \color{blue}{\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          2. lift-*.f64N/A

            \[\leadsto \left(\color{blue}{\left(-2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          3. associate-*l*N/A

            \[\leadsto \color{blue}{\left(-2 \cdot \left(J \cdot \cos \left(\frac{K}{2}\right)\right)\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          4. *-commutativeN/A

            \[\leadsto \color{blue}{\left(\left(J \cdot \cos \left(\frac{K}{2}\right)\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          5. lower-*.f64N/A

            \[\leadsto \color{blue}{\left(\left(J \cdot \cos \left(\frac{K}{2}\right)\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          6. lift-/.f64N/A

            \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{K}{2}\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          7. mult-flipN/A

            \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(K \cdot \frac{1}{2}\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          8. metadata-evalN/A

            \[\leadsto \left(\left(J \cdot \cos \left(K \cdot \color{blue}{\frac{1}{2}}\right)\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          9. *-commutativeN/A

            \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{1}{2} \cdot K\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          10. lift-*.f64N/A

            \[\leadsto \left(\left(J \cdot \cos \color{blue}{\left(\frac{1}{2} \cdot K\right)}\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          11. *-commutativeN/A

            \[\leadsto \left(\color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot J\right)} \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          12. lower-*.f6472.7

            \[\leadsto \left(\color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot J\right)} \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]
          13. lift-cos.f64N/A

            \[\leadsto \left(\left(\color{blue}{\cos \left(\frac{1}{2} \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          14. cos-neg-revN/A

            \[\leadsto \left(\left(\color{blue}{\cos \left(\mathsf{neg}\left(\frac{1}{2} \cdot K\right)\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          15. lift-*.f64N/A

            \[\leadsto \left(\left(\cos \left(\mathsf{neg}\left(\color{blue}{\frac{1}{2} \cdot K}\right)\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          16. distribute-lft-neg-inN/A

            \[\leadsto \left(\left(\cos \color{blue}{\left(\left(\mathsf{neg}\left(\frac{1}{2}\right)\right) \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          17. metadata-evalN/A

            \[\leadsto \left(\left(\cos \left(\color{blue}{\frac{-1}{2}} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          18. lift-*.f64N/A

            \[\leadsto \left(\left(\cos \color{blue}{\left(\frac{-1}{2} \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}} \]
          19. lift-cos.f6472.7

            \[\leadsto \left(\left(\color{blue}{\cos \left(-0.5 \cdot K\right)} \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]
        5. Applied rewrites72.7%

          \[\leadsto \color{blue}{\left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right)} \cdot \sqrt{1 + \frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{-2}}} \]
        6. Step-by-step derivation
          1. lift-/.f64N/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \color{blue}{\frac{1}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}}} \]
          2. lift-pow.f64N/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \frac{1}{\color{blue}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{-2}}}} \]
          3. pow-flipN/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \color{blue}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{\left(\mathsf{neg}\left(-2\right)\right)}}} \]
          4. metadata-evalN/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right)}^{\color{blue}{2}}} \]
          5. lower-pow.f6472.8

            \[\leadsto \left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \color{blue}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)}^{2}}} \]
          6. lift-*.f64N/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{-1}{2} \cdot K\right)}}\right)}^{2}} \]
          7. *-commutativeN/A

            \[\leadsto \left(\left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot \frac{-1}{2}\right)}}\right)}^{2}} \]
          8. lower-*.f6472.8

            \[\leadsto \left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot -0.5\right)}}\right)}^{2}} \]
        7. Applied rewrites72.8%

          \[\leadsto \left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{1 + \color{blue}{{\left(\frac{U}{\left(J + J\right) \cdot \cos \left(K \cdot -0.5\right)}\right)}^{2}}} \]

        if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

        1. Initial program 72.8%

          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
        2. Taylor expanded in U around inf

          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
          2. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
          3. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
          4. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
          5. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
          6. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          7. lower-sqrt.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          8. lower-/.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          9. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          10. lower-pow.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        4. Applied rewrites24.7%

          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
        5. Taylor expanded in J around 0

          \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
          2. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          3. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          4. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          5. lower-sqrt.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          6. lower-/.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          7. lower-pow.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          8. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          9. lower-*.f6452.4

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
        7. Applied rewrites52.4%

          \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
        8. Step-by-step derivation
          1. lift-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
          2. *-commutativeN/A

            \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
          3. lower-*.f6452.4

            \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
        9. Applied rewrites52.4%

          \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
      10. Recombined 3 regimes into one program.
      11. Add Preprocessing

      Alternative 3: 99.4% accurate, 0.3× speedup?

      \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ t_1 := \left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}}\\ t_2 := \cos \left(-0.5 \cdot K\right)\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_1 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_1 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot t\_2\right) \cdot \left(J\_m \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_2\right|} \cdot t\_2\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
      U_m = (fabs.f64 U)
      J\_m = (fabs.f64 J)
      J\_s = (copysign.f64 #s(literal 1 binary64) J)
      (FPCore (J_s J_m K U_m)
       :precision binary64
       (let* ((t_0 (cos (/ K 2.0)))
              (t_1
               (*
                (* (* -2.0 J_m) t_0)
                (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_0)) 2.0)))))
              (t_2 (cos (* -0.5 K))))
         (*
          J_s
          (if (<= t_1 -5e+305)
            (* -2.0 (* U_m 0.5))
            (if (<= t_1 1e+307)
              (*
               (*
                (sqrt
                 (-
                  (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 (* 0.5 (cos K))))
                  -1.0))
                t_2)
               (* J_m -2.0))
              (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_2)) t_2) U_m)))))))
      U_m = fabs(U);
      J\_m = fabs(J);
      J\_s = copysign(1.0, J);
      double code(double J_s, double J_m, double K, double U_m) {
      	double t_0 = cos((K / 2.0));
      	double t_1 = ((-2.0 * J_m) * t_0) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_0)), 2.0)));
      	double t_2 = cos((-0.5 * K));
      	double tmp;
      	if (t_1 <= -5e+305) {
      		tmp = -2.0 * (U_m * 0.5);
      	} else if (t_1 <= 1e+307) {
      		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * cos(K)))) - -1.0)) * t_2) * (J_m * -2.0);
      	} else {
      		tmp = -2.0 * (((sqrt(0.25) / fabs(t_2)) * t_2) * U_m);
      	}
      	return J_s * tmp;
      }
      
      U_m =     private
      J\_m =     private
      J\_s =     private
      module fmin_fmax_functions
          implicit none
          private
          public fmax
          public fmin
      
          interface fmax
              module procedure fmax88
              module procedure fmax44
              module procedure fmax84
              module procedure fmax48
          end interface
          interface fmin
              module procedure fmin88
              module procedure fmin44
              module procedure fmin84
              module procedure fmin48
          end interface
      contains
          real(8) function fmax88(x, y) result (res)
              real(8), intent (in) :: x
              real(8), intent (in) :: y
              res = merge(y, merge(x, max(x, y), y /= y), x /= x)
          end function
          real(4) function fmax44(x, y) result (res)
              real(4), intent (in) :: x
              real(4), intent (in) :: y
              res = merge(y, merge(x, max(x, y), y /= y), x /= x)
          end function
          real(8) function fmax84(x, y) result(res)
              real(8), intent (in) :: x
              real(4), intent (in) :: y
              res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
          end function
          real(8) function fmax48(x, y) result(res)
              real(4), intent (in) :: x
              real(8), intent (in) :: y
              res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
          end function
          real(8) function fmin88(x, y) result (res)
              real(8), intent (in) :: x
              real(8), intent (in) :: y
              res = merge(y, merge(x, min(x, y), y /= y), x /= x)
          end function
          real(4) function fmin44(x, y) result (res)
              real(4), intent (in) :: x
              real(4), intent (in) :: y
              res = merge(y, merge(x, min(x, y), y /= y), x /= x)
          end function
          real(8) function fmin84(x, y) result(res)
              real(8), intent (in) :: x
              real(4), intent (in) :: y
              res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
          end function
          real(8) function fmin48(x, y) result(res)
              real(4), intent (in) :: x
              real(8), intent (in) :: y
              res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
          end function
      end module
      
      real(8) function code(j_s, j_m, k, u_m)
      use fmin_fmax_functions
          real(8), intent (in) :: j_s
          real(8), intent (in) :: j_m
          real(8), intent (in) :: k
          real(8), intent (in) :: u_m
          real(8) :: t_0
          real(8) :: t_1
          real(8) :: t_2
          real(8) :: tmp
          t_0 = cos((k / 2.0d0))
          t_1 = (((-2.0d0) * j_m) * t_0) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_0)) ** 2.0d0)))
          t_2 = cos(((-0.5d0) * k))
          if (t_1 <= (-5d+305)) then
              tmp = (-2.0d0) * (u_m * 0.5d0)
          else if (t_1 <= 1d+307) then
              tmp = (sqrt((((((u_m / j_m) * (u_m / j_m)) / 4.0d0) / (0.5d0 + (0.5d0 * cos(k)))) - (-1.0d0))) * t_2) * (j_m * (-2.0d0))
          else
              tmp = (-2.0d0) * (((sqrt(0.25d0) / abs(t_2)) * t_2) * u_m)
          end if
          code = j_s * tmp
      end function
      
      U_m = Math.abs(U);
      J\_m = Math.abs(J);
      J\_s = Math.copySign(1.0, J);
      public static double code(double J_s, double J_m, double K, double U_m) {
      	double t_0 = Math.cos((K / 2.0));
      	double t_1 = ((-2.0 * J_m) * t_0) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)));
      	double t_2 = Math.cos((-0.5 * K));
      	double tmp;
      	if (t_1 <= -5e+305) {
      		tmp = -2.0 * (U_m * 0.5);
      	} else if (t_1 <= 1e+307) {
      		tmp = (Math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * Math.cos(K)))) - -1.0)) * t_2) * (J_m * -2.0);
      	} else {
      		tmp = -2.0 * (((Math.sqrt(0.25) / Math.abs(t_2)) * t_2) * U_m);
      	}
      	return J_s * tmp;
      }
      
      U_m = math.fabs(U)
      J\_m = math.fabs(J)
      J\_s = math.copysign(1.0, J)
      def code(J_s, J_m, K, U_m):
      	t_0 = math.cos((K / 2.0))
      	t_1 = ((-2.0 * J_m) * t_0) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))
      	t_2 = math.cos((-0.5 * K))
      	tmp = 0
      	if t_1 <= -5e+305:
      		tmp = -2.0 * (U_m * 0.5)
      	elif t_1 <= 1e+307:
      		tmp = (math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * math.cos(K)))) - -1.0)) * t_2) * (J_m * -2.0)
      	else:
      		tmp = -2.0 * (((math.sqrt(0.25) / math.fabs(t_2)) * t_2) * U_m)
      	return J_s * tmp
      
      U_m = abs(U)
      J\_m = abs(J)
      J\_s = copysign(1.0, J)
      function code(J_s, J_m, K, U_m)
      	t_0 = cos(Float64(K / 2.0))
      	t_1 = Float64(Float64(Float64(-2.0 * J_m) * t_0) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_0)) ^ 2.0))))
      	t_2 = cos(Float64(-0.5 * K))
      	tmp = 0.0
      	if (t_1 <= -5e+305)
      		tmp = Float64(-2.0 * Float64(U_m * 0.5));
      	elseif (t_1 <= 1e+307)
      		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + Float64(0.5 * cos(K)))) - -1.0)) * t_2) * Float64(J_m * -2.0));
      	else
      		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_2)) * t_2) * U_m));
      	end
      	return Float64(J_s * tmp)
      end
      
      U_m = abs(U);
      J\_m = abs(J);
      J\_s = sign(J) * abs(1.0);
      function tmp_2 = code(J_s, J_m, K, U_m)
      	t_0 = cos((K / 2.0));
      	t_1 = ((-2.0 * J_m) * t_0) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_0)) ^ 2.0)));
      	t_2 = cos((-0.5 * K));
      	tmp = 0.0;
      	if (t_1 <= -5e+305)
      		tmp = -2.0 * (U_m * 0.5);
      	elseif (t_1 <= 1e+307)
      		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * cos(K)))) - -1.0)) * t_2) * (J_m * -2.0);
      	else
      		tmp = -2.0 * (((sqrt(0.25) / abs(t_2)) * t_2) * U_m);
      	end
      	tmp_2 = J_s * tmp;
      end
      
      U_m = N[Abs[U], $MachinePrecision]
      J\_m = N[Abs[J], $MachinePrecision]
      J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
      code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$1, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 1e+307], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + N[(0.5 * N[Cos[K], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * t$95$2), $MachinePrecision] * N[(J$95$m * -2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$2], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
      
      \begin{array}{l}
      U_m = \left|U\right|
      \\
      J\_m = \left|J\right|
      \\
      J\_s = \mathsf{copysign}\left(1, J\right)
      
      \\
      \begin{array}{l}
      t_0 := \cos \left(\frac{K}{2}\right)\\
      t_1 := \left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}}\\
      t_2 := \cos \left(-0.5 \cdot K\right)\\
      J\_s \cdot \begin{array}{l}
      \mathbf{if}\;t\_1 \leq -5 \cdot 10^{+305}:\\
      \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
      
      \mathbf{elif}\;t\_1 \leq 10^{+307}:\\
      \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot t\_2\right) \cdot \left(J\_m \cdot -2\right)\\
      
      \mathbf{else}:\\
      \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_2\right|} \cdot t\_2\right) \cdot U\_m\right)\\
      
      
      \end{array}
      \end{array}
      \end{array}
      
      Derivation
      1. Split input into 3 regimes
      2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

        1. Initial program 72.8%

          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
        2. Taylor expanded in U around inf

          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
        3. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
          2. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
          3. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
          4. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
          5. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
          6. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          7. lower-sqrt.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          8. lower-/.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          9. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          10. lower-pow.f64N/A

            \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
        4. Applied rewrites24.7%

          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
        5. Taylor expanded in J around 0

          \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
        6. Step-by-step derivation
          1. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
          2. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          3. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          4. lower-*.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          5. lower-sqrt.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          6. lower-/.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          7. lower-pow.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          8. lower-cos.f64N/A

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
          9. lower-*.f6452.4

            \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
        7. Applied rewrites52.4%

          \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
        8. Taylor expanded in K around 0

          \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
        9. Step-by-step derivation
          1. Applied rewrites40.0%

            \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

          if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

          1. Initial program 72.8%

            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
          2. Applied rewrites72.6%

            \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot \left(J \cdot -2\right)} \]

          if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

          1. Initial program 72.8%

            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
          2. Taylor expanded in U around inf

            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
            2. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
            3. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
            4. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
            5. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
            6. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            7. lower-sqrt.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            8. lower-/.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            9. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            10. lower-pow.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          4. Applied rewrites24.7%

            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
          5. Taylor expanded in J around 0

            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
            2. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            3. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            4. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            5. lower-sqrt.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            6. lower-/.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            7. lower-pow.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            8. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            9. lower-*.f6452.4

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
          7. Applied rewrites52.4%

            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
          8. Step-by-step derivation
            1. lift-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
            2. *-commutativeN/A

              \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
            3. lower-*.f6452.4

              \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
          9. Applied rewrites52.4%

            \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
        10. Recombined 3 regimes into one program.
        11. Add Preprocessing

        Alternative 4: 99.4% accurate, 0.3× speedup?

        \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ t_1 := \left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}}\\ t_2 := \cos \left(-0.5 \cdot K\right)\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_1 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_1 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\_m\right) \cdot \left(t\_2 \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_2\right|} \cdot t\_2\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
        U_m = (fabs.f64 U)
        J\_m = (fabs.f64 J)
        J\_s = (copysign.f64 #s(literal 1 binary64) J)
        (FPCore (J_s J_m K U_m)
         :precision binary64
         (let* ((t_0 (cos (/ K 2.0)))
                (t_1
                 (*
                  (* (* -2.0 J_m) t_0)
                  (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_0)) 2.0)))))
                (t_2 (cos (* -0.5 K))))
           (*
            J_s
            (if (<= t_1 -5e+305)
              (* -2.0 (* U_m 0.5))
              (if (<= t_1 1e+307)
                (*
                 (*
                  (sqrt
                   (-
                    (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 (* 0.5 (cos K))))
                    -1.0))
                  J_m)
                 (* t_2 -2.0))
                (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_2)) t_2) U_m)))))))
        U_m = fabs(U);
        J\_m = fabs(J);
        J\_s = copysign(1.0, J);
        double code(double J_s, double J_m, double K, double U_m) {
        	double t_0 = cos((K / 2.0));
        	double t_1 = ((-2.0 * J_m) * t_0) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_0)), 2.0)));
        	double t_2 = cos((-0.5 * K));
        	double tmp;
        	if (t_1 <= -5e+305) {
        		tmp = -2.0 * (U_m * 0.5);
        	} else if (t_1 <= 1e+307) {
        		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * cos(K)))) - -1.0)) * J_m) * (t_2 * -2.0);
        	} else {
        		tmp = -2.0 * (((sqrt(0.25) / fabs(t_2)) * t_2) * U_m);
        	}
        	return J_s * tmp;
        }
        
        U_m =     private
        J\_m =     private
        J\_s =     private
        module fmin_fmax_functions
            implicit none
            private
            public fmax
            public fmin
        
            interface fmax
                module procedure fmax88
                module procedure fmax44
                module procedure fmax84
                module procedure fmax48
            end interface
            interface fmin
                module procedure fmin88
                module procedure fmin44
                module procedure fmin84
                module procedure fmin48
            end interface
        contains
            real(8) function fmax88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(4) function fmax44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, max(x, y), y /= y), x /= x)
            end function
            real(8) function fmax84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmax48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
            end function
            real(8) function fmin88(x, y) result (res)
                real(8), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(4) function fmin44(x, y) result (res)
                real(4), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(y, merge(x, min(x, y), y /= y), x /= x)
            end function
            real(8) function fmin84(x, y) result(res)
                real(8), intent (in) :: x
                real(4), intent (in) :: y
                res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
            end function
            real(8) function fmin48(x, y) result(res)
                real(4), intent (in) :: x
                real(8), intent (in) :: y
                res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
            end function
        end module
        
        real(8) function code(j_s, j_m, k, u_m)
        use fmin_fmax_functions
            real(8), intent (in) :: j_s
            real(8), intent (in) :: j_m
            real(8), intent (in) :: k
            real(8), intent (in) :: u_m
            real(8) :: t_0
            real(8) :: t_1
            real(8) :: t_2
            real(8) :: tmp
            t_0 = cos((k / 2.0d0))
            t_1 = (((-2.0d0) * j_m) * t_0) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_0)) ** 2.0d0)))
            t_2 = cos(((-0.5d0) * k))
            if (t_1 <= (-5d+305)) then
                tmp = (-2.0d0) * (u_m * 0.5d0)
            else if (t_1 <= 1d+307) then
                tmp = (sqrt((((((u_m / j_m) * (u_m / j_m)) / 4.0d0) / (0.5d0 + (0.5d0 * cos(k)))) - (-1.0d0))) * j_m) * (t_2 * (-2.0d0))
            else
                tmp = (-2.0d0) * (((sqrt(0.25d0) / abs(t_2)) * t_2) * u_m)
            end if
            code = j_s * tmp
        end function
        
        U_m = Math.abs(U);
        J\_m = Math.abs(J);
        J\_s = Math.copySign(1.0, J);
        public static double code(double J_s, double J_m, double K, double U_m) {
        	double t_0 = Math.cos((K / 2.0));
        	double t_1 = ((-2.0 * J_m) * t_0) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)));
        	double t_2 = Math.cos((-0.5 * K));
        	double tmp;
        	if (t_1 <= -5e+305) {
        		tmp = -2.0 * (U_m * 0.5);
        	} else if (t_1 <= 1e+307) {
        		tmp = (Math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * Math.cos(K)))) - -1.0)) * J_m) * (t_2 * -2.0);
        	} else {
        		tmp = -2.0 * (((Math.sqrt(0.25) / Math.abs(t_2)) * t_2) * U_m);
        	}
        	return J_s * tmp;
        }
        
        U_m = math.fabs(U)
        J\_m = math.fabs(J)
        J\_s = math.copysign(1.0, J)
        def code(J_s, J_m, K, U_m):
        	t_0 = math.cos((K / 2.0))
        	t_1 = ((-2.0 * J_m) * t_0) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))
        	t_2 = math.cos((-0.5 * K))
        	tmp = 0
        	if t_1 <= -5e+305:
        		tmp = -2.0 * (U_m * 0.5)
        	elif t_1 <= 1e+307:
        		tmp = (math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * math.cos(K)))) - -1.0)) * J_m) * (t_2 * -2.0)
        	else:
        		tmp = -2.0 * (((math.sqrt(0.25) / math.fabs(t_2)) * t_2) * U_m)
        	return J_s * tmp
        
        U_m = abs(U)
        J\_m = abs(J)
        J\_s = copysign(1.0, J)
        function code(J_s, J_m, K, U_m)
        	t_0 = cos(Float64(K / 2.0))
        	t_1 = Float64(Float64(Float64(-2.0 * J_m) * t_0) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_0)) ^ 2.0))))
        	t_2 = cos(Float64(-0.5 * K))
        	tmp = 0.0
        	if (t_1 <= -5e+305)
        		tmp = Float64(-2.0 * Float64(U_m * 0.5));
        	elseif (t_1 <= 1e+307)
        		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + Float64(0.5 * cos(K)))) - -1.0)) * J_m) * Float64(t_2 * -2.0));
        	else
        		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_2)) * t_2) * U_m));
        	end
        	return Float64(J_s * tmp)
        end
        
        U_m = abs(U);
        J\_m = abs(J);
        J\_s = sign(J) * abs(1.0);
        function tmp_2 = code(J_s, J_m, K, U_m)
        	t_0 = cos((K / 2.0));
        	t_1 = ((-2.0 * J_m) * t_0) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_0)) ^ 2.0)));
        	t_2 = cos((-0.5 * K));
        	tmp = 0.0;
        	if (t_1 <= -5e+305)
        		tmp = -2.0 * (U_m * 0.5);
        	elseif (t_1 <= 1e+307)
        		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + (0.5 * cos(K)))) - -1.0)) * J_m) * (t_2 * -2.0);
        	else
        		tmp = -2.0 * (((sqrt(0.25) / abs(t_2)) * t_2) * U_m);
        	end
        	tmp_2 = J_s * tmp;
        end
        
        U_m = N[Abs[U], $MachinePrecision]
        J\_m = N[Abs[J], $MachinePrecision]
        J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
        code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$2 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$1, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 1e+307], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + N[(0.5 * N[Cos[K], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(t$95$2 * -2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$2], $MachinePrecision]), $MachinePrecision] * t$95$2), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
        
        \begin{array}{l}
        U_m = \left|U\right|
        \\
        J\_m = \left|J\right|
        \\
        J\_s = \mathsf{copysign}\left(1, J\right)
        
        \\
        \begin{array}{l}
        t_0 := \cos \left(\frac{K}{2}\right)\\
        t_1 := \left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}}\\
        t_2 := \cos \left(-0.5 \cdot K\right)\\
        J\_s \cdot \begin{array}{l}
        \mathbf{if}\;t\_1 \leq -5 \cdot 10^{+305}:\\
        \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
        
        \mathbf{elif}\;t\_1 \leq 10^{+307}:\\
        \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\_m\right) \cdot \left(t\_2 \cdot -2\right)\\
        
        \mathbf{else}:\\
        \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_2\right|} \cdot t\_2\right) \cdot U\_m\right)\\
        
        
        \end{array}
        \end{array}
        \end{array}
        
        Derivation
        1. Split input into 3 regimes
        2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

          1. Initial program 72.8%

            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
          2. Taylor expanded in U around inf

            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
          3. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
            2. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
            3. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
            4. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
            5. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
            6. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            7. lower-sqrt.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            8. lower-/.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            9. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            10. lower-pow.f64N/A

              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
          4. Applied rewrites24.7%

            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
          5. Taylor expanded in J around 0

            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
          6. Step-by-step derivation
            1. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
            2. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            3. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            4. lower-*.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            5. lower-sqrt.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            6. lower-/.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            7. lower-pow.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            8. lower-cos.f64N/A

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
            9. lower-*.f6452.4

              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
          7. Applied rewrites52.4%

            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
          8. Taylor expanded in K around 0

            \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
          9. Step-by-step derivation
            1. Applied rewrites40.0%

              \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

            if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

            1. Initial program 72.8%

              \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
            2. Applied rewrites72.6%

              \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]

            if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

            1. Initial program 72.8%

              \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
            2. Taylor expanded in U around inf

              \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
              2. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
              3. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
              4. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
              5. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
              6. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              7. lower-sqrt.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              8. lower-/.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              9. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              10. lower-pow.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            4. Applied rewrites24.7%

              \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
            5. Taylor expanded in J around 0

              \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
              2. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              3. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              4. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              5. lower-sqrt.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              6. lower-/.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              7. lower-pow.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              8. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              9. lower-*.f6452.4

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
            7. Applied rewrites52.4%

              \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
            8. Step-by-step derivation
              1. lift-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
              2. *-commutativeN/A

                \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
              3. lower-*.f6452.4

                \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
            9. Applied rewrites52.4%

              \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
          10. Recombined 3 regimes into one program.
          11. Add Preprocessing

          Alternative 5: 99.3% accurate, 0.3× speedup?

          \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(-0.5 \cdot K\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\mathsf{fma}\left(\frac{U\_m}{J\_m}, \frac{\frac{U\_m}{J\_m}}{\mathsf{fma}\left(\cos K, 0.5, 0.5\right) \cdot 4}, 1\right)} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
          U_m = (fabs.f64 U)
          J\_m = (fabs.f64 J)
          J\_s = (copysign.f64 #s(literal 1 binary64) J)
          (FPCore (J_s J_m K U_m)
           :precision binary64
           (let* ((t_0 (cos (* -0.5 K)))
                  (t_1 (cos (/ K 2.0)))
                  (t_2
                   (*
                    (* (* -2.0 J_m) t_1)
                    (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
             (*
              J_s
              (if (<= t_2 -5e+305)
                (* -2.0 (* U_m 0.5))
                (if (<= t_2 1e+307)
                  (*
                   (*
                    (sqrt
                     (fma (/ U_m J_m) (/ (/ U_m J_m) (* (fma (cos K) 0.5 0.5) 4.0)) 1.0))
                    J_m)
                   (* t_0 -2.0))
                  (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_0)) t_0) U_m)))))))
          U_m = fabs(U);
          J\_m = fabs(J);
          J\_s = copysign(1.0, J);
          double code(double J_s, double J_m, double K, double U_m) {
          	double t_0 = cos((-0.5 * K));
          	double t_1 = cos((K / 2.0));
          	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
          	double tmp;
          	if (t_2 <= -5e+305) {
          		tmp = -2.0 * (U_m * 0.5);
          	} else if (t_2 <= 1e+307) {
          		tmp = (sqrt(fma((U_m / J_m), ((U_m / J_m) / (fma(cos(K), 0.5, 0.5) * 4.0)), 1.0)) * J_m) * (t_0 * -2.0);
          	} else {
          		tmp = -2.0 * (((sqrt(0.25) / fabs(t_0)) * t_0) * U_m);
          	}
          	return J_s * tmp;
          }
          
          U_m = abs(U)
          J\_m = abs(J)
          J\_s = copysign(1.0, J)
          function code(J_s, J_m, K, U_m)
          	t_0 = cos(Float64(-0.5 * K))
          	t_1 = cos(Float64(K / 2.0))
          	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
          	tmp = 0.0
          	if (t_2 <= -5e+305)
          		tmp = Float64(-2.0 * Float64(U_m * 0.5));
          	elseif (t_2 <= 1e+307)
          		tmp = Float64(Float64(sqrt(fma(Float64(U_m / J_m), Float64(Float64(U_m / J_m) / Float64(fma(cos(K), 0.5, 0.5) * 4.0)), 1.0)) * J_m) * Float64(t_0 * -2.0));
          	else
          		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_0)) * t_0) * U_m));
          	end
          	return Float64(J_s * tmp)
          end
          
          U_m = N[Abs[U], $MachinePrecision]
          J\_m = N[Abs[J], $MachinePrecision]
          J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
          code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[Sqrt[N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(N[(U$95$m / J$95$m), $MachinePrecision] / N[(N[(N[Cos[K], $MachinePrecision] * 0.5 + 0.5), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(t$95$0 * -2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$0], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
          
          \begin{array}{l}
          U_m = \left|U\right|
          \\
          J\_m = \left|J\right|
          \\
          J\_s = \mathsf{copysign}\left(1, J\right)
          
          \\
          \begin{array}{l}
          t_0 := \cos \left(-0.5 \cdot K\right)\\
          t_1 := \cos \left(\frac{K}{2}\right)\\
          t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
          J\_s \cdot \begin{array}{l}
          \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
          \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
          
          \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
          \;\;\;\;\left(\sqrt{\mathsf{fma}\left(\frac{U\_m}{J\_m}, \frac{\frac{U\_m}{J\_m}}{\mathsf{fma}\left(\cos K, 0.5, 0.5\right) \cdot 4}, 1\right)} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\
          
          \mathbf{else}:\\
          \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\
          
          
          \end{array}
          \end{array}
          \end{array}
          
          Derivation
          1. Split input into 3 regimes
          2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

            1. Initial program 72.8%

              \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
            2. Taylor expanded in U around inf

              \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
            3. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
              2. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
              3. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
              4. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
              5. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
              6. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              7. lower-sqrt.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              8. lower-/.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              9. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              10. lower-pow.f64N/A

                \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
            4. Applied rewrites24.7%

              \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
            5. Taylor expanded in J around 0

              \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
            6. Step-by-step derivation
              1. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
              2. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              3. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              4. lower-*.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              5. lower-sqrt.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              6. lower-/.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              7. lower-pow.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              8. lower-cos.f64N/A

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
              9. lower-*.f6452.4

                \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
            7. Applied rewrites52.4%

              \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
            8. Taylor expanded in K around 0

              \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
            9. Step-by-step derivation
              1. Applied rewrites40.0%

                \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

              if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

              1. Initial program 72.8%

                \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
              2. Applied rewrites72.6%

                \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
              3. Step-by-step derivation
                1. lift--.f64N/A

                  \[\leadsto \left(\sqrt{\color{blue}{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \frac{1}{2} \cdot \cos K} - -1}} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                2. sub-flipN/A

                  \[\leadsto \left(\sqrt{\color{blue}{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \frac{1}{2} \cdot \cos K} + \left(\mathsf{neg}\left(-1\right)\right)}} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                3. lift-/.f64N/A

                  \[\leadsto \left(\sqrt{\color{blue}{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \frac{1}{2} \cdot \cos K}} + \left(\mathsf{neg}\left(-1\right)\right)} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                4. lift-/.f64N/A

                  \[\leadsto \left(\sqrt{\frac{\color{blue}{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}}{\frac{1}{2} + \frac{1}{2} \cdot \cos K} + \left(\mathsf{neg}\left(-1\right)\right)} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                5. associate-/l/N/A

                  \[\leadsto \left(\sqrt{\color{blue}{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4 \cdot \left(\frac{1}{2} + \frac{1}{2} \cdot \cos K\right)}} + \left(\mathsf{neg}\left(-1\right)\right)} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                6. lift-*.f64N/A

                  \[\leadsto \left(\sqrt{\frac{\color{blue}{\frac{U}{J} \cdot \frac{U}{J}}}{4 \cdot \left(\frac{1}{2} + \frac{1}{2} \cdot \cos K\right)} + \left(\mathsf{neg}\left(-1\right)\right)} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                7. associate-/l*N/A

                  \[\leadsto \left(\sqrt{\color{blue}{\frac{U}{J} \cdot \frac{\frac{U}{J}}{4 \cdot \left(\frac{1}{2} + \frac{1}{2} \cdot \cos K\right)}} + \left(\mathsf{neg}\left(-1\right)\right)} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                8. metadata-evalN/A

                  \[\leadsto \left(\sqrt{\frac{U}{J} \cdot \frac{\frac{U}{J}}{4 \cdot \left(\frac{1}{2} + \frac{1}{2} \cdot \cos K\right)} + \color{blue}{1}} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                9. lower-fma.f64N/A

                  \[\leadsto \left(\sqrt{\color{blue}{\mathsf{fma}\left(\frac{U}{J}, \frac{\frac{U}{J}}{4 \cdot \left(\frac{1}{2} + \frac{1}{2} \cdot \cos K\right)}, 1\right)}} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
              4. Applied rewrites72.6%

                \[\leadsto \left(\sqrt{\color{blue}{\mathsf{fma}\left(\frac{U}{J}, \frac{\frac{U}{J}}{\mathsf{fma}\left(\cos K, 0.5, 0.5\right) \cdot 4}, 1\right)}} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]

              if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

              1. Initial program 72.8%

                \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
              2. Taylor expanded in U around inf

                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
              3. Step-by-step derivation
                1. lower-*.f64N/A

                  \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                2. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                3. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                4. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                5. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                6. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                7. lower-sqrt.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                8. lower-/.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                9. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                10. lower-pow.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              4. Applied rewrites24.7%

                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
              5. Taylor expanded in J around 0

                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
              6. Step-by-step derivation
                1. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                2. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                3. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                4. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                5. lower-sqrt.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                6. lower-/.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                7. lower-pow.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                8. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                9. lower-*.f6452.4

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
              7. Applied rewrites52.4%

                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
              8. Step-by-step derivation
                1. lift-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                2. *-commutativeN/A

                  \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
                3. lower-*.f6452.4

                  \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
              9. Applied rewrites52.4%

                \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
            10. Recombined 3 regimes into one program.
            11. Add Preprocessing

            Alternative 6: 92.8% accurate, 0.3× speedup?

            \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(-0.5 \cdot K\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 2 \cdot 10^{-77}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{\mathsf{fma}\left(U\_m \cdot \frac{U\_m}{J\_m \cdot J\_m}, \frac{-0.25}{\mathsf{fma}\left(\cos K, -0.5, -0.5\right)}, 1\right)}\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
            U_m = (fabs.f64 U)
            J\_m = (fabs.f64 J)
            J\_s = (copysign.f64 #s(literal 1 binary64) J)
            (FPCore (J_s J_m K U_m)
             :precision binary64
             (let* ((t_0 (cos (* -0.5 K)))
                    (t_1 (cos (/ K 2.0)))
                    (t_2
                     (*
                      (* (* -2.0 J_m) t_1)
                      (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
               (*
                J_s
                (if (<= t_2 -5e+305)
                  (* -2.0 (* U_m 0.5))
                  (if (<= t_2 2e-77)
                    (*
                     (*
                      (sqrt (- (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 0.5)) -1.0))
                      J_m)
                     (* t_0 -2.0))
                    (if (<= t_2 1e+307)
                      (*
                       (* (* t_0 J_m) -2.0)
                       (sqrt
                        (fma
                         (* U_m (/ U_m (* J_m J_m)))
                         (/ -0.25 (fma (cos K) -0.5 -0.5))
                         1.0)))
                      (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_0)) t_0) U_m))))))))
            U_m = fabs(U);
            J\_m = fabs(J);
            J\_s = copysign(1.0, J);
            double code(double J_s, double J_m, double K, double U_m) {
            	double t_0 = cos((-0.5 * K));
            	double t_1 = cos((K / 2.0));
            	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
            	double tmp;
            	if (t_2 <= -5e+305) {
            		tmp = -2.0 * (U_m * 0.5);
            	} else if (t_2 <= 2e-77) {
            		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (t_0 * -2.0);
            	} else if (t_2 <= 1e+307) {
            		tmp = ((t_0 * J_m) * -2.0) * sqrt(fma((U_m * (U_m / (J_m * J_m))), (-0.25 / fma(cos(K), -0.5, -0.5)), 1.0));
            	} else {
            		tmp = -2.0 * (((sqrt(0.25) / fabs(t_0)) * t_0) * U_m);
            	}
            	return J_s * tmp;
            }
            
            U_m = abs(U)
            J\_m = abs(J)
            J\_s = copysign(1.0, J)
            function code(J_s, J_m, K, U_m)
            	t_0 = cos(Float64(-0.5 * K))
            	t_1 = cos(Float64(K / 2.0))
            	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
            	tmp = 0.0
            	if (t_2 <= -5e+305)
            		tmp = Float64(-2.0 * Float64(U_m * 0.5));
            	elseif (t_2 <= 2e-77)
            		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + 0.5)) - -1.0)) * J_m) * Float64(t_0 * -2.0));
            	elseif (t_2 <= 1e+307)
            		tmp = Float64(Float64(Float64(t_0 * J_m) * -2.0) * sqrt(fma(Float64(U_m * Float64(U_m / Float64(J_m * J_m))), Float64(-0.25 / fma(cos(K), -0.5, -0.5)), 1.0)));
            	else
            		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_0)) * t_0) * U_m));
            	end
            	return Float64(J_s * tmp)
            end
            
            U_m = N[Abs[U], $MachinePrecision]
            J\_m = N[Abs[J], $MachinePrecision]
            J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
            code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 2e-77], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + 0.5), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(t$95$0 * -2.0), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[(t$95$0 * J$95$m), $MachinePrecision] * -2.0), $MachinePrecision] * N[Sqrt[N[(N[(U$95$m * N[(U$95$m / N[(J$95$m * J$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * N[(-0.25 / N[(N[Cos[K], $MachinePrecision] * -0.5 + -0.5), $MachinePrecision]), $MachinePrecision] + 1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$0], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]]), $MachinePrecision]]]]
            
            \begin{array}{l}
            U_m = \left|U\right|
            \\
            J\_m = \left|J\right|
            \\
            J\_s = \mathsf{copysign}\left(1, J\right)
            
            \\
            \begin{array}{l}
            t_0 := \cos \left(-0.5 \cdot K\right)\\
            t_1 := \cos \left(\frac{K}{2}\right)\\
            t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
            J\_s \cdot \begin{array}{l}
            \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
            \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
            
            \mathbf{elif}\;t\_2 \leq 2 \cdot 10^{-77}:\\
            \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\
            
            \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
            \;\;\;\;\left(\left(t\_0 \cdot J\_m\right) \cdot -2\right) \cdot \sqrt{\mathsf{fma}\left(U\_m \cdot \frac{U\_m}{J\_m \cdot J\_m}, \frac{-0.25}{\mathsf{fma}\left(\cos K, -0.5, -0.5\right)}, 1\right)}\\
            
            \mathbf{else}:\\
            \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\
            
            
            \end{array}
            \end{array}
            \end{array}
            
            Derivation
            1. Split input into 4 regimes
            2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

              1. Initial program 72.8%

                \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
              2. Taylor expanded in U around inf

                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
              3. Step-by-step derivation
                1. lower-*.f64N/A

                  \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                2. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                3. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                4. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                5. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                6. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                7. lower-sqrt.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                8. lower-/.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                9. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                10. lower-pow.f64N/A

                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
              4. Applied rewrites24.7%

                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
              5. Taylor expanded in J around 0

                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
              6. Step-by-step derivation
                1. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                2. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                3. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                4. lower-*.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                5. lower-sqrt.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                6. lower-/.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                7. lower-pow.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                8. lower-cos.f64N/A

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                9. lower-*.f6452.4

                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
              7. Applied rewrites52.4%

                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
              8. Taylor expanded in K around 0

                \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
              9. Step-by-step derivation
                1. Applied rewrites40.0%

                  \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 1.9999999999999999e-77

                1. Initial program 72.8%

                  \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                2. Applied rewrites72.6%

                  \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                3. Taylor expanded in K around 0

                  \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \color{blue}{\frac{1}{2}}} - -1} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                4. Step-by-step derivation
                  1. Applied rewrites64.0%

                    \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + \color{blue}{0.5}} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]

                  if 1.9999999999999999e-77 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

                  1. Initial program 72.8%

                    \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                  2. Applied rewrites72.6%

                    \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                  3. Applied rewrites60.7%

                    \[\leadsto \color{blue}{\left(\left(\cos \left(-0.5 \cdot K\right) \cdot J\right) \cdot -2\right) \cdot \sqrt{\mathsf{fma}\left(U \cdot \frac{U}{J \cdot J}, \frac{-0.25}{\mathsf{fma}\left(\cos K, -0.5, -0.5\right)}, 1\right)}} \]

                  if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                  1. Initial program 72.8%

                    \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                  2. Taylor expanded in U around inf

                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                  3. Step-by-step derivation
                    1. lower-*.f64N/A

                      \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                    2. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                    3. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                    4. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                    5. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                    6. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    7. lower-sqrt.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    8. lower-/.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    9. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    10. lower-pow.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                  4. Applied rewrites24.7%

                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                  5. Taylor expanded in J around 0

                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                  6. Step-by-step derivation
                    1. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                    2. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    3. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    4. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    5. lower-sqrt.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    6. lower-/.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    7. lower-pow.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    8. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    9. lower-*.f6452.4

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                  7. Applied rewrites52.4%

                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                  8. Step-by-step derivation
                    1. lift-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                    2. *-commutativeN/A

                      \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
                    3. lower-*.f6452.4

                      \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
                  9. Applied rewrites52.4%

                    \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
                5. Recombined 4 regimes into one program.
                6. Add Preprocessing

                Alternative 7: 90.8% accurate, 0.4× speedup?

                \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(-0.5 \cdot K\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\ \end{array} \end{array} \end{array} \]
                U_m = (fabs.f64 U)
                J\_m = (fabs.f64 J)
                J\_s = (copysign.f64 #s(literal 1 binary64) J)
                (FPCore (J_s J_m K U_m)
                 :precision binary64
                 (let* ((t_0 (cos (* -0.5 K)))
                        (t_1 (cos (/ K 2.0)))
                        (t_2
                         (*
                          (* (* -2.0 J_m) t_1)
                          (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
                   (*
                    J_s
                    (if (<= t_2 -5e+305)
                      (* -2.0 (* U_m 0.5))
                      (if (<= t_2 1e+307)
                        (*
                         (*
                          (sqrt (- (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 0.5)) -1.0))
                          J_m)
                         (* t_0 -2.0))
                        (* -2.0 (* (* (/ (sqrt 0.25) (fabs t_0)) t_0) U_m)))))))
                U_m = fabs(U);
                J\_m = fabs(J);
                J\_s = copysign(1.0, J);
                double code(double J_s, double J_m, double K, double U_m) {
                	double t_0 = cos((-0.5 * K));
                	double t_1 = cos((K / 2.0));
                	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                	double tmp;
                	if (t_2 <= -5e+305) {
                		tmp = -2.0 * (U_m * 0.5);
                	} else if (t_2 <= 1e+307) {
                		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (t_0 * -2.0);
                	} else {
                		tmp = -2.0 * (((sqrt(0.25) / fabs(t_0)) * t_0) * U_m);
                	}
                	return J_s * tmp;
                }
                
                U_m =     private
                J\_m =     private
                J\_s =     private
                module fmin_fmax_functions
                    implicit none
                    private
                    public fmax
                    public fmin
                
                    interface fmax
                        module procedure fmax88
                        module procedure fmax44
                        module procedure fmax84
                        module procedure fmax48
                    end interface
                    interface fmin
                        module procedure fmin88
                        module procedure fmin44
                        module procedure fmin84
                        module procedure fmin48
                    end interface
                contains
                    real(8) function fmax88(x, y) result (res)
                        real(8), intent (in) :: x
                        real(8), intent (in) :: y
                        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                    end function
                    real(4) function fmax44(x, y) result (res)
                        real(4), intent (in) :: x
                        real(4), intent (in) :: y
                        res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                    end function
                    real(8) function fmax84(x, y) result(res)
                        real(8), intent (in) :: x
                        real(4), intent (in) :: y
                        res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
                    end function
                    real(8) function fmax48(x, y) result(res)
                        real(4), intent (in) :: x
                        real(8), intent (in) :: y
                        res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
                    end function
                    real(8) function fmin88(x, y) result (res)
                        real(8), intent (in) :: x
                        real(8), intent (in) :: y
                        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                    end function
                    real(4) function fmin44(x, y) result (res)
                        real(4), intent (in) :: x
                        real(4), intent (in) :: y
                        res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                    end function
                    real(8) function fmin84(x, y) result(res)
                        real(8), intent (in) :: x
                        real(4), intent (in) :: y
                        res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
                    end function
                    real(8) function fmin48(x, y) result(res)
                        real(4), intent (in) :: x
                        real(8), intent (in) :: y
                        res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
                    end function
                end module
                
                real(8) function code(j_s, j_m, k, u_m)
                use fmin_fmax_functions
                    real(8), intent (in) :: j_s
                    real(8), intent (in) :: j_m
                    real(8), intent (in) :: k
                    real(8), intent (in) :: u_m
                    real(8) :: t_0
                    real(8) :: t_1
                    real(8) :: t_2
                    real(8) :: tmp
                    t_0 = cos(((-0.5d0) * k))
                    t_1 = cos((k / 2.0d0))
                    t_2 = (((-2.0d0) * j_m) * t_1) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_1)) ** 2.0d0)))
                    if (t_2 <= (-5d+305)) then
                        tmp = (-2.0d0) * (u_m * 0.5d0)
                    else if (t_2 <= 1d+307) then
                        tmp = (sqrt((((((u_m / j_m) * (u_m / j_m)) / 4.0d0) / (0.5d0 + 0.5d0)) - (-1.0d0))) * j_m) * (t_0 * (-2.0d0))
                    else
                        tmp = (-2.0d0) * (((sqrt(0.25d0) / abs(t_0)) * t_0) * u_m)
                    end if
                    code = j_s * tmp
                end function
                
                U_m = Math.abs(U);
                J\_m = Math.abs(J);
                J\_s = Math.copySign(1.0, J);
                public static double code(double J_s, double J_m, double K, double U_m) {
                	double t_0 = Math.cos((-0.5 * K));
                	double t_1 = Math.cos((K / 2.0));
                	double t_2 = ((-2.0 * J_m) * t_1) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                	double tmp;
                	if (t_2 <= -5e+305) {
                		tmp = -2.0 * (U_m * 0.5);
                	} else if (t_2 <= 1e+307) {
                		tmp = (Math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (t_0 * -2.0);
                	} else {
                		tmp = -2.0 * (((Math.sqrt(0.25) / Math.abs(t_0)) * t_0) * U_m);
                	}
                	return J_s * tmp;
                }
                
                U_m = math.fabs(U)
                J\_m = math.fabs(J)
                J\_s = math.copysign(1.0, J)
                def code(J_s, J_m, K, U_m):
                	t_0 = math.cos((-0.5 * K))
                	t_1 = math.cos((K / 2.0))
                	t_2 = ((-2.0 * J_m) * t_1) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)))
                	tmp = 0
                	if t_2 <= -5e+305:
                		tmp = -2.0 * (U_m * 0.5)
                	elif t_2 <= 1e+307:
                		tmp = (math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (t_0 * -2.0)
                	else:
                		tmp = -2.0 * (((math.sqrt(0.25) / math.fabs(t_0)) * t_0) * U_m)
                	return J_s * tmp
                
                U_m = abs(U)
                J\_m = abs(J)
                J\_s = copysign(1.0, J)
                function code(J_s, J_m, K, U_m)
                	t_0 = cos(Float64(-0.5 * K))
                	t_1 = cos(Float64(K / 2.0))
                	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
                	tmp = 0.0
                	if (t_2 <= -5e+305)
                		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                	elseif (t_2 <= 1e+307)
                		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + 0.5)) - -1.0)) * J_m) * Float64(t_0 * -2.0));
                	else
                		tmp = Float64(-2.0 * Float64(Float64(Float64(sqrt(0.25) / abs(t_0)) * t_0) * U_m));
                	end
                	return Float64(J_s * tmp)
                end
                
                U_m = abs(U);
                J\_m = abs(J);
                J\_s = sign(J) * abs(1.0);
                function tmp_2 = code(J_s, J_m, K, U_m)
                	t_0 = cos((-0.5 * K));
                	t_1 = cos((K / 2.0));
                	t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_1)) ^ 2.0)));
                	tmp = 0.0;
                	if (t_2 <= -5e+305)
                		tmp = -2.0 * (U_m * 0.5);
                	elseif (t_2 <= 1e+307)
                		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (t_0 * -2.0);
                	else
                		tmp = -2.0 * (((sqrt(0.25) / abs(t_0)) * t_0) * U_m);
                	end
                	tmp_2 = J_s * tmp;
                end
                
                U_m = N[Abs[U], $MachinePrecision]
                J\_m = N[Abs[J], $MachinePrecision]
                J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + 0.5), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(t$95$0 * -2.0), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(N[(N[(N[Sqrt[0.25], $MachinePrecision] / N[Abs[t$95$0], $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * U$95$m), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
                
                \begin{array}{l}
                U_m = \left|U\right|
                \\
                J\_m = \left|J\right|
                \\
                J\_s = \mathsf{copysign}\left(1, J\right)
                
                \\
                \begin{array}{l}
                t_0 := \cos \left(-0.5 \cdot K\right)\\
                t_1 := \cos \left(\frac{K}{2}\right)\\
                t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
                J\_s \cdot \begin{array}{l}
                \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
                \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                
                \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
                \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(t\_0 \cdot -2\right)\\
                
                \mathbf{else}:\\
                \;\;\;\;-2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|t\_0\right|} \cdot t\_0\right) \cdot U\_m\right)\\
                
                
                \end{array}
                \end{array}
                \end{array}
                
                Derivation
                1. Split input into 3 regimes
                2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                  1. Initial program 72.8%

                    \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                  2. Taylor expanded in U around inf

                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                  3. Step-by-step derivation
                    1. lower-*.f64N/A

                      \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                    2. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                    3. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                    4. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                    5. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                    6. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    7. lower-sqrt.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    8. lower-/.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    9. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                    10. lower-pow.f64N/A

                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                  4. Applied rewrites24.7%

                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                  5. Taylor expanded in J around 0

                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                  6. Step-by-step derivation
                    1. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                    2. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    3. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    4. lower-*.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    5. lower-sqrt.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    6. lower-/.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    7. lower-pow.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    8. lower-cos.f64N/A

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                    9. lower-*.f6452.4

                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                  7. Applied rewrites52.4%

                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                  8. Taylor expanded in K around 0

                    \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                  9. Step-by-step derivation
                    1. Applied rewrites40.0%

                      \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                    if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

                    1. Initial program 72.8%

                      \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                    2. Applied rewrites72.6%

                      \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                    3. Taylor expanded in K around 0

                      \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \color{blue}{\frac{1}{2}}} - -1} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                    4. Step-by-step derivation
                      1. Applied rewrites64.0%

                        \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + \color{blue}{0.5}} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]

                      if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                      1. Initial program 72.8%

                        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                      2. Taylor expanded in U around inf

                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                      3. Step-by-step derivation
                        1. lower-*.f64N/A

                          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                        2. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                        3. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                        4. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                        5. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                        6. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        7. lower-sqrt.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        8. lower-/.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        9. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        10. lower-pow.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                      4. Applied rewrites24.7%

                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                      5. Taylor expanded in J around 0

                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                      6. Step-by-step derivation
                        1. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                        2. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        3. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        4. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        5. lower-sqrt.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        6. lower-/.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        7. lower-pow.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        8. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        9. lower-*.f6452.4

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                      7. Applied rewrites52.4%

                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                      8. Step-by-step derivation
                        1. lift-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                        2. *-commutativeN/A

                          \[\leadsto -2 \cdot \left(\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right) \cdot U\right) \]
                        3. lower-*.f6452.4

                          \[\leadsto -2 \cdot \left(\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right) \cdot U\right) \]
                      9. Applied rewrites52.4%

                        \[\leadsto -2 \cdot \left(\left(\frac{\sqrt{0.25}}{\left|\cos \left(-0.5 \cdot K\right)\right|} \cdot \cos \left(-0.5 \cdot K\right)\right) \cdot U\right) \]
                    5. Recombined 3 regimes into one program.
                    6. Add Preprocessing

                    Alternative 8: 86.2% accurate, 0.4× speedup?

                    \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := J\_m \cdot {K}^{2}\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(-2, J\_m, 0.25 \cdot t\_0\right) \cdot \cosh \sinh^{-1} \left(\frac{U\_m}{\mathsf{fma}\left(-0.25, t\_0, 2 \cdot J\_m\right)}\right)\\ \end{array} \end{array} \end{array} \]
                    U_m = (fabs.f64 U)
                    J\_m = (fabs.f64 J)
                    J\_s = (copysign.f64 #s(literal 1 binary64) J)
                    (FPCore (J_s J_m K U_m)
                     :precision binary64
                     (let* ((t_0 (* J_m (pow K 2.0)))
                            (t_1 (cos (/ K 2.0)))
                            (t_2
                             (*
                              (* (* -2.0 J_m) t_1)
                              (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
                       (*
                        J_s
                        (if (<= t_2 -5e+305)
                          (* -2.0 (* U_m 0.5))
                          (if (<= t_2 1e+307)
                            (*
                             (*
                              (sqrt (- (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 0.5)) -1.0))
                              J_m)
                             (* (cos (* -0.5 K)) -2.0))
                            (*
                             (fma -2.0 J_m (* 0.25 t_0))
                             (cosh (asinh (/ U_m (fma -0.25 t_0 (* 2.0 J_m)))))))))))
                    U_m = fabs(U);
                    J\_m = fabs(J);
                    J\_s = copysign(1.0, J);
                    double code(double J_s, double J_m, double K, double U_m) {
                    	double t_0 = J_m * pow(K, 2.0);
                    	double t_1 = cos((K / 2.0));
                    	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                    	double tmp;
                    	if (t_2 <= -5e+305) {
                    		tmp = -2.0 * (U_m * 0.5);
                    	} else if (t_2 <= 1e+307) {
                    		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (cos((-0.5 * K)) * -2.0);
                    	} else {
                    		tmp = fma(-2.0, J_m, (0.25 * t_0)) * cosh(asinh((U_m / fma(-0.25, t_0, (2.0 * J_m)))));
                    	}
                    	return J_s * tmp;
                    }
                    
                    U_m = abs(U)
                    J\_m = abs(J)
                    J\_s = copysign(1.0, J)
                    function code(J_s, J_m, K, U_m)
                    	t_0 = Float64(J_m * (K ^ 2.0))
                    	t_1 = cos(Float64(K / 2.0))
                    	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
                    	tmp = 0.0
                    	if (t_2 <= -5e+305)
                    		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                    	elseif (t_2 <= 1e+307)
                    		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + 0.5)) - -1.0)) * J_m) * Float64(cos(Float64(-0.5 * K)) * -2.0));
                    	else
                    		tmp = Float64(fma(-2.0, J_m, Float64(0.25 * t_0)) * cosh(asinh(Float64(U_m / fma(-0.25, t_0, Float64(2.0 * J_m))))));
                    	end
                    	return Float64(J_s * tmp)
                    end
                    
                    U_m = N[Abs[U], $MachinePrecision]
                    J\_m = N[Abs[J], $MachinePrecision]
                    J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                    code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[(J$95$m * N[Power[K, 2.0], $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + 0.5), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision] * -2.0), $MachinePrecision]), $MachinePrecision], N[(N[(-2.0 * J$95$m + N[(0.25 * t$95$0), $MachinePrecision]), $MachinePrecision] * N[Cosh[N[ArcSinh[N[(U$95$m / N[(-0.25 * t$95$0 + N[(2.0 * J$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
                    
                    \begin{array}{l}
                    U_m = \left|U\right|
                    \\
                    J\_m = \left|J\right|
                    \\
                    J\_s = \mathsf{copysign}\left(1, J\right)
                    
                    \\
                    \begin{array}{l}
                    t_0 := J\_m \cdot {K}^{2}\\
                    t_1 := \cos \left(\frac{K}{2}\right)\\
                    t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
                    J\_s \cdot \begin{array}{l}
                    \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
                    \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                    
                    \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
                    \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\
                    
                    \mathbf{else}:\\
                    \;\;\;\;\mathsf{fma}\left(-2, J\_m, 0.25 \cdot t\_0\right) \cdot \cosh \sinh^{-1} \left(\frac{U\_m}{\mathsf{fma}\left(-0.25, t\_0, 2 \cdot J\_m\right)}\right)\\
                    
                    
                    \end{array}
                    \end{array}
                    \end{array}
                    
                    Derivation
                    1. Split input into 3 regimes
                    2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                      1. Initial program 72.8%

                        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                      2. Taylor expanded in U around inf

                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                      3. Step-by-step derivation
                        1. lower-*.f64N/A

                          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                        2. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                        3. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                        4. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                        5. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                        6. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        7. lower-sqrt.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        8. lower-/.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        9. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                        10. lower-pow.f64N/A

                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                      4. Applied rewrites24.7%

                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                      5. Taylor expanded in J around 0

                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                      6. Step-by-step derivation
                        1. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                        2. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        3. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        4. lower-*.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        5. lower-sqrt.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        6. lower-/.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        7. lower-pow.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        8. lower-cos.f64N/A

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                        9. lower-*.f6452.4

                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                      7. Applied rewrites52.4%

                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                      8. Taylor expanded in K around 0

                        \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                      9. Step-by-step derivation
                        1. Applied rewrites40.0%

                          \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                        if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

                        1. Initial program 72.8%

                          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                        2. Applied rewrites72.6%

                          \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                        3. Taylor expanded in K around 0

                          \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \color{blue}{\frac{1}{2}}} - -1} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                        4. Step-by-step derivation
                          1. Applied rewrites64.0%

                            \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + \color{blue}{0.5}} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]

                          if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                          1. Initial program 72.8%

                            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                          2. Step-by-step derivation
                            1. lift-sqrt.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
                            2. lift-+.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
                            3. +-commutativeN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2} + 1}} \]
                            4. lift-pow.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} + 1} \]
                            5. unpow2N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} + 1} \]
                            6. cosh-asinh-revN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                            7. lower-cosh.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                            8. lower-asinh.f6484.5

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \color{blue}{\sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                            9. lift-*.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                            10. count-2-revN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                            11. lower-+.f6484.5

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                            12. lift-cos.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\frac{K}{2}\right)}}\right) \]
                            13. cos-neg-revN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right) \]
                            14. lower-cos.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right) \]
                            15. lift-/.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\frac{K}{2}}\right)\right)}\right) \]
                            16. distribute-neg-frac2N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{K}{\mathsf{neg}\left(2\right)}\right)}}\right) \]
                            17. metadata-evalN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{K}{\color{blue}{-2}}\right)}\right) \]
                            18. mult-flip-revN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot \frac{1}{-2}\right)}}\right) \]
                            19. *-commutativeN/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right) \]
                            20. lower-*.f64N/A

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right) \]
                            21. metadata-eval84.5

                              \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\color{blue}{-0.5} \cdot K\right)}\right) \]
                          3. Applied rewrites84.5%

                            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)} \]
                          4. Taylor expanded in K around 0

                            \[\leadsto \color{blue}{\left(-2 \cdot J + \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                          5. Step-by-step derivation
                            1. lower-fma.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, \color{blue}{J}, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                            2. lower-*.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                            3. lower-*.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                            4. lower-pow.f6443.7

                              \[\leadsto \mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                          6. Applied rewrites43.7%

                            \[\leadsto \color{blue}{\mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                          7. Taylor expanded in K around 0

                            \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\frac{-1}{4} \cdot \left(J \cdot {K}^{2}\right) + 2 \cdot J}}\right) \]
                          8. Step-by-step derivation
                            1. lower-fma.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, \color{blue}{J \cdot {K}^{2}}, 2 \cdot J\right)}\right) \]
                            2. lower-*.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, J \cdot \color{blue}{{K}^{2}}, 2 \cdot J\right)}\right) \]
                            3. lower-pow.f64N/A

                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, J \cdot {K}^{\color{blue}{2}}, 2 \cdot J\right)}\right) \]
                            4. lower-*.f6446.3

                              \[\leadsto \mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(-0.25, J \cdot {K}^{2}, 2 \cdot J\right)}\right) \]
                          9. Applied rewrites46.3%

                            \[\leadsto \mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\mathsf{fma}\left(-0.25, J \cdot {K}^{2}, 2 \cdot J\right)}}\right) \]
                        5. Recombined 3 regimes into one program.
                        6. Add Preprocessing

                        Alternative 9: 86.2% accurate, 0.4× speedup?

                        \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \left(\left(K \cdot K\right) \cdot J\_m\right) \cdot 0.25\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq 10^{+307}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\ \mathbf{else}:\\ \;\;\;\;\left(\left(1 + \frac{J\_m \cdot -2}{t\_0}\right) \cdot t\_0\right) \cdot \cosh \sinh^{-1} \left(\frac{U\_m}{\mathsf{fma}\left(-0.25, J\_m \cdot {K}^{2}, 2 \cdot J\_m\right)}\right)\\ \end{array} \end{array} \end{array} \]
                        U_m = (fabs.f64 U)
                        J\_m = (fabs.f64 J)
                        J\_s = (copysign.f64 #s(literal 1 binary64) J)
                        (FPCore (J_s J_m K U_m)
                         :precision binary64
                         (let* ((t_0 (* (* (* K K) J_m) 0.25))
                                (t_1 (cos (/ K 2.0)))
                                (t_2
                                 (*
                                  (* (* -2.0 J_m) t_1)
                                  (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
                           (*
                            J_s
                            (if (<= t_2 -5e+305)
                              (* -2.0 (* U_m 0.5))
                              (if (<= t_2 1e+307)
                                (*
                                 (*
                                  (sqrt (- (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 0.5)) -1.0))
                                  J_m)
                                 (* (cos (* -0.5 K)) -2.0))
                                (*
                                 (* (+ 1.0 (/ (* J_m -2.0) t_0)) t_0)
                                 (cosh
                                  (asinh (/ U_m (fma -0.25 (* J_m (pow K 2.0)) (* 2.0 J_m)))))))))))
                        U_m = fabs(U);
                        J\_m = fabs(J);
                        J\_s = copysign(1.0, J);
                        double code(double J_s, double J_m, double K, double U_m) {
                        	double t_0 = ((K * K) * J_m) * 0.25;
                        	double t_1 = cos((K / 2.0));
                        	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                        	double tmp;
                        	if (t_2 <= -5e+305) {
                        		tmp = -2.0 * (U_m * 0.5);
                        	} else if (t_2 <= 1e+307) {
                        		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (cos((-0.5 * K)) * -2.0);
                        	} else {
                        		tmp = ((1.0 + ((J_m * -2.0) / t_0)) * t_0) * cosh(asinh((U_m / fma(-0.25, (J_m * pow(K, 2.0)), (2.0 * J_m)))));
                        	}
                        	return J_s * tmp;
                        }
                        
                        U_m = abs(U)
                        J\_m = abs(J)
                        J\_s = copysign(1.0, J)
                        function code(J_s, J_m, K, U_m)
                        	t_0 = Float64(Float64(Float64(K * K) * J_m) * 0.25)
                        	t_1 = cos(Float64(K / 2.0))
                        	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
                        	tmp = 0.0
                        	if (t_2 <= -5e+305)
                        		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                        	elseif (t_2 <= 1e+307)
                        		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + 0.5)) - -1.0)) * J_m) * Float64(cos(Float64(-0.5 * K)) * -2.0));
                        	else
                        		tmp = Float64(Float64(Float64(1.0 + Float64(Float64(J_m * -2.0) / t_0)) * t_0) * cosh(asinh(Float64(U_m / fma(-0.25, Float64(J_m * (K ^ 2.0)), Float64(2.0 * J_m))))));
                        	end
                        	return Float64(J_s * tmp)
                        end
                        
                        U_m = N[Abs[U], $MachinePrecision]
                        J\_m = N[Abs[J], $MachinePrecision]
                        J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                        code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[(N[(N[(K * K), $MachinePrecision] * J$95$m), $MachinePrecision] * 0.25), $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, 1e+307], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + 0.5), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision] * -2.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(1.0 + N[(N[(J$95$m * -2.0), $MachinePrecision] / t$95$0), $MachinePrecision]), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Cosh[N[ArcSinh[N[(U$95$m / N[(-0.25 * N[(J$95$m * N[Power[K, 2.0], $MachinePrecision]), $MachinePrecision] + N[(2.0 * J$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]]]]
                        
                        \begin{array}{l}
                        U_m = \left|U\right|
                        \\
                        J\_m = \left|J\right|
                        \\
                        J\_s = \mathsf{copysign}\left(1, J\right)
                        
                        \\
                        \begin{array}{l}
                        t_0 := \left(\left(K \cdot K\right) \cdot J\_m\right) \cdot 0.25\\
                        t_1 := \cos \left(\frac{K}{2}\right)\\
                        t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
                        J\_s \cdot \begin{array}{l}
                        \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
                        \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                        
                        \mathbf{elif}\;t\_2 \leq 10^{+307}:\\
                        \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\
                        
                        \mathbf{else}:\\
                        \;\;\;\;\left(\left(1 + \frac{J\_m \cdot -2}{t\_0}\right) \cdot t\_0\right) \cdot \cosh \sinh^{-1} \left(\frac{U\_m}{\mathsf{fma}\left(-0.25, J\_m \cdot {K}^{2}, 2 \cdot J\_m\right)}\right)\\
                        
                        
                        \end{array}
                        \end{array}
                        \end{array}
                        
                        Derivation
                        1. Split input into 3 regimes
                        2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                          1. Initial program 72.8%

                            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                          2. Taylor expanded in U around inf

                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                          3. Step-by-step derivation
                            1. lower-*.f64N/A

                              \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                            2. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                            3. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                            4. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                            5. lower-cos.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                            6. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                            7. lower-sqrt.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                            8. lower-/.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                            9. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                            10. lower-pow.f64N/A

                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                          4. Applied rewrites24.7%

                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                          5. Taylor expanded in J around 0

                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                          6. Step-by-step derivation
                            1. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                            2. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            3. lower-cos.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            4. lower-*.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            5. lower-sqrt.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            6. lower-/.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            7. lower-pow.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            8. lower-cos.f64N/A

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                            9. lower-*.f6452.4

                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                          7. Applied rewrites52.4%

                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                          8. Taylor expanded in K around 0

                            \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                          9. Step-by-step derivation
                            1. Applied rewrites40.0%

                              \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                            if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < 9.99999999999999986e306

                            1. Initial program 72.8%

                              \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                            2. Applied rewrites72.6%

                              \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                            3. Taylor expanded in K around 0

                              \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \color{blue}{\frac{1}{2}}} - -1} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                            4. Step-by-step derivation
                              1. Applied rewrites64.0%

                                \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + \color{blue}{0.5}} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]

                              if 9.99999999999999986e306 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                              1. Initial program 72.8%

                                \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                              2. Step-by-step derivation
                                1. lift-sqrt.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
                                2. lift-+.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
                                3. +-commutativeN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2} + 1}} \]
                                4. lift-pow.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} + 1} \]
                                5. unpow2N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} + 1} \]
                                6. cosh-asinh-revN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                                7. lower-cosh.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                                8. lower-asinh.f6484.5

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \color{blue}{\sinh^{-1} \left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)} \]
                                9. lift-*.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(2 \cdot J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                                10. count-2-revN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                                11. lower-+.f6484.5

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\left(J + J\right)} \cdot \cos \left(\frac{K}{2}\right)}\right) \]
                                12. lift-cos.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\frac{K}{2}\right)}}\right) \]
                                13. cos-neg-revN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right) \]
                                14. lower-cos.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \color{blue}{\cos \left(\mathsf{neg}\left(\frac{K}{2}\right)\right)}}\right) \]
                                15. lift-/.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\mathsf{neg}\left(\color{blue}{\frac{K}{2}}\right)\right)}\right) \]
                                16. distribute-neg-frac2N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{K}{\mathsf{neg}\left(2\right)}\right)}}\right) \]
                                17. metadata-evalN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{K}{\color{blue}{-2}}\right)}\right) \]
                                18. mult-flip-revN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(K \cdot \frac{1}{-2}\right)}}\right) \]
                                19. *-commutativeN/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right) \]
                                20. lower-*.f64N/A

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \color{blue}{\left(\frac{1}{-2} \cdot K\right)}}\right) \]
                                21. metadata-eval84.5

                                  \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\color{blue}{-0.5} \cdot K\right)}\right) \]
                              3. Applied rewrites84.5%

                                \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{\cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right)} \]
                              4. Taylor expanded in K around 0

                                \[\leadsto \color{blue}{\left(-2 \cdot J + \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                              5. Step-by-step derivation
                                1. lower-fma.f64N/A

                                  \[\leadsto \mathsf{fma}\left(-2, \color{blue}{J}, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                2. lower-*.f64N/A

                                  \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                3. lower-*.f64N/A

                                  \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                4. lower-pow.f6443.7

                                  \[\leadsto \mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                              6. Applied rewrites43.7%

                                \[\leadsto \color{blue}{\mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                              7. Step-by-step derivation
                                1. lift-fma.f64N/A

                                  \[\leadsto \left(-2 \cdot J + \color{blue}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                2. lift-*.f64N/A

                                  \[\leadsto \left(-2 \cdot J + \color{blue}{\frac{1}{4}} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                3. +-commutativeN/A

                                  \[\leadsto \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right) + \color{blue}{-2 \cdot J}\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                4. sum-to-multN/A

                                  \[\leadsto \left(\left(1 + \frac{-2 \cdot J}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \color{blue}{\left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)}\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                5. lower-unsound-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{-2 \cdot J}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \color{blue}{\left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)}\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                6. lower-unsound-+.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{-2 \cdot J}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(\color{blue}{\frac{1}{4}} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                7. lower-unsound-/.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{-2 \cdot J}{0.25 \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(0.25 \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                                8. lift-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{-2 \cdot J}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                9. *-commutativeN/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                10. lower-*.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{0.25 \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(0.25 \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                                11. lift-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                12. *-commutativeN/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(J \cdot {K}^{2}\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                13. lower-*.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(J \cdot {K}^{2}\right) \cdot 0.25}\right) \cdot \left(0.25 \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                                14. lift-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(J \cdot {K}^{2}\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                15. *-commutativeN/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left({K}^{2} \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                16. lower-*.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left({K}^{2} \cdot J\right) \cdot 0.25}\right) \cdot \left(0.25 \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                                17. lift-pow.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left({K}^{2} \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                18. unpow2N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                19. lower-*.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25}\right) \cdot \left(0.25 \cdot \left(J \cdot {K}^{2}\right)\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                                20. lift-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\frac{1}{4} \cdot \color{blue}{\left(J \cdot {K}^{2}\right)}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                21. *-commutativeN/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\left(J \cdot {K}^{2}\right) \cdot \color{blue}{\frac{1}{4}}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                22. lower-*.f6419.9

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25}\right) \cdot \left(\left(J \cdot {K}^{2}\right) \cdot \color{blue}{0.25}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                              8. Applied rewrites19.9%

                                \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25}\right) \cdot \color{blue}{\left(\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25\right)}\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\left(J + J\right) \cdot \cos \left(-0.5 \cdot K\right)}\right) \]
                              9. Taylor expanded in K around 0

                                \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\frac{-1}{4} \cdot \left(J \cdot {K}^{2}\right) + 2 \cdot J}}\right) \]
                              10. Step-by-step derivation
                                1. lower-fma.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, \color{blue}{J \cdot {K}^{2}}, 2 \cdot J\right)}\right) \]
                                2. lower-*.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, J \cdot \color{blue}{{K}^{2}}, 2 \cdot J\right)}\right) \]
                                3. lower-pow.f64N/A

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot \frac{1}{4}\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(\frac{-1}{4}, J \cdot {K}^{\color{blue}{2}}, 2 \cdot J\right)}\right) \]
                                4. lower-*.f6422.5

                                  \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\mathsf{fma}\left(-0.25, J \cdot {K}^{2}, 2 \cdot J\right)}\right) \]
                              11. Applied rewrites22.5%

                                \[\leadsto \left(\left(1 + \frac{J \cdot -2}{\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25}\right) \cdot \left(\left(\left(K \cdot K\right) \cdot J\right) \cdot 0.25\right)\right) \cdot \cosh \sinh^{-1} \left(\frac{U}{\color{blue}{\mathsf{fma}\left(-0.25, J \cdot {K}^{2}, 2 \cdot J\right)}}\right) \]
                            5. Recombined 3 regimes into one program.
                            6. Add Preprocessing

                            Alternative 10: 84.2% accurate, 0.6× speedup?

                            \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;\left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{else}:\\ \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\ \end{array} \end{array} \end{array} \]
                            U_m = (fabs.f64 U)
                            J\_m = (fabs.f64 J)
                            J\_s = (copysign.f64 #s(literal 1 binary64) J)
                            (FPCore (J_s J_m K U_m)
                             :precision binary64
                             (let* ((t_0 (cos (/ K 2.0))))
                               (*
                                J_s
                                (if (<=
                                     (*
                                      (* (* -2.0 J_m) t_0)
                                      (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_0)) 2.0))))
                                     -5e+305)
                                  (* -2.0 (* U_m 0.5))
                                  (*
                                   (*
                                    (sqrt (- (/ (/ (* (/ U_m J_m) (/ U_m J_m)) 4.0) (+ 0.5 0.5)) -1.0))
                                    J_m)
                                   (* (cos (* -0.5 K)) -2.0))))))
                            U_m = fabs(U);
                            J\_m = fabs(J);
                            J\_s = copysign(1.0, J);
                            double code(double J_s, double J_m, double K, double U_m) {
                            	double t_0 = cos((K / 2.0));
                            	double tmp;
                            	if ((((-2.0 * J_m) * t_0) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305) {
                            		tmp = -2.0 * (U_m * 0.5);
                            	} else {
                            		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (cos((-0.5 * K)) * -2.0);
                            	}
                            	return J_s * tmp;
                            }
                            
                            U_m =     private
                            J\_m =     private
                            J\_s =     private
                            module fmin_fmax_functions
                                implicit none
                                private
                                public fmax
                                public fmin
                            
                                interface fmax
                                    module procedure fmax88
                                    module procedure fmax44
                                    module procedure fmax84
                                    module procedure fmax48
                                end interface
                                interface fmin
                                    module procedure fmin88
                                    module procedure fmin44
                                    module procedure fmin84
                                    module procedure fmin48
                                end interface
                            contains
                                real(8) function fmax88(x, y) result (res)
                                    real(8), intent (in) :: x
                                    real(8), intent (in) :: y
                                    res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                end function
                                real(4) function fmax44(x, y) result (res)
                                    real(4), intent (in) :: x
                                    real(4), intent (in) :: y
                                    res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                end function
                                real(8) function fmax84(x, y) result(res)
                                    real(8), intent (in) :: x
                                    real(4), intent (in) :: y
                                    res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
                                end function
                                real(8) function fmax48(x, y) result(res)
                                    real(4), intent (in) :: x
                                    real(8), intent (in) :: y
                                    res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
                                end function
                                real(8) function fmin88(x, y) result (res)
                                    real(8), intent (in) :: x
                                    real(8), intent (in) :: y
                                    res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                end function
                                real(4) function fmin44(x, y) result (res)
                                    real(4), intent (in) :: x
                                    real(4), intent (in) :: y
                                    res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                end function
                                real(8) function fmin84(x, y) result(res)
                                    real(8), intent (in) :: x
                                    real(4), intent (in) :: y
                                    res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
                                end function
                                real(8) function fmin48(x, y) result(res)
                                    real(4), intent (in) :: x
                                    real(8), intent (in) :: y
                                    res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
                                end function
                            end module
                            
                            real(8) function code(j_s, j_m, k, u_m)
                            use fmin_fmax_functions
                                real(8), intent (in) :: j_s
                                real(8), intent (in) :: j_m
                                real(8), intent (in) :: k
                                real(8), intent (in) :: u_m
                                real(8) :: t_0
                                real(8) :: tmp
                                t_0 = cos((k / 2.0d0))
                                if (((((-2.0d0) * j_m) * t_0) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_0)) ** 2.0d0)))) <= (-5d+305)) then
                                    tmp = (-2.0d0) * (u_m * 0.5d0)
                                else
                                    tmp = (sqrt((((((u_m / j_m) * (u_m / j_m)) / 4.0d0) / (0.5d0 + 0.5d0)) - (-1.0d0))) * j_m) * (cos(((-0.5d0) * k)) * (-2.0d0))
                                end if
                                code = j_s * tmp
                            end function
                            
                            U_m = Math.abs(U);
                            J\_m = Math.abs(J);
                            J\_s = Math.copySign(1.0, J);
                            public static double code(double J_s, double J_m, double K, double U_m) {
                            	double t_0 = Math.cos((K / 2.0));
                            	double tmp;
                            	if ((((-2.0 * J_m) * t_0) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305) {
                            		tmp = -2.0 * (U_m * 0.5);
                            	} else {
                            		tmp = (Math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (Math.cos((-0.5 * K)) * -2.0);
                            	}
                            	return J_s * tmp;
                            }
                            
                            U_m = math.fabs(U)
                            J\_m = math.fabs(J)
                            J\_s = math.copysign(1.0, J)
                            def code(J_s, J_m, K, U_m):
                            	t_0 = math.cos((K / 2.0))
                            	tmp = 0
                            	if (((-2.0 * J_m) * t_0) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305:
                            		tmp = -2.0 * (U_m * 0.5)
                            	else:
                            		tmp = (math.sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (math.cos((-0.5 * K)) * -2.0)
                            	return J_s * tmp
                            
                            U_m = abs(U)
                            J\_m = abs(J)
                            J\_s = copysign(1.0, J)
                            function code(J_s, J_m, K, U_m)
                            	t_0 = cos(Float64(K / 2.0))
                            	tmp = 0.0
                            	if (Float64(Float64(Float64(-2.0 * J_m) * t_0) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_0)) ^ 2.0)))) <= -5e+305)
                            		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                            	else
                            		tmp = Float64(Float64(sqrt(Float64(Float64(Float64(Float64(Float64(U_m / J_m) * Float64(U_m / J_m)) / 4.0) / Float64(0.5 + 0.5)) - -1.0)) * J_m) * Float64(cos(Float64(-0.5 * K)) * -2.0));
                            	end
                            	return Float64(J_s * tmp)
                            end
                            
                            U_m = abs(U);
                            J\_m = abs(J);
                            J\_s = sign(J) * abs(1.0);
                            function tmp_2 = code(J_s, J_m, K, U_m)
                            	t_0 = cos((K / 2.0));
                            	tmp = 0.0;
                            	if ((((-2.0 * J_m) * t_0) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_0)) ^ 2.0)))) <= -5e+305)
                            		tmp = -2.0 * (U_m * 0.5);
                            	else
                            		tmp = (sqrt((((((U_m / J_m) * (U_m / J_m)) / 4.0) / (0.5 + 0.5)) - -1.0)) * J_m) * (cos((-0.5 * K)) * -2.0);
                            	end
                            	tmp_2 = J_s * tmp;
                            end
                            
                            U_m = N[Abs[U], $MachinePrecision]
                            J\_m = N[Abs[J], $MachinePrecision]
                            J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                            code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, N[(J$95$s * If[LessEqual[N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], N[(N[(N[Sqrt[N[(N[(N[(N[(N[(U$95$m / J$95$m), $MachinePrecision] * N[(U$95$m / J$95$m), $MachinePrecision]), $MachinePrecision] / 4.0), $MachinePrecision] / N[(0.5 + 0.5), $MachinePrecision]), $MachinePrecision] - -1.0), $MachinePrecision]], $MachinePrecision] * J$95$m), $MachinePrecision] * N[(N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision] * -2.0), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]
                            
                            \begin{array}{l}
                            U_m = \left|U\right|
                            \\
                            J\_m = \left|J\right|
                            \\
                            J\_s = \mathsf{copysign}\left(1, J\right)
                            
                            \\
                            \begin{array}{l}
                            t_0 := \cos \left(\frac{K}{2}\right)\\
                            J\_s \cdot \begin{array}{l}
                            \mathbf{if}\;\left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\
                            \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                            
                            \mathbf{else}:\\
                            \;\;\;\;\left(\sqrt{\frac{\frac{\frac{U\_m}{J\_m} \cdot \frac{U\_m}{J\_m}}{4}}{0.5 + 0.5} - -1} \cdot J\_m\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)\\
                            
                            
                            \end{array}
                            \end{array}
                            \end{array}
                            
                            Derivation
                            1. Split input into 2 regimes
                            2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                              1. Initial program 72.8%

                                \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                              2. Taylor expanded in U around inf

                                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                              3. Step-by-step derivation
                                1. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                2. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                3. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                4. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                5. lower-cos.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                6. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                7. lower-sqrt.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                8. lower-/.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                9. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                10. lower-pow.f64N/A

                                  \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                              4. Applied rewrites24.7%

                                \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                              5. Taylor expanded in J around 0

                                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                              6. Step-by-step derivation
                                1. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                2. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                3. lower-cos.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                4. lower-*.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                5. lower-sqrt.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                6. lower-/.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                7. lower-pow.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                8. lower-cos.f64N/A

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                9. lower-*.f6452.4

                                  \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                              7. Applied rewrites52.4%

                                \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                              8. Taylor expanded in K around 0

                                \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                              9. Step-by-step derivation
                                1. Applied rewrites40.0%

                                  \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                                if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                                1. Initial program 72.8%

                                  \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                2. Applied rewrites72.6%

                                  \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                                3. Taylor expanded in K around 0

                                  \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{\frac{1}{2} + \color{blue}{\frac{1}{2}}} - -1} \cdot J\right) \cdot \left(\cos \left(\frac{-1}{2} \cdot K\right) \cdot -2\right) \]
                                4. Step-by-step derivation
                                  1. Applied rewrites64.0%

                                    \[\leadsto \left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + \color{blue}{0.5}} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right) \]
                                5. Recombined 2 regimes into one program.
                                6. Add Preprocessing

                                Alternative 11: 82.7% accurate, 0.6× speedup?

                                \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ t_1 := \left(-2 \cdot J\_m\right) \cdot t\_0\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_1 \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{else}:\\ \;\;\;\;t\_1 \cdot \sqrt{\mathsf{fma}\left(\frac{U\_m}{J\_m + J\_m} \cdot U\_m, \frac{0.5}{J\_m}, 1\right)}\\ \end{array} \end{array} \end{array} \]
                                U_m = (fabs.f64 U)
                                J\_m = (fabs.f64 J)
                                J\_s = (copysign.f64 #s(literal 1 binary64) J)
                                (FPCore (J_s J_m K U_m)
                                 :precision binary64
                                 (let* ((t_0 (cos (/ K 2.0))) (t_1 (* (* -2.0 J_m) t_0)))
                                   (*
                                    J_s
                                    (if (<=
                                         (* t_1 (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_0)) 2.0))))
                                         -5e+305)
                                      (* -2.0 (* U_m 0.5))
                                      (* t_1 (sqrt (fma (* (/ U_m (+ J_m J_m)) U_m) (/ 0.5 J_m) 1.0)))))))
                                U_m = fabs(U);
                                J\_m = fabs(J);
                                J\_s = copysign(1.0, J);
                                double code(double J_s, double J_m, double K, double U_m) {
                                	double t_0 = cos((K / 2.0));
                                	double t_1 = (-2.0 * J_m) * t_0;
                                	double tmp;
                                	if ((t_1 * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305) {
                                		tmp = -2.0 * (U_m * 0.5);
                                	} else {
                                		tmp = t_1 * sqrt(fma(((U_m / (J_m + J_m)) * U_m), (0.5 / J_m), 1.0));
                                	}
                                	return J_s * tmp;
                                }
                                
                                U_m = abs(U)
                                J\_m = abs(J)
                                J\_s = copysign(1.0, J)
                                function code(J_s, J_m, K, U_m)
                                	t_0 = cos(Float64(K / 2.0))
                                	t_1 = Float64(Float64(-2.0 * J_m) * t_0)
                                	tmp = 0.0
                                	if (Float64(t_1 * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_0)) ^ 2.0)))) <= -5e+305)
                                		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                                	else
                                		tmp = Float64(t_1 * sqrt(fma(Float64(Float64(U_m / Float64(J_m + J_m)) * U_m), Float64(0.5 / J_m), 1.0)));
                                	end
                                	return Float64(J_s * tmp)
                                end
                                
                                U_m = N[Abs[U], $MachinePrecision]
                                J\_m = N[Abs[J], $MachinePrecision]
                                J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                                code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$1 = N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]}, N[(J$95$s * If[LessEqual[N[(t$95$1 * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], N[(t$95$1 * N[Sqrt[N[(N[(N[(U$95$m / N[(J$95$m + J$95$m), $MachinePrecision]), $MachinePrecision] * U$95$m), $MachinePrecision] * N[(0.5 / J$95$m), $MachinePrecision] + 1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]]
                                
                                \begin{array}{l}
                                U_m = \left|U\right|
                                \\
                                J\_m = \left|J\right|
                                \\
                                J\_s = \mathsf{copysign}\left(1, J\right)
                                
                                \\
                                \begin{array}{l}
                                t_0 := \cos \left(\frac{K}{2}\right)\\
                                t_1 := \left(-2 \cdot J\_m\right) \cdot t\_0\\
                                J\_s \cdot \begin{array}{l}
                                \mathbf{if}\;t\_1 \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\
                                \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                                
                                \mathbf{else}:\\
                                \;\;\;\;t\_1 \cdot \sqrt{\mathsf{fma}\left(\frac{U\_m}{J\_m + J\_m} \cdot U\_m, \frac{0.5}{J\_m}, 1\right)}\\
                                
                                
                                \end{array}
                                \end{array}
                                \end{array}
                                
                                Derivation
                                1. Split input into 2 regimes
                                2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                                  1. Initial program 72.8%

                                    \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                  2. Taylor expanded in U around inf

                                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                  3. Step-by-step derivation
                                    1. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                    2. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                    3. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                    4. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                    5. lower-cos.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                    6. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                    7. lower-sqrt.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                    8. lower-/.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                    9. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                    10. lower-pow.f64N/A

                                      \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                  4. Applied rewrites24.7%

                                    \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                  5. Taylor expanded in J around 0

                                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                                  6. Step-by-step derivation
                                    1. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                    2. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    3. lower-cos.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    4. lower-*.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    5. lower-sqrt.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    6. lower-/.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    7. lower-pow.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    8. lower-cos.f64N/A

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                    9. lower-*.f6452.4

                                      \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                                  7. Applied rewrites52.4%

                                    \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                                  8. Taylor expanded in K around 0

                                    \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                                  9. Step-by-step derivation
                                    1. Applied rewrites40.0%

                                      \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                                    if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                                    1. Initial program 72.8%

                                      \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                    2. Step-by-step derivation
                                      1. lift-+.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}}} \]
                                      2. +-commutativeN/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2} + 1}} \]
                                      3. lift-pow.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{{\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} + 1} \]
                                      4. unpow2N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} + 1} \]
                                      5. lift-/.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} + 1} \]
                                      6. lift-*.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\frac{U}{\color{blue}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} + 1} \]
                                      7. associate-/r*N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{\frac{U}{2 \cdot J}}{\cos \left(\frac{K}{2}\right)}} \cdot \frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)} + 1} \]
                                      8. lift-/.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\frac{\frac{U}{2 \cdot J}}{\cos \left(\frac{K}{2}\right)} \cdot \color{blue}{\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}} + 1} \]
                                      9. frac-timesN/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\frac{\frac{U}{2 \cdot J} \cdot U}{\cos \left(\frac{K}{2}\right) \cdot \left(\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right)}} + 1} \]
                                      10. mult-flipN/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\left(\frac{U}{2 \cdot J} \cdot U\right) \cdot \frac{1}{\cos \left(\frac{K}{2}\right) \cdot \left(\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right)}} + 1} \]
                                      11. lower-fma.f64N/A

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\mathsf{fma}\left(\frac{U}{2 \cdot J} \cdot U, \frac{1}{\cos \left(\frac{K}{2}\right) \cdot \left(\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right)}, 1\right)}} \]
                                    3. Applied rewrites69.8%

                                      \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\color{blue}{\mathsf{fma}\left(\frac{U}{J + J} \cdot U, \frac{1}{\left(0.5 + 0.5 \cdot \cos K\right) \cdot \left(J + J\right)}, 1\right)}} \]
                                    4. Taylor expanded in K around 0

                                      \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\mathsf{fma}\left(\frac{U}{J + J} \cdot U, \color{blue}{\frac{\frac{1}{2}}{J}}, 1\right)} \]
                                    5. Step-by-step derivation
                                      1. lower-/.f6462.4

                                        \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\mathsf{fma}\left(\frac{U}{J + J} \cdot U, \frac{0.5}{\color{blue}{J}}, 1\right)} \]
                                    6. Applied rewrites62.4%

                                      \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{\mathsf{fma}\left(\frac{U}{J + J} \cdot U, \color{blue}{\frac{0.5}{J}}, 1\right)} \]
                                  10. Recombined 2 regimes into one program.
                                  11. Add Preprocessing

                                  Alternative 12: 74.0% accurate, 0.3× speedup?

                                  \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := -2 \cdot \left(J\_m \cdot \cos \left(-0.5 \cdot K\right)\right)\\ t_1 := \cos \left(\frac{K}{2}\right)\\ t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{elif}\;t\_2 \leq -5 \cdot 10^{+140}:\\ \;\;\;\;t\_0\\ \mathbf{elif}\;t\_2 \leq -0.02:\\ \;\;\;\;-2 \cdot \left(J\_m \cdot \sqrt{1 + 0.25 \cdot \frac{{U\_m}^{2}}{{J\_m}^{2}}}\right)\\ \mathbf{else}:\\ \;\;\;\;t\_0\\ \end{array} \end{array} \end{array} \]
                                  U_m = (fabs.f64 U)
                                  J\_m = (fabs.f64 J)
                                  J\_s = (copysign.f64 #s(literal 1 binary64) J)
                                  (FPCore (J_s J_m K U_m)
                                   :precision binary64
                                   (let* ((t_0 (* -2.0 (* J_m (cos (* -0.5 K)))))
                                          (t_1 (cos (/ K 2.0)))
                                          (t_2
                                           (*
                                            (* (* -2.0 J_m) t_1)
                                            (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_1)) 2.0))))))
                                     (*
                                      J_s
                                      (if (<= t_2 -5e+305)
                                        (* -2.0 (* U_m 0.5))
                                        (if (<= t_2 -5e+140)
                                          t_0
                                          (if (<= t_2 -0.02)
                                            (*
                                             -2.0
                                             (* J_m (sqrt (+ 1.0 (* 0.25 (/ (pow U_m 2.0) (pow J_m 2.0)))))))
                                            t_0))))))
                                  U_m = fabs(U);
                                  J\_m = fabs(J);
                                  J\_s = copysign(1.0, J);
                                  double code(double J_s, double J_m, double K, double U_m) {
                                  	double t_0 = -2.0 * (J_m * cos((-0.5 * K)));
                                  	double t_1 = cos((K / 2.0));
                                  	double t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                                  	double tmp;
                                  	if (t_2 <= -5e+305) {
                                  		tmp = -2.0 * (U_m * 0.5);
                                  	} else if (t_2 <= -5e+140) {
                                  		tmp = t_0;
                                  	} else if (t_2 <= -0.02) {
                                  		tmp = -2.0 * (J_m * sqrt((1.0 + (0.25 * (pow(U_m, 2.0) / pow(J_m, 2.0))))));
                                  	} else {
                                  		tmp = t_0;
                                  	}
                                  	return J_s * tmp;
                                  }
                                  
                                  U_m =     private
                                  J\_m =     private
                                  J\_s =     private
                                  module fmin_fmax_functions
                                      implicit none
                                      private
                                      public fmax
                                      public fmin
                                  
                                      interface fmax
                                          module procedure fmax88
                                          module procedure fmax44
                                          module procedure fmax84
                                          module procedure fmax48
                                      end interface
                                      interface fmin
                                          module procedure fmin88
                                          module procedure fmin44
                                          module procedure fmin84
                                          module procedure fmin48
                                      end interface
                                  contains
                                      real(8) function fmax88(x, y) result (res)
                                          real(8), intent (in) :: x
                                          real(8), intent (in) :: y
                                          res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                      end function
                                      real(4) function fmax44(x, y) result (res)
                                          real(4), intent (in) :: x
                                          real(4), intent (in) :: y
                                          res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                      end function
                                      real(8) function fmax84(x, y) result(res)
                                          real(8), intent (in) :: x
                                          real(4), intent (in) :: y
                                          res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
                                      end function
                                      real(8) function fmax48(x, y) result(res)
                                          real(4), intent (in) :: x
                                          real(8), intent (in) :: y
                                          res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
                                      end function
                                      real(8) function fmin88(x, y) result (res)
                                          real(8), intent (in) :: x
                                          real(8), intent (in) :: y
                                          res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                      end function
                                      real(4) function fmin44(x, y) result (res)
                                          real(4), intent (in) :: x
                                          real(4), intent (in) :: y
                                          res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                      end function
                                      real(8) function fmin84(x, y) result(res)
                                          real(8), intent (in) :: x
                                          real(4), intent (in) :: y
                                          res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
                                      end function
                                      real(8) function fmin48(x, y) result(res)
                                          real(4), intent (in) :: x
                                          real(8), intent (in) :: y
                                          res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
                                      end function
                                  end module
                                  
                                  real(8) function code(j_s, j_m, k, u_m)
                                  use fmin_fmax_functions
                                      real(8), intent (in) :: j_s
                                      real(8), intent (in) :: j_m
                                      real(8), intent (in) :: k
                                      real(8), intent (in) :: u_m
                                      real(8) :: t_0
                                      real(8) :: t_1
                                      real(8) :: t_2
                                      real(8) :: tmp
                                      t_0 = (-2.0d0) * (j_m * cos(((-0.5d0) * k)))
                                      t_1 = cos((k / 2.0d0))
                                      t_2 = (((-2.0d0) * j_m) * t_1) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_1)) ** 2.0d0)))
                                      if (t_2 <= (-5d+305)) then
                                          tmp = (-2.0d0) * (u_m * 0.5d0)
                                      else if (t_2 <= (-5d+140)) then
                                          tmp = t_0
                                      else if (t_2 <= (-0.02d0)) then
                                          tmp = (-2.0d0) * (j_m * sqrt((1.0d0 + (0.25d0 * ((u_m ** 2.0d0) / (j_m ** 2.0d0))))))
                                      else
                                          tmp = t_0
                                      end if
                                      code = j_s * tmp
                                  end function
                                  
                                  U_m = Math.abs(U);
                                  J\_m = Math.abs(J);
                                  J\_s = Math.copySign(1.0, J);
                                  public static double code(double J_s, double J_m, double K, double U_m) {
                                  	double t_0 = -2.0 * (J_m * Math.cos((-0.5 * K)));
                                  	double t_1 = Math.cos((K / 2.0));
                                  	double t_2 = ((-2.0 * J_m) * t_1) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)));
                                  	double tmp;
                                  	if (t_2 <= -5e+305) {
                                  		tmp = -2.0 * (U_m * 0.5);
                                  	} else if (t_2 <= -5e+140) {
                                  		tmp = t_0;
                                  	} else if (t_2 <= -0.02) {
                                  		tmp = -2.0 * (J_m * Math.sqrt((1.0 + (0.25 * (Math.pow(U_m, 2.0) / Math.pow(J_m, 2.0))))));
                                  	} else {
                                  		tmp = t_0;
                                  	}
                                  	return J_s * tmp;
                                  }
                                  
                                  U_m = math.fabs(U)
                                  J\_m = math.fabs(J)
                                  J\_s = math.copysign(1.0, J)
                                  def code(J_s, J_m, K, U_m):
                                  	t_0 = -2.0 * (J_m * math.cos((-0.5 * K)))
                                  	t_1 = math.cos((K / 2.0))
                                  	t_2 = ((-2.0 * J_m) * t_1) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_1)), 2.0)))
                                  	tmp = 0
                                  	if t_2 <= -5e+305:
                                  		tmp = -2.0 * (U_m * 0.5)
                                  	elif t_2 <= -5e+140:
                                  		tmp = t_0
                                  	elif t_2 <= -0.02:
                                  		tmp = -2.0 * (J_m * math.sqrt((1.0 + (0.25 * (math.pow(U_m, 2.0) / math.pow(J_m, 2.0))))))
                                  	else:
                                  		tmp = t_0
                                  	return J_s * tmp
                                  
                                  U_m = abs(U)
                                  J\_m = abs(J)
                                  J\_s = copysign(1.0, J)
                                  function code(J_s, J_m, K, U_m)
                                  	t_0 = Float64(-2.0 * Float64(J_m * cos(Float64(-0.5 * K))))
                                  	t_1 = cos(Float64(K / 2.0))
                                  	t_2 = Float64(Float64(Float64(-2.0 * J_m) * t_1) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_1)) ^ 2.0))))
                                  	tmp = 0.0
                                  	if (t_2 <= -5e+305)
                                  		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                                  	elseif (t_2 <= -5e+140)
                                  		tmp = t_0;
                                  	elseif (t_2 <= -0.02)
                                  		tmp = Float64(-2.0 * Float64(J_m * sqrt(Float64(1.0 + Float64(0.25 * Float64((U_m ^ 2.0) / (J_m ^ 2.0)))))));
                                  	else
                                  		tmp = t_0;
                                  	end
                                  	return Float64(J_s * tmp)
                                  end
                                  
                                  U_m = abs(U);
                                  J\_m = abs(J);
                                  J\_s = sign(J) * abs(1.0);
                                  function tmp_2 = code(J_s, J_m, K, U_m)
                                  	t_0 = -2.0 * (J_m * cos((-0.5 * K)));
                                  	t_1 = cos((K / 2.0));
                                  	t_2 = ((-2.0 * J_m) * t_1) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_1)) ^ 2.0)));
                                  	tmp = 0.0;
                                  	if (t_2 <= -5e+305)
                                  		tmp = -2.0 * (U_m * 0.5);
                                  	elseif (t_2 <= -5e+140)
                                  		tmp = t_0;
                                  	elseif (t_2 <= -0.02)
                                  		tmp = -2.0 * (J_m * sqrt((1.0 + (0.25 * ((U_m ^ 2.0) / (J_m ^ 2.0))))));
                                  	else
                                  		tmp = t_0;
                                  	end
                                  	tmp_2 = J_s * tmp;
                                  end
                                  
                                  U_m = N[Abs[U], $MachinePrecision]
                                  J\_m = N[Abs[J], $MachinePrecision]
                                  J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                                  code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[(-2.0 * N[(J$95$m * N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, Block[{t$95$1 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, Block[{t$95$2 = N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$1), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(J$95$s * If[LessEqual[t$95$2, -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$2, -5e+140], t$95$0, If[LessEqual[t$95$2, -0.02], N[(-2.0 * N[(J$95$m * N[Sqrt[N[(1.0 + N[(0.25 * N[(N[Power[U$95$m, 2.0], $MachinePrecision] / N[Power[J$95$m, 2.0], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$0]]]), $MachinePrecision]]]]
                                  
                                  \begin{array}{l}
                                  U_m = \left|U\right|
                                  \\
                                  J\_m = \left|J\right|
                                  \\
                                  J\_s = \mathsf{copysign}\left(1, J\right)
                                  
                                  \\
                                  \begin{array}{l}
                                  t_0 := -2 \cdot \left(J\_m \cdot \cos \left(-0.5 \cdot K\right)\right)\\
                                  t_1 := \cos \left(\frac{K}{2}\right)\\
                                  t_2 := \left(\left(-2 \cdot J\_m\right) \cdot t\_1\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_1}\right)}^{2}}\\
                                  J\_s \cdot \begin{array}{l}
                                  \mathbf{if}\;t\_2 \leq -5 \cdot 10^{+305}:\\
                                  \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                                  
                                  \mathbf{elif}\;t\_2 \leq -5 \cdot 10^{+140}:\\
                                  \;\;\;\;t\_0\\
                                  
                                  \mathbf{elif}\;t\_2 \leq -0.02:\\
                                  \;\;\;\;-2 \cdot \left(J\_m \cdot \sqrt{1 + 0.25 \cdot \frac{{U\_m}^{2}}{{J\_m}^{2}}}\right)\\
                                  
                                  \mathbf{else}:\\
                                  \;\;\;\;t\_0\\
                                  
                                  
                                  \end{array}
                                  \end{array}
                                  \end{array}
                                  
                                  Derivation
                                  1. Split input into 3 regimes
                                  2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                                    1. Initial program 72.8%

                                      \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                    2. Taylor expanded in U around inf

                                      \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                    3. Step-by-step derivation
                                      1. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                      2. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                      3. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                      4. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                      5. lower-cos.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                      6. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                      7. lower-sqrt.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                      8. lower-/.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                      9. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                      10. lower-pow.f64N/A

                                        \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                    4. Applied rewrites24.7%

                                      \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                    5. Taylor expanded in J around 0

                                      \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                                    6. Step-by-step derivation
                                      1. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                      2. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      3. lower-cos.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      4. lower-*.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      5. lower-sqrt.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      6. lower-/.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      7. lower-pow.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      8. lower-cos.f64N/A

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                      9. lower-*.f6452.4

                                        \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                                    7. Applied rewrites52.4%

                                      \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                                    8. Taylor expanded in K around 0

                                      \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                                    9. Step-by-step derivation
                                      1. Applied rewrites40.0%

                                        \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                                      if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000008e140 or -0.0200000000000000004 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                                      1. Initial program 72.8%

                                        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                      2. Applied rewrites72.6%

                                        \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                                      3. Taylor expanded in J around inf

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right)} \]
                                      4. Step-by-step derivation
                                        1. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right)} \]
                                        2. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                        3. lower-cos.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right) \]
                                        4. lower-*.f6451.3

                                          \[\leadsto -2 \cdot \left(J \cdot \cos \left(-0.5 \cdot K\right)\right) \]
                                      5. Applied rewrites51.3%

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \cos \left(-0.5 \cdot K\right)\right)} \]

                                      if -5.00000000000000008e140 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -0.0200000000000000004

                                      1. Initial program 72.8%

                                        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                      2. Taylor expanded in K around 0

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right)} \]
                                      3. Step-by-step derivation
                                        1. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right)} \]
                                        2. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}}\right) \]
                                        3. lower-sqrt.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                        4. lower-+.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                        5. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                        6. lower-/.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                        7. lower-pow.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + \frac{1}{4} \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                        8. lower-pow.f6432.4

                                          \[\leadsto -2 \cdot \left(J \cdot \sqrt{1 + 0.25 \cdot \frac{{U}^{2}}{{J}^{2}}}\right) \]
                                      4. Applied rewrites32.4%

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \sqrt{1 + 0.25 \cdot \frac{{U}^{2}}{{J}^{2}}}\right)} \]
                                    10. Recombined 3 regimes into one program.
                                    11. Add Preprocessing

                                    Alternative 13: 72.2% accurate, 0.7× speedup?

                                    \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ \begin{array}{l} t_0 := \cos \left(\frac{K}{2}\right)\\ J\_s \cdot \begin{array}{l} \mathbf{if}\;\left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(J\_m \cdot \cos \left(-0.5 \cdot K\right)\right)\\ \end{array} \end{array} \end{array} \]
                                    U_m = (fabs.f64 U)
                                    J\_m = (fabs.f64 J)
                                    J\_s = (copysign.f64 #s(literal 1 binary64) J)
                                    (FPCore (J_s J_m K U_m)
                                     :precision binary64
                                     (let* ((t_0 (cos (/ K 2.0))))
                                       (*
                                        J_s
                                        (if (<=
                                             (*
                                              (* (* -2.0 J_m) t_0)
                                              (sqrt (+ 1.0 (pow (/ U_m (* (* 2.0 J_m) t_0)) 2.0))))
                                             -5e+305)
                                          (* -2.0 (* U_m 0.5))
                                          (* -2.0 (* J_m (cos (* -0.5 K))))))))
                                    U_m = fabs(U);
                                    J\_m = fabs(J);
                                    J\_s = copysign(1.0, J);
                                    double code(double J_s, double J_m, double K, double U_m) {
                                    	double t_0 = cos((K / 2.0));
                                    	double tmp;
                                    	if ((((-2.0 * J_m) * t_0) * sqrt((1.0 + pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305) {
                                    		tmp = -2.0 * (U_m * 0.5);
                                    	} else {
                                    		tmp = -2.0 * (J_m * cos((-0.5 * K)));
                                    	}
                                    	return J_s * tmp;
                                    }
                                    
                                    U_m =     private
                                    J\_m =     private
                                    J\_s =     private
                                    module fmin_fmax_functions
                                        implicit none
                                        private
                                        public fmax
                                        public fmin
                                    
                                        interface fmax
                                            module procedure fmax88
                                            module procedure fmax44
                                            module procedure fmax84
                                            module procedure fmax48
                                        end interface
                                        interface fmin
                                            module procedure fmin88
                                            module procedure fmin44
                                            module procedure fmin84
                                            module procedure fmin48
                                        end interface
                                    contains
                                        real(8) function fmax88(x, y) result (res)
                                            real(8), intent (in) :: x
                                            real(8), intent (in) :: y
                                            res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                        end function
                                        real(4) function fmax44(x, y) result (res)
                                            real(4), intent (in) :: x
                                            real(4), intent (in) :: y
                                            res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                        end function
                                        real(8) function fmax84(x, y) result(res)
                                            real(8), intent (in) :: x
                                            real(4), intent (in) :: y
                                            res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
                                        end function
                                        real(8) function fmax48(x, y) result(res)
                                            real(4), intent (in) :: x
                                            real(8), intent (in) :: y
                                            res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
                                        end function
                                        real(8) function fmin88(x, y) result (res)
                                            real(8), intent (in) :: x
                                            real(8), intent (in) :: y
                                            res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                        end function
                                        real(4) function fmin44(x, y) result (res)
                                            real(4), intent (in) :: x
                                            real(4), intent (in) :: y
                                            res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                        end function
                                        real(8) function fmin84(x, y) result(res)
                                            real(8), intent (in) :: x
                                            real(4), intent (in) :: y
                                            res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
                                        end function
                                        real(8) function fmin48(x, y) result(res)
                                            real(4), intent (in) :: x
                                            real(8), intent (in) :: y
                                            res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
                                        end function
                                    end module
                                    
                                    real(8) function code(j_s, j_m, k, u_m)
                                    use fmin_fmax_functions
                                        real(8), intent (in) :: j_s
                                        real(8), intent (in) :: j_m
                                        real(8), intent (in) :: k
                                        real(8), intent (in) :: u_m
                                        real(8) :: t_0
                                        real(8) :: tmp
                                        t_0 = cos((k / 2.0d0))
                                        if (((((-2.0d0) * j_m) * t_0) * sqrt((1.0d0 + ((u_m / ((2.0d0 * j_m) * t_0)) ** 2.0d0)))) <= (-5d+305)) then
                                            tmp = (-2.0d0) * (u_m * 0.5d0)
                                        else
                                            tmp = (-2.0d0) * (j_m * cos(((-0.5d0) * k)))
                                        end if
                                        code = j_s * tmp
                                    end function
                                    
                                    U_m = Math.abs(U);
                                    J\_m = Math.abs(J);
                                    J\_s = Math.copySign(1.0, J);
                                    public static double code(double J_s, double J_m, double K, double U_m) {
                                    	double t_0 = Math.cos((K / 2.0));
                                    	double tmp;
                                    	if ((((-2.0 * J_m) * t_0) * Math.sqrt((1.0 + Math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305) {
                                    		tmp = -2.0 * (U_m * 0.5);
                                    	} else {
                                    		tmp = -2.0 * (J_m * Math.cos((-0.5 * K)));
                                    	}
                                    	return J_s * tmp;
                                    }
                                    
                                    U_m = math.fabs(U)
                                    J\_m = math.fabs(J)
                                    J\_s = math.copysign(1.0, J)
                                    def code(J_s, J_m, K, U_m):
                                    	t_0 = math.cos((K / 2.0))
                                    	tmp = 0
                                    	if (((-2.0 * J_m) * t_0) * math.sqrt((1.0 + math.pow((U_m / ((2.0 * J_m) * t_0)), 2.0)))) <= -5e+305:
                                    		tmp = -2.0 * (U_m * 0.5)
                                    	else:
                                    		tmp = -2.0 * (J_m * math.cos((-0.5 * K)))
                                    	return J_s * tmp
                                    
                                    U_m = abs(U)
                                    J\_m = abs(J)
                                    J\_s = copysign(1.0, J)
                                    function code(J_s, J_m, K, U_m)
                                    	t_0 = cos(Float64(K / 2.0))
                                    	tmp = 0.0
                                    	if (Float64(Float64(Float64(-2.0 * J_m) * t_0) * sqrt(Float64(1.0 + (Float64(U_m / Float64(Float64(2.0 * J_m) * t_0)) ^ 2.0)))) <= -5e+305)
                                    		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                                    	else
                                    		tmp = Float64(-2.0 * Float64(J_m * cos(Float64(-0.5 * K))));
                                    	end
                                    	return Float64(J_s * tmp)
                                    end
                                    
                                    U_m = abs(U);
                                    J\_m = abs(J);
                                    J\_s = sign(J) * abs(1.0);
                                    function tmp_2 = code(J_s, J_m, K, U_m)
                                    	t_0 = cos((K / 2.0));
                                    	tmp = 0.0;
                                    	if ((((-2.0 * J_m) * t_0) * sqrt((1.0 + ((U_m / ((2.0 * J_m) * t_0)) ^ 2.0)))) <= -5e+305)
                                    		tmp = -2.0 * (U_m * 0.5);
                                    	else
                                    		tmp = -2.0 * (J_m * cos((-0.5 * K)));
                                    	end
                                    	tmp_2 = J_s * tmp;
                                    end
                                    
                                    U_m = N[Abs[U], $MachinePrecision]
                                    J\_m = N[Abs[J], $MachinePrecision]
                                    J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                                    code[J$95$s_, J$95$m_, K_, U$95$m_] := Block[{t$95$0 = N[Cos[N[(K / 2.0), $MachinePrecision]], $MachinePrecision]}, N[(J$95$s * If[LessEqual[N[(N[(N[(-2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision] * N[Sqrt[N[(1.0 + N[Power[N[(U$95$m / N[(N[(2.0 * J$95$m), $MachinePrecision] * t$95$0), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], -5e+305], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision], N[(-2.0 * N[(J$95$m * N[Cos[N[(-0.5 * K), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]]
                                    
                                    \begin{array}{l}
                                    U_m = \left|U\right|
                                    \\
                                    J\_m = \left|J\right|
                                    \\
                                    J\_s = \mathsf{copysign}\left(1, J\right)
                                    
                                    \\
                                    \begin{array}{l}
                                    t_0 := \cos \left(\frac{K}{2}\right)\\
                                    J\_s \cdot \begin{array}{l}
                                    \mathbf{if}\;\left(\left(-2 \cdot J\_m\right) \cdot t\_0\right) \cdot \sqrt{1 + {\left(\frac{U\_m}{\left(2 \cdot J\_m\right) \cdot t\_0}\right)}^{2}} \leq -5 \cdot 10^{+305}:\\
                                    \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                                    
                                    \mathbf{else}:\\
                                    \;\;\;\;-2 \cdot \left(J\_m \cdot \cos \left(-0.5 \cdot K\right)\right)\\
                                    
                                    
                                    \end{array}
                                    \end{array}
                                    \end{array}
                                    
                                    Derivation
                                    1. Split input into 2 regimes
                                    2. if (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64))))) < -5.00000000000000009e305

                                      1. Initial program 72.8%

                                        \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                      2. Taylor expanded in U around inf

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                      3. Step-by-step derivation
                                        1. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                        2. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                        3. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                        4. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                        5. lower-cos.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                        6. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                        7. lower-sqrt.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                        8. lower-/.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                        9. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                        10. lower-pow.f64N/A

                                          \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                      4. Applied rewrites24.7%

                                        \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                      5. Taylor expanded in J around 0

                                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                                      6. Step-by-step derivation
                                        1. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                        2. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        3. lower-cos.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        4. lower-*.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        5. lower-sqrt.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        6. lower-/.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        7. lower-pow.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        8. lower-cos.f64N/A

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                        9. lower-*.f6452.4

                                          \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                                      7. Applied rewrites52.4%

                                        \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                                      8. Taylor expanded in K around 0

                                        \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                                      9. Step-by-step derivation
                                        1. Applied rewrites40.0%

                                          \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]

                                        if -5.00000000000000009e305 < (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64)))) (sqrt.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (/.f64 U (*.f64 (*.f64 #s(literal 2 binary64) J) (cos.f64 (/.f64 K #s(literal 2 binary64))))) #s(literal 2 binary64)))))

                                        1. Initial program 72.8%

                                          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                        2. Applied rewrites72.6%

                                          \[\leadsto \color{blue}{\left(\sqrt{\frac{\frac{\frac{U}{J} \cdot \frac{U}{J}}{4}}{0.5 + 0.5 \cdot \cos K} - -1} \cdot J\right) \cdot \left(\cos \left(-0.5 \cdot K\right) \cdot -2\right)} \]
                                        3. Taylor expanded in J around inf

                                          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right)} \]
                                        4. Step-by-step derivation
                                          1. lower-*.f64N/A

                                            \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right)} \]
                                          2. lower-*.f64N/A

                                            \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\cos \left(\frac{-1}{2} \cdot K\right)}\right) \]
                                          3. lower-cos.f64N/A

                                            \[\leadsto -2 \cdot \left(J \cdot \cos \left(\frac{-1}{2} \cdot K\right)\right) \]
                                          4. lower-*.f6451.3

                                            \[\leadsto -2 \cdot \left(J \cdot \cos \left(-0.5 \cdot K\right)\right) \]
                                        5. Applied rewrites51.3%

                                          \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \cos \left(-0.5 \cdot K\right)\right)} \]
                                      10. Recombined 2 regimes into one program.
                                      11. Add Preprocessing

                                      Alternative 14: 49.8% accurate, 5.1× speedup?

                                      \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ J\_s \cdot \begin{array}{l} \mathbf{if}\;U\_m \leq 2.4 \cdot 10^{-84}:\\ \;\;\;\;\mathsf{fma}\left(\left(0.25 \cdot J\_m\right) \cdot K, K, J\_m \cdot -2\right) \cdot 1\\ \mathbf{else}:\\ \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\ \end{array} \end{array} \]
                                      U_m = (fabs.f64 U)
                                      J\_m = (fabs.f64 J)
                                      J\_s = (copysign.f64 #s(literal 1 binary64) J)
                                      (FPCore (J_s J_m K U_m)
                                       :precision binary64
                                       (*
                                        J_s
                                        (if (<= U_m 2.4e-84)
                                          (* (fma (* (* 0.25 J_m) K) K (* J_m -2.0)) 1.0)
                                          (* -2.0 (* U_m 0.5)))))
                                      U_m = fabs(U);
                                      J\_m = fabs(J);
                                      J\_s = copysign(1.0, J);
                                      double code(double J_s, double J_m, double K, double U_m) {
                                      	double tmp;
                                      	if (U_m <= 2.4e-84) {
                                      		tmp = fma(((0.25 * J_m) * K), K, (J_m * -2.0)) * 1.0;
                                      	} else {
                                      		tmp = -2.0 * (U_m * 0.5);
                                      	}
                                      	return J_s * tmp;
                                      }
                                      
                                      U_m = abs(U)
                                      J\_m = abs(J)
                                      J\_s = copysign(1.0, J)
                                      function code(J_s, J_m, K, U_m)
                                      	tmp = 0.0
                                      	if (U_m <= 2.4e-84)
                                      		tmp = Float64(fma(Float64(Float64(0.25 * J_m) * K), K, Float64(J_m * -2.0)) * 1.0);
                                      	else
                                      		tmp = Float64(-2.0 * Float64(U_m * 0.5));
                                      	end
                                      	return Float64(J_s * tmp)
                                      end
                                      
                                      U_m = N[Abs[U], $MachinePrecision]
                                      J\_m = N[Abs[J], $MachinePrecision]
                                      J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                                      code[J$95$s_, J$95$m_, K_, U$95$m_] := N[(J$95$s * If[LessEqual[U$95$m, 2.4e-84], N[(N[(N[(N[(0.25 * J$95$m), $MachinePrecision] * K), $MachinePrecision] * K + N[(J$95$m * -2.0), $MachinePrecision]), $MachinePrecision] * 1.0), $MachinePrecision], N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]
                                      
                                      \begin{array}{l}
                                      U_m = \left|U\right|
                                      \\
                                      J\_m = \left|J\right|
                                      \\
                                      J\_s = \mathsf{copysign}\left(1, J\right)
                                      
                                      \\
                                      J\_s \cdot \begin{array}{l}
                                      \mathbf{if}\;U\_m \leq 2.4 \cdot 10^{-84}:\\
                                      \;\;\;\;\mathsf{fma}\left(\left(0.25 \cdot J\_m\right) \cdot K, K, J\_m \cdot -2\right) \cdot 1\\
                                      
                                      \mathbf{else}:\\
                                      \;\;\;\;-2 \cdot \left(U\_m \cdot 0.5\right)\\
                                      
                                      
                                      \end{array}
                                      \end{array}
                                      
                                      Derivation
                                      1. Split input into 2 regimes
                                      2. if U < 2.40000000000000017e-84

                                        1. Initial program 72.8%

                                          \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                        2. Taylor expanded in J around inf

                                          \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{1} \]
                                        3. Step-by-step derivation
                                          1. Applied rewrites51.3%

                                            \[\leadsto \left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \color{blue}{1} \]
                                          2. Taylor expanded in K around 0

                                            \[\leadsto \color{blue}{\left(-2 \cdot J + \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot 1 \]
                                          3. Step-by-step derivation
                                            1. lower-fma.f64N/A

                                              \[\leadsto \mathsf{fma}\left(-2, \color{blue}{J}, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot 1 \]
                                            2. lower-*.f64N/A

                                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot 1 \]
                                            3. lower-*.f64N/A

                                              \[\leadsto \mathsf{fma}\left(-2, J, \frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot 1 \]
                                            4. lower-pow.f6427.1

                                              \[\leadsto \mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right) \cdot 1 \]
                                          4. Applied rewrites27.1%

                                            \[\leadsto \color{blue}{\mathsf{fma}\left(-2, J, 0.25 \cdot \left(J \cdot {K}^{2}\right)\right)} \cdot 1 \]
                                          5. Step-by-step derivation
                                            1. lift-fma.f64N/A

                                              \[\leadsto \left(-2 \cdot J + \color{blue}{\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right)}\right) \cdot 1 \]
                                            2. lift-*.f64N/A

                                              \[\leadsto \left(-2 \cdot J + \color{blue}{\frac{1}{4}} \cdot \left(J \cdot {K}^{2}\right)\right) \cdot 1 \]
                                            3. +-commutativeN/A

                                              \[\leadsto \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right) + \color{blue}{-2 \cdot J}\right) \cdot 1 \]
                                            4. lift-*.f64N/A

                                              \[\leadsto \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right) + \color{blue}{-2} \cdot J\right) \cdot 1 \]
                                            5. lift-*.f64N/A

                                              \[\leadsto \left(\frac{1}{4} \cdot \left(J \cdot {K}^{2}\right) + -2 \cdot J\right) \cdot 1 \]
                                            6. associate-*r*N/A

                                              \[\leadsto \left(\left(\frac{1}{4} \cdot J\right) \cdot {K}^{2} + \color{blue}{-2} \cdot J\right) \cdot 1 \]
                                            7. lift-*.f64N/A

                                              \[\leadsto \left(\left(\frac{1}{4} \cdot J\right) \cdot {K}^{2} + -2 \cdot J\right) \cdot 1 \]
                                            8. lift-pow.f64N/A

                                              \[\leadsto \left(\left(\frac{1}{4} \cdot J\right) \cdot {K}^{2} + -2 \cdot J\right) \cdot 1 \]
                                            9. unpow2N/A

                                              \[\leadsto \left(\left(\frac{1}{4} \cdot J\right) \cdot \left(K \cdot K\right) + -2 \cdot J\right) \cdot 1 \]
                                            10. associate-*r*N/A

                                              \[\leadsto \left(\left(\left(\frac{1}{4} \cdot J\right) \cdot K\right) \cdot K + \color{blue}{-2} \cdot J\right) \cdot 1 \]
                                            11. lower-fma.f64N/A

                                              \[\leadsto \mathsf{fma}\left(\left(\frac{1}{4} \cdot J\right) \cdot K, \color{blue}{K}, -2 \cdot J\right) \cdot 1 \]
                                            12. lower-*.f6427.1

                                              \[\leadsto \mathsf{fma}\left(\left(0.25 \cdot J\right) \cdot K, K, -2 \cdot J\right) \cdot 1 \]
                                            13. lift-*.f64N/A

                                              \[\leadsto \mathsf{fma}\left(\left(\frac{1}{4} \cdot J\right) \cdot K, K, -2 \cdot J\right) \cdot 1 \]
                                            14. *-commutativeN/A

                                              \[\leadsto \mathsf{fma}\left(\left(\frac{1}{4} \cdot J\right) \cdot K, K, J \cdot -2\right) \cdot 1 \]
                                            15. lower-*.f6427.1

                                              \[\leadsto \mathsf{fma}\left(\left(0.25 \cdot J\right) \cdot K, K, J \cdot -2\right) \cdot 1 \]
                                          6. Applied rewrites27.1%

                                            \[\leadsto \mathsf{fma}\left(\left(0.25 \cdot J\right) \cdot K, \color{blue}{K}, J \cdot -2\right) \cdot 1 \]

                                          if 2.40000000000000017e-84 < U

                                          1. Initial program 72.8%

                                            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                          2. Taylor expanded in U around inf

                                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                          3. Step-by-step derivation
                                            1. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                            2. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                            3. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                            4. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                            5. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                            6. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            7. lower-sqrt.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            8. lower-/.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            9. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            10. lower-pow.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                          4. Applied rewrites24.7%

                                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                          5. Taylor expanded in J around 0

                                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                                          6. Step-by-step derivation
                                            1. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                            2. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            3. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            4. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            5. lower-sqrt.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            6. lower-/.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            7. lower-pow.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            8. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            9. lower-*.f6452.4

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                                          7. Applied rewrites52.4%

                                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                                          8. Taylor expanded in K around 0

                                            \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                                          9. Step-by-step derivation
                                            1. Applied rewrites40.0%

                                              \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]
                                          10. Recombined 2 regimes into one program.
                                          11. Add Preprocessing

                                          Alternative 15: 40.0% accurate, 15.9× speedup?

                                          \[\begin{array}{l} U_m = \left|U\right| \\ J\_m = \left|J\right| \\ J\_s = \mathsf{copysign}\left(1, J\right) \\ J\_s \cdot \left(-2 \cdot \left(U\_m \cdot 0.5\right)\right) \end{array} \]
                                          U_m = (fabs.f64 U)
                                          J\_m = (fabs.f64 J)
                                          J\_s = (copysign.f64 #s(literal 1 binary64) J)
                                          (FPCore (J_s J_m K U_m) :precision binary64 (* J_s (* -2.0 (* U_m 0.5))))
                                          U_m = fabs(U);
                                          J\_m = fabs(J);
                                          J\_s = copysign(1.0, J);
                                          double code(double J_s, double J_m, double K, double U_m) {
                                          	return J_s * (-2.0 * (U_m * 0.5));
                                          }
                                          
                                          U_m =     private
                                          J\_m =     private
                                          J\_s =     private
                                          module fmin_fmax_functions
                                              implicit none
                                              private
                                              public fmax
                                              public fmin
                                          
                                              interface fmax
                                                  module procedure fmax88
                                                  module procedure fmax44
                                                  module procedure fmax84
                                                  module procedure fmax48
                                              end interface
                                              interface fmin
                                                  module procedure fmin88
                                                  module procedure fmin44
                                                  module procedure fmin84
                                                  module procedure fmin48
                                              end interface
                                          contains
                                              real(8) function fmax88(x, y) result (res)
                                                  real(8), intent (in) :: x
                                                  real(8), intent (in) :: y
                                                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                              end function
                                              real(4) function fmax44(x, y) result (res)
                                                  real(4), intent (in) :: x
                                                  real(4), intent (in) :: y
                                                  res = merge(y, merge(x, max(x, y), y /= y), x /= x)
                                              end function
                                              real(8) function fmax84(x, y) result(res)
                                                  real(8), intent (in) :: x
                                                  real(4), intent (in) :: y
                                                  res = merge(dble(y), merge(x, max(x, dble(y)), y /= y), x /= x)
                                              end function
                                              real(8) function fmax48(x, y) result(res)
                                                  real(4), intent (in) :: x
                                                  real(8), intent (in) :: y
                                                  res = merge(y, merge(dble(x), max(dble(x), y), y /= y), x /= x)
                                              end function
                                              real(8) function fmin88(x, y) result (res)
                                                  real(8), intent (in) :: x
                                                  real(8), intent (in) :: y
                                                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                              end function
                                              real(4) function fmin44(x, y) result (res)
                                                  real(4), intent (in) :: x
                                                  real(4), intent (in) :: y
                                                  res = merge(y, merge(x, min(x, y), y /= y), x /= x)
                                              end function
                                              real(8) function fmin84(x, y) result(res)
                                                  real(8), intent (in) :: x
                                                  real(4), intent (in) :: y
                                                  res = merge(dble(y), merge(x, min(x, dble(y)), y /= y), x /= x)
                                              end function
                                              real(8) function fmin48(x, y) result(res)
                                                  real(4), intent (in) :: x
                                                  real(8), intent (in) :: y
                                                  res = merge(y, merge(dble(x), min(dble(x), y), y /= y), x /= x)
                                              end function
                                          end module
                                          
                                          real(8) function code(j_s, j_m, k, u_m)
                                          use fmin_fmax_functions
                                              real(8), intent (in) :: j_s
                                              real(8), intent (in) :: j_m
                                              real(8), intent (in) :: k
                                              real(8), intent (in) :: u_m
                                              code = j_s * ((-2.0d0) * (u_m * 0.5d0))
                                          end function
                                          
                                          U_m = Math.abs(U);
                                          J\_m = Math.abs(J);
                                          J\_s = Math.copySign(1.0, J);
                                          public static double code(double J_s, double J_m, double K, double U_m) {
                                          	return J_s * (-2.0 * (U_m * 0.5));
                                          }
                                          
                                          U_m = math.fabs(U)
                                          J\_m = math.fabs(J)
                                          J\_s = math.copysign(1.0, J)
                                          def code(J_s, J_m, K, U_m):
                                          	return J_s * (-2.0 * (U_m * 0.5))
                                          
                                          U_m = abs(U)
                                          J\_m = abs(J)
                                          J\_s = copysign(1.0, J)
                                          function code(J_s, J_m, K, U_m)
                                          	return Float64(J_s * Float64(-2.0 * Float64(U_m * 0.5)))
                                          end
                                          
                                          U_m = abs(U);
                                          J\_m = abs(J);
                                          J\_s = sign(J) * abs(1.0);
                                          function tmp = code(J_s, J_m, K, U_m)
                                          	tmp = J_s * (-2.0 * (U_m * 0.5));
                                          end
                                          
                                          U_m = N[Abs[U], $MachinePrecision]
                                          J\_m = N[Abs[J], $MachinePrecision]
                                          J\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[J]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
                                          code[J$95$s_, J$95$m_, K_, U$95$m_] := N[(J$95$s * N[(-2.0 * N[(U$95$m * 0.5), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
                                          
                                          \begin{array}{l}
                                          U_m = \left|U\right|
                                          \\
                                          J\_m = \left|J\right|
                                          \\
                                          J\_s = \mathsf{copysign}\left(1, J\right)
                                          
                                          \\
                                          J\_s \cdot \left(-2 \cdot \left(U\_m \cdot 0.5\right)\right)
                                          \end{array}
                                          
                                          Derivation
                                          1. Initial program 72.8%

                                            \[\left(\left(-2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)\right) \cdot \sqrt{1 + {\left(\frac{U}{\left(2 \cdot J\right) \cdot \cos \left(\frac{K}{2}\right)}\right)}^{2}} \]
                                          2. Taylor expanded in U around inf

                                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                          3. Step-by-step derivation
                                            1. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \color{blue}{\left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                            2. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \color{blue}{\left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)}\right) \]
                                            3. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right)\right) \]
                                            4. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                            5. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\color{blue}{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right)\right) \]
                                            6. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\color{blue}{\frac{1}{4}}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            7. lower-sqrt.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            8. lower-/.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            9. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                            10. lower-pow.f64N/A

                                              \[\leadsto -2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{J}^{2} \cdot {\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right)\right) \]
                                          4. Applied rewrites24.7%

                                            \[\leadsto \color{blue}{-2 \cdot \left(J \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{J}^{2} \cdot {\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right)\right)} \]
                                          5. Taylor expanded in J around 0

                                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)}\right) \]
                                          6. Step-by-step derivation
                                            1. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \color{blue}{\sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}}\right)\right) \]
                                            2. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            3. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            4. lower-*.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            5. lower-sqrt.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            6. lower-/.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            7. lower-pow.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            8. lower-cos.f64N/A

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(\frac{1}{2} \cdot K\right) \cdot \sqrt{\frac{\frac{1}{4}}{{\cos \left(\frac{1}{2} \cdot K\right)}^{2}}}\right)\right) \]
                                            9. lower-*.f6452.4

                                              \[\leadsto -2 \cdot \left(U \cdot \left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)\right) \]
                                          7. Applied rewrites52.4%

                                            \[\leadsto -2 \cdot \left(U \cdot \color{blue}{\left(\cos \left(0.5 \cdot K\right) \cdot \sqrt{\frac{0.25}{{\cos \left(0.5 \cdot K\right)}^{2}}}\right)}\right) \]
                                          8. Taylor expanded in K around 0

                                            \[\leadsto -2 \cdot \left(U \cdot \frac{1}{2}\right) \]
                                          9. Step-by-step derivation
                                            1. Applied rewrites40.0%

                                              \[\leadsto -2 \cdot \left(U \cdot 0.5\right) \]
                                            2. Add Preprocessing

                                            Reproduce

                                            ?
                                            herbie shell --seed 2025162 
                                            (FPCore (J K U)
                                              :name "Maksimov and Kolovsky, Equation (3)"
                                              :precision binary64
                                              (* (* (* -2.0 J) (cos (/ K 2.0))) (sqrt (+ 1.0 (pow (/ U (* (* 2.0 J) (cos (/ K 2.0)))) 2.0)))))