Anisotropic x16 LOD (line direction, u)

Percentage Accurate: 76.4% → 76.5%
Time: 11.3s
Alternatives: 5
Speedup: 1.0×

Specification

?
\[\left(\left(\left(\left(\left(\left(1 \leq w \land w \leq 16384\right) \land \left(1 \leq h \land h \leq 16384\right)\right) \land \left(10^{-20} \leq \left|dX.u\right| \land \left|dX.u\right| \leq 10^{+20}\right)\right) \land \left(10^{-20} \leq \left|dX.v\right| \land \left|dX.v\right| \leq 10^{+20}\right)\right) \land \left(10^{-20} \leq \left|dY.u\right| \land \left|dY.u\right| \leq 10^{+20}\right)\right) \land \left(10^{-20} \leq \left|dY.v\right| \land \left|dY.v\right| \leq 10^{+20}\right)\right) \land maxAniso = 16\]
\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left\lfloor h\right\rfloor \cdot dX.v\\ t_1 := \left\lfloor w\right\rfloor \cdot dY.u\\ t_2 := \left\lfloor w\right\rfloor \cdot dX.u\\ t_3 := t\_2 \cdot t\_2 + t\_0 \cdot t\_0\\ t_4 := \left\lfloor h\right\rfloor \cdot dY.v\\ t_5 := t\_1 \cdot t\_1 + t\_4 \cdot t\_4\\ t_6 := \frac{1}{\sqrt{\mathsf{max}\left(t\_3, t\_5\right)}}\\ \mathbf{if}\;t\_3 \geq t\_5:\\ \;\;\;\;t\_6 \cdot t\_2\\ \mathbf{else}:\\ \;\;\;\;t\_6 \cdot t\_1\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0 (* (floor h) dX.v))
        (t_1 (* (floor w) dY.u))
        (t_2 (* (floor w) dX.u))
        (t_3 (+ (* t_2 t_2) (* t_0 t_0)))
        (t_4 (* (floor h) dY.v))
        (t_5 (+ (* t_1 t_1) (* t_4 t_4)))
        (t_6 (/ 1.0 (sqrt (fmax t_3 t_5)))))
   (if (>= t_3 t_5) (* t_6 t_2) (* t_6 t_1))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = floorf(h) * dX_46_v;
	float t_1 = floorf(w) * dY_46_u;
	float t_2 = floorf(w) * dX_46_u;
	float t_3 = (t_2 * t_2) + (t_0 * t_0);
	float t_4 = floorf(h) * dY_46_v;
	float t_5 = (t_1 * t_1) + (t_4 * t_4);
	float t_6 = 1.0f / sqrtf(fmaxf(t_3, t_5));
	float tmp;
	if (t_3 >= t_5) {
		tmp = t_6 * t_2;
	} else {
		tmp = t_6 * t_1;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = Float32(floor(h) * dX_46_v)
	t_1 = Float32(floor(w) * dY_46_u)
	t_2 = Float32(floor(w) * dX_46_u)
	t_3 = Float32(Float32(t_2 * t_2) + Float32(t_0 * t_0))
	t_4 = Float32(floor(h) * dY_46_v)
	t_5 = Float32(Float32(t_1 * t_1) + Float32(t_4 * t_4))
	t_6 = Float32(Float32(1.0) / sqrt(fmax(t_3, t_5)))
	tmp = Float32(0.0)
	if (t_3 >= t_5)
		tmp = Float32(t_6 * t_2);
	else
		tmp = Float32(t_6 * t_1);
	end
	return tmp
end
function tmp_2 = code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = floor(h) * dX_46_v;
	t_1 = floor(w) * dY_46_u;
	t_2 = floor(w) * dX_46_u;
	t_3 = (t_2 * t_2) + (t_0 * t_0);
	t_4 = floor(h) * dY_46_v;
	t_5 = (t_1 * t_1) + (t_4 * t_4);
	t_6 = single(1.0) / sqrt(max(t_3, t_5));
	tmp = single(0.0);
	if (t_3 >= t_5)
		tmp = t_6 * t_2;
	else
		tmp = t_6 * t_1;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left\lfloor h\right\rfloor  \cdot dX.v\\
t_1 := \left\lfloor w\right\rfloor  \cdot dY.u\\
t_2 := \left\lfloor w\right\rfloor  \cdot dX.u\\
t_3 := t\_2 \cdot t\_2 + t\_0 \cdot t\_0\\
t_4 := \left\lfloor h\right\rfloor  \cdot dY.v\\
t_5 := t\_1 \cdot t\_1 + t\_4 \cdot t\_4\\
t_6 := \frac{1}{\sqrt{\mathsf{max}\left(t\_3, t\_5\right)}}\\
\mathbf{if}\;t\_3 \geq t\_5:\\
\;\;\;\;t\_6 \cdot t\_2\\

\mathbf{else}:\\
\;\;\;\;t\_6 \cdot t\_1\\


\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 5 alternatives:

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

Initial Program: 76.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left\lfloor h\right\rfloor \cdot dX.v\\ t_1 := \left\lfloor w\right\rfloor \cdot dY.u\\ t_2 := \left\lfloor w\right\rfloor \cdot dX.u\\ t_3 := t\_2 \cdot t\_2 + t\_0 \cdot t\_0\\ t_4 := \left\lfloor h\right\rfloor \cdot dY.v\\ t_5 := t\_1 \cdot t\_1 + t\_4 \cdot t\_4\\ t_6 := \frac{1}{\sqrt{\mathsf{max}\left(t\_3, t\_5\right)}}\\ \mathbf{if}\;t\_3 \geq t\_5:\\ \;\;\;\;t\_6 \cdot t\_2\\ \mathbf{else}:\\ \;\;\;\;t\_6 \cdot t\_1\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0 (* (floor h) dX.v))
        (t_1 (* (floor w) dY.u))
        (t_2 (* (floor w) dX.u))
        (t_3 (+ (* t_2 t_2) (* t_0 t_0)))
        (t_4 (* (floor h) dY.v))
        (t_5 (+ (* t_1 t_1) (* t_4 t_4)))
        (t_6 (/ 1.0 (sqrt (fmax t_3 t_5)))))
   (if (>= t_3 t_5) (* t_6 t_2) (* t_6 t_1))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = floorf(h) * dX_46_v;
	float t_1 = floorf(w) * dY_46_u;
	float t_2 = floorf(w) * dX_46_u;
	float t_3 = (t_2 * t_2) + (t_0 * t_0);
	float t_4 = floorf(h) * dY_46_v;
	float t_5 = (t_1 * t_1) + (t_4 * t_4);
	float t_6 = 1.0f / sqrtf(fmaxf(t_3, t_5));
	float tmp;
	if (t_3 >= t_5) {
		tmp = t_6 * t_2;
	} else {
		tmp = t_6 * t_1;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = Float32(floor(h) * dX_46_v)
	t_1 = Float32(floor(w) * dY_46_u)
	t_2 = Float32(floor(w) * dX_46_u)
	t_3 = Float32(Float32(t_2 * t_2) + Float32(t_0 * t_0))
	t_4 = Float32(floor(h) * dY_46_v)
	t_5 = Float32(Float32(t_1 * t_1) + Float32(t_4 * t_4))
	t_6 = Float32(Float32(1.0) / sqrt(fmax(t_3, t_5)))
	tmp = Float32(0.0)
	if (t_3 >= t_5)
		tmp = Float32(t_6 * t_2);
	else
		tmp = Float32(t_6 * t_1);
	end
	return tmp
end
function tmp_2 = code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = floor(h) * dX_46_v;
	t_1 = floor(w) * dY_46_u;
	t_2 = floor(w) * dX_46_u;
	t_3 = (t_2 * t_2) + (t_0 * t_0);
	t_4 = floor(h) * dY_46_v;
	t_5 = (t_1 * t_1) + (t_4 * t_4);
	t_6 = single(1.0) / sqrt(max(t_3, t_5));
	tmp = single(0.0);
	if (t_3 >= t_5)
		tmp = t_6 * t_2;
	else
		tmp = t_6 * t_1;
	end
	tmp_2 = tmp;
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left\lfloor h\right\rfloor  \cdot dX.v\\
t_1 := \left\lfloor w\right\rfloor  \cdot dY.u\\
t_2 := \left\lfloor w\right\rfloor  \cdot dX.u\\
t_3 := t\_2 \cdot t\_2 + t\_0 \cdot t\_0\\
t_4 := \left\lfloor h\right\rfloor  \cdot dY.v\\
t_5 := t\_1 \cdot t\_1 + t\_4 \cdot t\_4\\
t_6 := \frac{1}{\sqrt{\mathsf{max}\left(t\_3, t\_5\right)}}\\
\mathbf{if}\;t\_3 \geq t\_5:\\
\;\;\;\;t\_6 \cdot t\_2\\

\mathbf{else}:\\
\;\;\;\;t\_6 \cdot t\_1\\


\end{array}
\end{array}

Alternative 1: 76.5% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\\ t_1 := \left\lfloor w\right\rfloor \cdot dY.u\\ t_2 := \left\lfloor h\right\rfloor \cdot dY.v\\ t_3 := \left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\\ t_4 := dX.u \cdot \left\lfloor w\right\rfloor \\ t_5 := \left\lfloor w\right\rfloor \cdot dX.u\\ t_6 := \left\lfloor h\right\rfloor \cdot dX.v\\ t_7 := t\_4 \cdot dX.u\\ t_8 := \left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u\\ \mathbf{if}\;\mathsf{fma}\left(t\_7, \left\lfloor w\right\rfloor , t\_0 \cdot \left\lfloor h\right\rfloor \right) \geq \mathsf{fma}\left(t\_3, \left\lfloor h\right\rfloor , t\_8 \cdot \left\lfloor w\right\rfloor \right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(t\_0, \left\lfloor h\right\rfloor , t\_7 \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(t\_8, \left\lfloor w\right\rfloor , t\_3 \cdot \left\lfloor h\right\rfloor \right)\right)}}{t\_4}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(t\_5 \cdot t\_5 + t\_6 \cdot t\_6, t\_1 \cdot t\_1 + t\_2 \cdot t\_2\right)}} \cdot t\_1\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0 (* (* dX.v (floor h)) dX.v))
        (t_1 (* (floor w) dY.u))
        (t_2 (* (floor h) dY.v))
        (t_3 (* (* dY.v (floor h)) dY.v))
        (t_4 (* dX.u (floor w)))
        (t_5 (* (floor w) dX.u))
        (t_6 (* (floor h) dX.v))
        (t_7 (* t_4 dX.u))
        (t_8 (* (* dY.u (floor w)) dY.u)))
   (if (>=
        (fma t_7 (floor w) (* t_0 (floor h)))
        (fma t_3 (floor h) (* t_8 (floor w))))
     (/
      1.0
      (/
       (sqrt
        (fmax
         (fma t_0 (floor h) (* t_7 (floor w)))
         (fma t_8 (floor w) (* t_3 (floor h)))))
       t_4))
     (*
      (/
       1.0
       (sqrt (fmax (+ (* t_5 t_5) (* t_6 t_6)) (+ (* t_1 t_1) (* t_2 t_2)))))
      t_1))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = (dX_46_v * floorf(h)) * dX_46_v;
	float t_1 = floorf(w) * dY_46_u;
	float t_2 = floorf(h) * dY_46_v;
	float t_3 = (dY_46_v * floorf(h)) * dY_46_v;
	float t_4 = dX_46_u * floorf(w);
	float t_5 = floorf(w) * dX_46_u;
	float t_6 = floorf(h) * dX_46_v;
	float t_7 = t_4 * dX_46_u;
	float t_8 = (dY_46_u * floorf(w)) * dY_46_u;
	float tmp;
	if (fmaf(t_7, floorf(w), (t_0 * floorf(h))) >= fmaf(t_3, floorf(h), (t_8 * floorf(w)))) {
		tmp = 1.0f / (sqrtf(fmaxf(fmaf(t_0, floorf(h), (t_7 * floorf(w))), fmaf(t_8, floorf(w), (t_3 * floorf(h))))) / t_4);
	} else {
		tmp = (1.0f / sqrtf(fmaxf(((t_5 * t_5) + (t_6 * t_6)), ((t_1 * t_1) + (t_2 * t_2))))) * t_1;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = Float32(Float32(dX_46_v * floor(h)) * dX_46_v)
	t_1 = Float32(floor(w) * dY_46_u)
	t_2 = Float32(floor(h) * dY_46_v)
	t_3 = Float32(Float32(dY_46_v * floor(h)) * dY_46_v)
	t_4 = Float32(dX_46_u * floor(w))
	t_5 = Float32(floor(w) * dX_46_u)
	t_6 = Float32(floor(h) * dX_46_v)
	t_7 = Float32(t_4 * dX_46_u)
	t_8 = Float32(Float32(dY_46_u * floor(w)) * dY_46_u)
	tmp = Float32(0.0)
	if (fma(t_7, floor(w), Float32(t_0 * floor(h))) >= fma(t_3, floor(h), Float32(t_8 * floor(w))))
		tmp = Float32(Float32(1.0) / Float32(sqrt(fmax(fma(t_0, floor(h), Float32(t_7 * floor(w))), fma(t_8, floor(w), Float32(t_3 * floor(h))))) / t_4));
	else
		tmp = Float32(Float32(Float32(1.0) / sqrt(fmax(Float32(Float32(t_5 * t_5) + Float32(t_6 * t_6)), Float32(Float32(t_1 * t_1) + Float32(t_2 * t_2))))) * t_1);
	end
	return tmp
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\\
t_1 := \left\lfloor w\right\rfloor  \cdot dY.u\\
t_2 := \left\lfloor h\right\rfloor  \cdot dY.v\\
t_3 := \left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\\
t_4 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_5 := \left\lfloor w\right\rfloor  \cdot dX.u\\
t_6 := \left\lfloor h\right\rfloor  \cdot dX.v\\
t_7 := t\_4 \cdot dX.u\\
t_8 := \left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u\\
\mathbf{if}\;\mathsf{fma}\left(t\_7, \left\lfloor w\right\rfloor , t\_0 \cdot \left\lfloor h\right\rfloor \right) \geq \mathsf{fma}\left(t\_3, \left\lfloor h\right\rfloor , t\_8 \cdot \left\lfloor w\right\rfloor \right):\\
\;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(t\_0, \left\lfloor h\right\rfloor , t\_7 \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(t\_8, \left\lfloor w\right\rfloor , t\_3 \cdot \left\lfloor h\right\rfloor \right)\right)}}{t\_4}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(t\_5 \cdot t\_5 + t\_6 \cdot t\_6, t\_1 \cdot t\_1 + t\_2 \cdot t\_2\right)}} \cdot t\_1\\


\end{array}
\end{array}
Derivation
  1. Initial program 76.4%

    \[\begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  2. Applied rewrites76.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\color{blue}{\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  3. Applied rewrites76.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\color{blue}{\mathsf{fma}\left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u, \left\lfloor w\right\rfloor , \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v, \left\lfloor h\right\rfloor , \left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u\right) \cdot \left\lfloor w\right\rfloor \right)}:\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  4. Add Preprocessing

Alternative 2: 76.5% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\ t_1 := \left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\\ t_2 := \mathsf{fma}\left(t\_1, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right)\\ t_3 := dX.u \cdot \left\lfloor w\right\rfloor \\ \mathbf{if}\;t\_2 \geq t\_0:\\ \;\;\;\;\frac{t\_3}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(t\_1, \left\lfloor h\right\rfloor , \left(t\_3 \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), t\_0\right)}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_2, t\_0\right)}} \cdot dY.u\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0
         (fma
          (* (* dY.u (floor w)) dY.u)
          (floor w)
          (* (* (* dY.v (floor h)) dY.v) (floor h))))
        (t_1 (* (* dX.v (floor h)) dX.v))
        (t_2 (fma t_1 (floor h) (* (* (* dX.u dX.u) (floor w)) (floor w))))
        (t_3 (* dX.u (floor w))))
   (if (>= t_2 t_0)
     (/ t_3 (sqrt (fmax (fma t_1 (floor h) (* (* t_3 dX.u) (floor w))) t_0)))
     (* (/ (floor w) (sqrt (fmax t_2 t_0))) dY.u))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = fmaf(((dY_46_u * floorf(w)) * dY_46_u), floorf(w), (((dY_46_v * floorf(h)) * dY_46_v) * floorf(h)));
	float t_1 = (dX_46_v * floorf(h)) * dX_46_v;
	float t_2 = fmaf(t_1, floorf(h), (((dX_46_u * dX_46_u) * floorf(w)) * floorf(w)));
	float t_3 = dX_46_u * floorf(w);
	float tmp;
	if (t_2 >= t_0) {
		tmp = t_3 / sqrtf(fmaxf(fmaf(t_1, floorf(h), ((t_3 * dX_46_u) * floorf(w))), t_0));
	} else {
		tmp = (floorf(w) / sqrtf(fmaxf(t_2, t_0))) * dY_46_u;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = fma(Float32(Float32(dY_46_u * floor(w)) * dY_46_u), floor(w), Float32(Float32(Float32(dY_46_v * floor(h)) * dY_46_v) * floor(h)))
	t_1 = Float32(Float32(dX_46_v * floor(h)) * dX_46_v)
	t_2 = fma(t_1, floor(h), Float32(Float32(Float32(dX_46_u * dX_46_u) * floor(w)) * floor(w)))
	t_3 = Float32(dX_46_u * floor(w))
	tmp = Float32(0.0)
	if (t_2 >= t_0)
		tmp = Float32(t_3 / sqrt(fmax(fma(t_1, floor(h), Float32(Float32(t_3 * dX_46_u) * floor(w))), t_0)));
	else
		tmp = Float32(Float32(floor(w) / sqrt(fmax(t_2, t_0))) * dY_46_u);
	end
	return tmp
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\
t_1 := \left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\\
t_2 := \mathsf{fma}\left(t\_1, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right)\\
t_3 := dX.u \cdot \left\lfloor w\right\rfloor \\
\mathbf{if}\;t\_2 \geq t\_0:\\
\;\;\;\;\frac{t\_3}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(t\_1, \left\lfloor h\right\rfloor , \left(t\_3 \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), t\_0\right)}}\\

\mathbf{else}:\\
\;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_2, t\_0\right)}} \cdot dY.u\\


\end{array}
\end{array}
Derivation
  1. Initial program 76.4%

    \[\begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  2. Applied rewrites76.4%

    \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ } \end{array}} \]
  3. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right)} \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\color{blue}{\left(dX.u \cdot \left\lfloor w\right\rfloor \right)} \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(dX.u \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\right)} \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(dX.u \cdot \color{blue}{\left(dX.u \cdot \left\lfloor w\right\rfloor \right)}\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.4

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\color{blue}{\left(dX.u \cdot dX.u\right)} \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  4. Applied rewrites76.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  5. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right)} \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\color{blue}{\left(dX.u \cdot \left\lfloor w\right\rfloor \right)} \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(dX.u \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\right)} \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(dX.u \cdot \color{blue}{\left(dX.u \cdot \left\lfloor w\right\rfloor \right)}\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.3

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\color{blue}{\left(dX.u \cdot dX.u\right)} \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  6. Applied rewrites76.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \color{blue}{\left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)} \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  7. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(dX.u \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(dX.u \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right)\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.3

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  8. Applied rewrites76.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  9. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\color{blue}{\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-/.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\color{blue}{\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l/N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\color{blue}{\frac{\left\lfloor w\right\rfloor \cdot dX.u}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\color{blue}{dX.u \cdot \left\lfloor w\right\rfloor }}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\color{blue}{dX.u \cdot \left\lfloor w\right\rfloor }}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lift-sqrt.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{dX.u \cdot \left\lfloor w\right\rfloor }{\color{blue}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  10. Applied rewrites76.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\color{blue}{\frac{dX.u \cdot \left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}}\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  11. Add Preprocessing

Alternative 3: 76.4% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\ t_1 := \mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)\\ t_2 := \frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_1, t\_0\right)}}\\ \mathbf{if}\;t\_1 \geq t\_0:\\ \;\;\;\;t\_2 \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;t\_2 \cdot dY.u\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0
         (fma
          (* (* dY.u (floor w)) dY.u)
          (floor w)
          (* (* (* dY.v (floor h)) dY.v) (floor h))))
        (t_1
         (fma
          (* (* dX.v (floor h)) dX.v)
          (floor h)
          (* (* (* dX.u (floor w)) dX.u) (floor w))))
        (t_2 (/ (floor w) (sqrt (fmax t_1 t_0)))))
   (if (>= t_1 t_0) (* t_2 dX.u) (* t_2 dY.u))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = fmaf(((dY_46_u * floorf(w)) * dY_46_u), floorf(w), (((dY_46_v * floorf(h)) * dY_46_v) * floorf(h)));
	float t_1 = fmaf(((dX_46_v * floorf(h)) * dX_46_v), floorf(h), (((dX_46_u * floorf(w)) * dX_46_u) * floorf(w)));
	float t_2 = floorf(w) / sqrtf(fmaxf(t_1, t_0));
	float tmp;
	if (t_1 >= t_0) {
		tmp = t_2 * dX_46_u;
	} else {
		tmp = t_2 * dY_46_u;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = fma(Float32(Float32(dY_46_u * floor(w)) * dY_46_u), floor(w), Float32(Float32(Float32(dY_46_v * floor(h)) * dY_46_v) * floor(h)))
	t_1 = fma(Float32(Float32(dX_46_v * floor(h)) * dX_46_v), floor(h), Float32(Float32(Float32(dX_46_u * floor(w)) * dX_46_u) * floor(w)))
	t_2 = Float32(floor(w) / sqrt(fmax(t_1, t_0)))
	tmp = Float32(0.0)
	if (t_1 >= t_0)
		tmp = Float32(t_2 * dX_46_u);
	else
		tmp = Float32(t_2 * dY_46_u);
	end
	return tmp
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\
t_1 := \mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)\\
t_2 := \frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_1, t\_0\right)}}\\
\mathbf{if}\;t\_1 \geq t\_0:\\
\;\;\;\;t\_2 \cdot dX.u\\

\mathbf{else}:\\
\;\;\;\;t\_2 \cdot dY.u\\


\end{array}
\end{array}
Derivation
  1. Initial program 76.4%

    \[\begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  2. Applied rewrites76.4%

    \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ } \end{array}} \]
  3. Add Preprocessing

Alternative 4: 76.3% accurate, 1.0× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\ t_1 := \mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)\\ t_2 := \frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_1, t\_0\right)}}\\ \mathbf{if}\;t\_1 \geq t\_0:\\ \;\;\;\;t\_2 \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;t\_2 \cdot dY.u\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0
         (fma
          (* (* dY.u (floor w)) dY.u)
          (floor w)
          (* (* (* dY.v (floor h)) dY.v) (floor h))))
        (t_1
         (fma
          (* (* dX.v dX.v) (floor h))
          (floor h)
          (* (* (* dX.u (floor w)) dX.u) (floor w))))
        (t_2 (/ (floor w) (sqrt (fmax t_1 t_0)))))
   (if (>= t_1 t_0) (* t_2 dX.u) (* t_2 dY.u))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = fmaf(((dY_46_u * floorf(w)) * dY_46_u), floorf(w), (((dY_46_v * floorf(h)) * dY_46_v) * floorf(h)));
	float t_1 = fmaf(((dX_46_v * dX_46_v) * floorf(h)), floorf(h), (((dX_46_u * floorf(w)) * dX_46_u) * floorf(w)));
	float t_2 = floorf(w) / sqrtf(fmaxf(t_1, t_0));
	float tmp;
	if (t_1 >= t_0) {
		tmp = t_2 * dX_46_u;
	} else {
		tmp = t_2 * dY_46_u;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = fma(Float32(Float32(dY_46_u * floor(w)) * dY_46_u), floor(w), Float32(Float32(Float32(dY_46_v * floor(h)) * dY_46_v) * floor(h)))
	t_1 = fma(Float32(Float32(dX_46_v * dX_46_v) * floor(h)), floor(h), Float32(Float32(Float32(dX_46_u * floor(w)) * dX_46_u) * floor(w)))
	t_2 = Float32(floor(w) / sqrt(fmax(t_1, t_0)))
	tmp = Float32(0.0)
	if (t_1 >= t_0)
		tmp = Float32(t_2 * dX_46_u);
	else
		tmp = Float32(t_2 * dY_46_u);
	end
	return tmp
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\\
t_1 := \mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right)\\
t_2 := \frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(t\_1, t\_0\right)}}\\
\mathbf{if}\;t\_1 \geq t\_0:\\
\;\;\;\;t\_2 \cdot dX.u\\

\mathbf{else}:\\
\;\;\;\;t\_2 \cdot dY.u\\


\end{array}
\end{array}
Derivation
  1. Initial program 76.4%

    \[\begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  2. Applied rewrites76.4%

    \[\leadsto \color{blue}{\begin{array}{l} \color{blue}{\mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ } \end{array}} \]
  3. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right)} \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{dX.v \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right)}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(dX.v \cdot \color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.4

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right)} \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  4. Applied rewrites76.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  5. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right)} \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{dX.v \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right)}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(dX.v \cdot \color{blue}{\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.3

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right)} \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  6. Applied rewrites76.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\color{blue}{\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor }, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  7. Step-by-step derivation
    1. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    2. lift-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    3. associate-*l*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(dX.v \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    4. *-commutativeN/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(dX.v \cdot \left(dX.v \cdot \left\lfloor h\right\rfloor \right), \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    5. associate-*r*N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    6. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
    7. lower-*.f3276.3

      \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  8. Applied rewrites76.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right) \geq \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right):\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dX.u\\ \mathbf{else}:\\ \;\;\;\;\frac{\left\lfloor w\right\rfloor }{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor , \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}} \cdot dY.u\\ \end{array} \]
  9. Add Preprocessing

Alternative 5: 56.4% accurate, 1.1× speedup?

\[\begin{array}{l} \\ \begin{array}{l} t_0 := \left\lfloor w\right\rfloor \cdot dY.u\\ t_1 := dX.u \cdot \left\lfloor w\right\rfloor \\ t_2 := \left\lfloor h\right\rfloor \cdot dY.v\\ t_3 := t\_0 \cdot t\_0 + t\_2 \cdot t\_2\\ t_4 := dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right)\\ \mathbf{if}\;t\_4 \geq t\_3:\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(t\_1 \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{t\_1}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(t\_4, t\_3\right)}} \cdot t\_0\\ \end{array} \end{array} \]
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
 :precision binary32
 (let* ((t_0 (* (floor w) dY.u))
        (t_1 (* dX.u (floor w)))
        (t_2 (* (floor h) dY.v))
        (t_3 (+ (* t_0 t_0) (* t_2 t_2)))
        (t_4 (* dX.u (* (fabs dX.u) (* (fabs (floor w)) (floor w))))))
   (if (>= t_4 t_3)
     (/
      1.0
      (/
       (sqrt
        (fmax
         (fma (* (* dX.v (floor h)) dX.v) (floor h) (* (* t_1 dX.u) (floor w)))
         (fma
          (* (* dY.u (floor w)) dY.u)
          (floor w)
          (* (* (* dY.v (floor h)) dY.v) (floor h)))))
       t_1))
     (* (/ 1.0 (sqrt (fmax t_4 t_3))) t_0))))
float code(float w, float h, float dX_46_u, float dX_46_v, float dY_46_u, float dY_46_v, float maxAniso) {
	float t_0 = floorf(w) * dY_46_u;
	float t_1 = dX_46_u * floorf(w);
	float t_2 = floorf(h) * dY_46_v;
	float t_3 = (t_0 * t_0) + (t_2 * t_2);
	float t_4 = dX_46_u * (fabsf(dX_46_u) * (fabsf(floorf(w)) * floorf(w)));
	float tmp;
	if (t_4 >= t_3) {
		tmp = 1.0f / (sqrtf(fmaxf(fmaf(((dX_46_v * floorf(h)) * dX_46_v), floorf(h), ((t_1 * dX_46_u) * floorf(w))), fmaf(((dY_46_u * floorf(w)) * dY_46_u), floorf(w), (((dY_46_v * floorf(h)) * dY_46_v) * floorf(h))))) / t_1);
	} else {
		tmp = (1.0f / sqrtf(fmaxf(t_4, t_3))) * t_0;
	}
	return tmp;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso)
	t_0 = Float32(floor(w) * dY_46_u)
	t_1 = Float32(dX_46_u * floor(w))
	t_2 = Float32(floor(h) * dY_46_v)
	t_3 = Float32(Float32(t_0 * t_0) + Float32(t_2 * t_2))
	t_4 = Float32(dX_46_u * Float32(abs(dX_46_u) * Float32(abs(floor(w)) * floor(w))))
	tmp = Float32(0.0)
	if (t_4 >= t_3)
		tmp = Float32(Float32(1.0) / Float32(sqrt(fmax(fma(Float32(Float32(dX_46_v * floor(h)) * dX_46_v), floor(h), Float32(Float32(t_1 * dX_46_u) * floor(w))), fma(Float32(Float32(dY_46_u * floor(w)) * dY_46_u), floor(w), Float32(Float32(Float32(dY_46_v * floor(h)) * dY_46_v) * floor(h))))) / t_1));
	else
		tmp = Float32(Float32(Float32(1.0) / sqrt(fmax(t_4, t_3))) * t_0);
	end
	return tmp
end
\begin{array}{l}

\\
\begin{array}{l}
t_0 := \left\lfloor w\right\rfloor  \cdot dY.u\\
t_1 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_2 := \left\lfloor h\right\rfloor  \cdot dY.v\\
t_3 := t\_0 \cdot t\_0 + t\_2 \cdot t\_2\\
t_4 := dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right)\\
\mathbf{if}\;t\_4 \geq t\_3:\\
\;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(t\_1 \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{t\_1}}\\

\mathbf{else}:\\
\;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(t\_4, t\_3\right)}} \cdot t\_0\\


\end{array}
\end{array}
Derivation
  1. Initial program 76.4%

    \[\begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right)\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  2. Applied rewrites76.5%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\color{blue}{\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  3. Applied rewrites68.3%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\color{blue}{\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right)} \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\left(\left\lfloor w\right\rfloor \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dX.u\right) + \left(\left\lfloor h\right\rfloor \cdot dX.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.v\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  4. Applied rewrites70.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  5. Taylor expanded in dX.u around inf

    \[\leadsto \begin{array}{l} \mathbf{if}\;\color{blue}{dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right)} \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  6. Step-by-step derivation
    1. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \color{blue}{\left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right)} \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    2. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \color{blue}{\left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)}\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    3. lower-fabs.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\color{blue}{\left|\left\lfloor w\right\rfloor \right|} \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    4. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \color{blue}{\left\lfloor w\right\rfloor }\right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    5. lower-fabs.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor \color{blue}{w}\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    6. lower-floor.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    7. lower-floor.f3256.8

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  7. Applied rewrites56.8%

    \[\leadsto \begin{array}{l} \mathbf{if}\;\color{blue}{dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right)} \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left|dX.u\right| \cdot \left(dX.u \cdot \left\lfloor w\right\rfloor \right), \left|\left\lfloor w\right\rfloor \right|, \left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  8. Taylor expanded in dX.u around inf

    \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  9. Step-by-step derivation
    1. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    2. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    3. lower-fabs.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    4. lower-*.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    5. lower-fabs.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    6. lower-floor.f32N/A

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
    7. lower-floor.f3256.4

      \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  10. Applied rewrites56.4%

    \[\leadsto \begin{array}{l} \mathbf{if}\;dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right) \geq \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right):\\ \;\;\;\;\frac{1}{\frac{\sqrt{\mathsf{max}\left(\mathsf{fma}\left(\left(dX.v \cdot \left\lfloor h\right\rfloor \right) \cdot dX.v, \left\lfloor h\right\rfloor , \left(\left(dX.u \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor w\right\rfloor \right), \mathsf{fma}\left(\left(dY.u \cdot \left\lfloor w\right\rfloor \right) \cdot dY.u, \left\lfloor w\right\rfloor , \left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot dY.v\right) \cdot \left\lfloor h\right\rfloor \right)\right)}}{dX.u \cdot \left\lfloor w\right\rfloor }}\\ \mathbf{else}:\\ \;\;\;\;\frac{1}{\sqrt{\mathsf{max}\left(dX.u \cdot \left(\left|dX.u\right| \cdot \left(\left|\left\lfloor w\right\rfloor \right| \cdot \left\lfloor w\right\rfloor \right)\right), \left(\left\lfloor w\right\rfloor \cdot dY.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right) + \left(\left\lfloor h\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dY.v\right)\right)}} \cdot \left(\left\lfloor w\right\rfloor \cdot dY.u\right)\\ \end{array} \]
  11. Add Preprocessing

Reproduce

?
herbie shell --seed 2025159 
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
  :name "Anisotropic x16 LOD (line direction, u)"
  :precision binary32
  :pre (and (and (and (and (and (and (and (<= 1.0 w) (<= w 16384.0)) (and (<= 1.0 h) (<= h 16384.0))) (and (<= 1e-20 (fabs dX.u)) (<= (fabs dX.u) 1e+20))) (and (<= 1e-20 (fabs dX.v)) (<= (fabs dX.v) 1e+20))) (and (<= 1e-20 (fabs dY.u)) (<= (fabs dY.u) 1e+20))) (and (<= 1e-20 (fabs dY.v)) (<= (fabs dY.v) 1e+20))) (== maxAniso 16.0))
  (if (>= (+ (* (* (floor w) dX.u) (* (floor w) dX.u)) (* (* (floor h) dX.v) (* (floor h) dX.v))) (+ (* (* (floor w) dY.u) (* (floor w) dY.u)) (* (* (floor h) dY.v) (* (floor h) dY.v)))) (* (/ 1.0 (sqrt (fmax (+ (* (* (floor w) dX.u) (* (floor w) dX.u)) (* (* (floor h) dX.v) (* (floor h) dX.v))) (+ (* (* (floor w) dY.u) (* (floor w) dY.u)) (* (* (floor h) dY.v) (* (floor h) dY.v)))))) (* (floor w) dX.u)) (* (/ 1.0 (sqrt (fmax (+ (* (* (floor w) dX.u) (* (floor w) dX.u)) (* (* (floor h) dX.v) (* (floor h) dX.v))) (+ (* (* (floor w) dY.u) (* (floor w) dY.u)) (* (* (floor h) dY.v) (* (floor h) dY.v)))))) (* (floor w) dY.u))))