
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (* (floor h) dX.v))
(t_1 (* (floor h) dY.v))
(t_2 (* (floor w) dY.u))
(t_3 (* (floor w) dX.u))
(t_4 (fmax (+ (* t_3 t_3) (* t_0 t_0)) (+ (* t_2 t_2) (* t_1 t_1))))
(t_5 (sqrt t_4))
(t_6 (fabs (- (* t_3 t_1) (* t_0 t_2))))
(t_7 (/ t_4 t_6))
(t_8 (> t_7 (floor maxAniso)))
(t_9 (if t_8 (/ t_5 (floor maxAniso)) (/ t_6 t_5)))
(t_10 (if t_8 (floor maxAniso) t_7)))
(if (< t_9 1.0) (fmax 1.0 (* t_10 t_9)) t_10)))
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(h) * dY_46_v;
float t_2 = floorf(w) * dY_46_u;
float t_3 = floorf(w) * dX_46_u;
float t_4 = fmaxf(((t_3 * t_3) + (t_0 * t_0)), ((t_2 * t_2) + (t_1 * t_1)));
float t_5 = sqrtf(t_4);
float t_6 = fabsf(((t_3 * t_1) - (t_0 * t_2)));
float t_7 = t_4 / t_6;
int t_8 = t_7 > floorf(maxAniso);
float tmp;
if (t_8) {
tmp = t_5 / floorf(maxAniso);
} else {
tmp = t_6 / t_5;
}
float t_9 = tmp;
float tmp_1;
if (t_8) {
tmp_1 = floorf(maxAniso);
} else {
tmp_1 = t_7;
}
float t_10 = tmp_1;
float tmp_2;
if (t_9 < 1.0f) {
tmp_2 = fmaxf(1.0f, (t_10 * t_9));
} else {
tmp_2 = t_10;
}
return tmp_2;
}
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(h) * dY_46_v) t_2 = Float32(floor(w) * dY_46_u) t_3 = Float32(floor(w) * dX_46_u) t_4 = (Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) != Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0))) ? Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) : ((Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) != Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1))) ? Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) : max(Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)), Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)))) t_5 = sqrt(t_4) t_6 = abs(Float32(Float32(t_3 * t_1) - Float32(t_0 * t_2))) t_7 = Float32(t_4 / t_6) t_8 = t_7 > floor(maxAniso) tmp = Float32(0.0) if (t_8) tmp = Float32(t_5 / floor(maxAniso)); else tmp = Float32(t_6 / t_5); end t_9 = tmp tmp_1 = Float32(0.0) if (t_8) tmp_1 = floor(maxAniso); else tmp_1 = t_7; end t_10 = tmp_1 tmp_2 = Float32(0.0) if (t_9 < Float32(1.0)) tmp_2 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * t_9) : ((Float32(t_10 * t_9) != Float32(t_10 * t_9)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * t_9))); else tmp_2 = t_10; end return tmp_2 end
function tmp_4 = 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(h) * dY_46_v; t_2 = floor(w) * dY_46_u; t_3 = floor(w) * dX_46_u; t_4 = max(((t_3 * t_3) + (t_0 * t_0)), ((t_2 * t_2) + (t_1 * t_1))); t_5 = sqrt(t_4); t_6 = abs(((t_3 * t_1) - (t_0 * t_2))); t_7 = t_4 / t_6; t_8 = t_7 > floor(maxAniso); tmp = single(0.0); if (t_8) tmp = t_5 / floor(maxAniso); else tmp = t_6 / t_5; end t_9 = tmp; tmp_2 = single(0.0); if (t_8) tmp_2 = floor(maxAniso); else tmp_2 = t_7; end t_10 = tmp_2; tmp_3 = single(0.0); if (t_9 < single(1.0)) tmp_3 = max(single(1.0), (t_10 * t_9)); else tmp_3 = t_10; end tmp_4 = tmp_3; end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_3 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_4 := \mathsf{max}\left(t\_3 \cdot t\_3 + t\_0 \cdot t\_0, t\_2 \cdot t\_2 + t\_1 \cdot t\_1\right)\\
t_5 := \sqrt{t\_4}\\
t_6 := \left|t\_3 \cdot t\_1 - t\_0 \cdot t\_2\right|\\
t_7 := \frac{t\_4}{t\_6}\\
t_8 := t\_7 > \left\lfloor maxAniso\right\rfloor \\
t_9 := \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\frac{t\_5}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_6}{t\_5}\\
\end{array}\\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\\
\mathbf{if}\;t\_9 < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot t\_9\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Sampling outcomes in binary32 precision:
Herbie found 17 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (* (floor h) dX.v))
(t_1 (* (floor h) dY.v))
(t_2 (* (floor w) dY.u))
(t_3 (* (floor w) dX.u))
(t_4 (fmax (+ (* t_3 t_3) (* t_0 t_0)) (+ (* t_2 t_2) (* t_1 t_1))))
(t_5 (sqrt t_4))
(t_6 (fabs (- (* t_3 t_1) (* t_0 t_2))))
(t_7 (/ t_4 t_6))
(t_8 (> t_7 (floor maxAniso)))
(t_9 (if t_8 (/ t_5 (floor maxAniso)) (/ t_6 t_5)))
(t_10 (if t_8 (floor maxAniso) t_7)))
(if (< t_9 1.0) (fmax 1.0 (* t_10 t_9)) t_10)))
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(h) * dY_46_v;
float t_2 = floorf(w) * dY_46_u;
float t_3 = floorf(w) * dX_46_u;
float t_4 = fmaxf(((t_3 * t_3) + (t_0 * t_0)), ((t_2 * t_2) + (t_1 * t_1)));
float t_5 = sqrtf(t_4);
float t_6 = fabsf(((t_3 * t_1) - (t_0 * t_2)));
float t_7 = t_4 / t_6;
int t_8 = t_7 > floorf(maxAniso);
float tmp;
if (t_8) {
tmp = t_5 / floorf(maxAniso);
} else {
tmp = t_6 / t_5;
}
float t_9 = tmp;
float tmp_1;
if (t_8) {
tmp_1 = floorf(maxAniso);
} else {
tmp_1 = t_7;
}
float t_10 = tmp_1;
float tmp_2;
if (t_9 < 1.0f) {
tmp_2 = fmaxf(1.0f, (t_10 * t_9));
} else {
tmp_2 = t_10;
}
return tmp_2;
}
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(h) * dY_46_v) t_2 = Float32(floor(w) * dY_46_u) t_3 = Float32(floor(w) * dX_46_u) t_4 = (Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) != Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0))) ? Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) : ((Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) != Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1))) ? Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) : max(Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)), Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)))) t_5 = sqrt(t_4) t_6 = abs(Float32(Float32(t_3 * t_1) - Float32(t_0 * t_2))) t_7 = Float32(t_4 / t_6) t_8 = t_7 > floor(maxAniso) tmp = Float32(0.0) if (t_8) tmp = Float32(t_5 / floor(maxAniso)); else tmp = Float32(t_6 / t_5); end t_9 = tmp tmp_1 = Float32(0.0) if (t_8) tmp_1 = floor(maxAniso); else tmp_1 = t_7; end t_10 = tmp_1 tmp_2 = Float32(0.0) if (t_9 < Float32(1.0)) tmp_2 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * t_9) : ((Float32(t_10 * t_9) != Float32(t_10 * t_9)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * t_9))); else tmp_2 = t_10; end return tmp_2 end
function tmp_4 = 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(h) * dY_46_v; t_2 = floor(w) * dY_46_u; t_3 = floor(w) * dX_46_u; t_4 = max(((t_3 * t_3) + (t_0 * t_0)), ((t_2 * t_2) + (t_1 * t_1))); t_5 = sqrt(t_4); t_6 = abs(((t_3 * t_1) - (t_0 * t_2))); t_7 = t_4 / t_6; t_8 = t_7 > floor(maxAniso); tmp = single(0.0); if (t_8) tmp = t_5 / floor(maxAniso); else tmp = t_6 / t_5; end t_9 = tmp; tmp_2 = single(0.0); if (t_8) tmp_2 = floor(maxAniso); else tmp_2 = t_7; end t_10 = tmp_2; tmp_3 = single(0.0); if (t_9 < single(1.0)) tmp_3 = max(single(1.0), (t_10 * t_9)); else tmp_3 = t_10; end tmp_4 = tmp_3; end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_3 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_4 := \mathsf{max}\left(t\_3 \cdot t\_3 + t\_0 \cdot t\_0, t\_2 \cdot t\_2 + t\_1 \cdot t\_1\right)\\
t_5 := \sqrt{t\_4}\\
t_6 := \left|t\_3 \cdot t\_1 - t\_0 \cdot t\_2\right|\\
t_7 := \frac{t\_4}{t\_6}\\
t_8 := t\_7 > \left\lfloor maxAniso\right\rfloor \\
t_9 := \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\frac{t\_5}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_6}{t\_5}\\
\end{array}\\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\\
\mathbf{if}\;t\_9 < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot t\_9\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\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 h) dY.v))
(t_2 (* (floor w) dY.u))
(t_3 (* (floor w) dX.u))
(t_4 (fmax (+ (* t_3 t_3) (* t_0 t_0)) (+ (* t_2 t_2) (* t_1 t_1))))
(t_5 (sqrt t_4))
(t_6 (fabs (- (* t_0 t_2) (* t_3 t_1))))
(t_7 (/ t_4 t_6))
(t_8 (> t_7 (floor maxAniso)))
(t_9 (if t_8 (/ t_5 (floor maxAniso)) (/ t_6 t_5))))
(if (< t_9 1.0)
(fmax 1.0 (* (if t_8 (floor maxAniso) t_7) t_9))
(if (>
(/
t_4
(fabs
(fma
(* (* dY.v (floor h)) (floor w))
dX.u
(* (* (- dY.u) (floor w)) (* dX.v (floor h))))))
(floor maxAniso))
(floor maxAniso)
t_7))))
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(h) * dY_46_v;
float t_2 = floorf(w) * dY_46_u;
float t_3 = floorf(w) * dX_46_u;
float t_4 = fmaxf(((t_3 * t_3) + (t_0 * t_0)), ((t_2 * t_2) + (t_1 * t_1)));
float t_5 = sqrtf(t_4);
float t_6 = fabsf(((t_0 * t_2) - (t_3 * t_1)));
float t_7 = t_4 / t_6;
int t_8 = t_7 > floorf(maxAniso);
float tmp;
if (t_8) {
tmp = t_5 / floorf(maxAniso);
} else {
tmp = t_6 / t_5;
}
float t_9 = tmp;
float tmp_2;
if (t_9 < 1.0f) {
float tmp_3;
if (t_8) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_7;
}
tmp_2 = fmaxf(1.0f, (tmp_3 * t_9));
} else if ((t_4 / fabsf(fmaf(((dY_46_v * floorf(h)) * floorf(w)), dX_46_u, ((-dY_46_u * floorf(w)) * (dX_46_v * floorf(h)))))) > floorf(maxAniso)) {
tmp_2 = floorf(maxAniso);
} else {
tmp_2 = t_7;
}
return tmp_2;
}
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(h) * dY_46_v) t_2 = Float32(floor(w) * dY_46_u) t_3 = Float32(floor(w) * dX_46_u) t_4 = (Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) != Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0))) ? Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) : ((Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)) != Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1))) ? Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)) : max(Float32(Float32(t_3 * t_3) + Float32(t_0 * t_0)), Float32(Float32(t_2 * t_2) + Float32(t_1 * t_1)))) t_5 = sqrt(t_4) t_6 = abs(Float32(Float32(t_0 * t_2) - Float32(t_3 * t_1))) t_7 = Float32(t_4 / t_6) t_8 = t_7 > floor(maxAniso) tmp = Float32(0.0) if (t_8) tmp = Float32(t_5 / floor(maxAniso)); else tmp = Float32(t_6 / t_5); end t_9 = tmp tmp_2 = Float32(0.0) if (t_9 < Float32(1.0)) tmp_3 = Float32(0.0) if (t_8) tmp_3 = floor(maxAniso); else tmp_3 = t_7; end tmp_2 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_3 * t_9) : ((Float32(tmp_3 * t_9) != Float32(tmp_3 * t_9)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_3 * t_9))); elseif (Float32(t_4 / abs(fma(Float32(Float32(dY_46_v * floor(h)) * floor(w)), dX_46_u, Float32(Float32(Float32(-dY_46_u) * floor(w)) * Float32(dX_46_v * floor(h)))))) > floor(maxAniso)) tmp_2 = floor(maxAniso); else tmp_2 = t_7; end return tmp_2 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_3 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_4 := \mathsf{max}\left(t\_3 \cdot t\_3 + t\_0 \cdot t\_0, t\_2 \cdot t\_2 + t\_1 \cdot t\_1\right)\\
t_5 := \sqrt{t\_4}\\
t_6 := \left|t\_0 \cdot t\_2 - t\_3 \cdot t\_1\right|\\
t_7 := \frac{t\_4}{t\_6}\\
t_8 := t\_7 > \left\lfloor maxAniso\right\rfloor \\
t_9 := \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\frac{t\_5}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_6}{t\_5}\\
\end{array}\\
\mathbf{if}\;t\_9 < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_8:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array} \cdot t\_9\right)\\
\mathbf{elif}\;\frac{t\_4}{\left|\mathsf{fma}\left(\left(dY.v \cdot \left\lfloor h\right\rfloor \right) \cdot \left\lfloor w\right\rfloor , dX.u, \left(\left(-dY.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left(dX.v \cdot \left\lfloor h\right\rfloor \right)\right)\right|} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}
\end{array}
Initial program 96.9%
lift--.f32N/A
lift-*.f32N/A
*-commutativeN/A
fp-cancel-sub-sign-invN/A
lift-*.f32N/A
*-commutativeN/A
lift-*.f32N/A
associate-*r*N/A
lower-fma.f32N/A
lower-*.f32N/A
lift-*.f32N/A
*-commutativeN/A
lower-*.f32N/A
lower-*.f32N/A
Applied rewrites97.7%
Final simplification97.7%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (+ (pow (* dX.v (floor h)) 2.0) (pow (* dX.u (floor w)) 2.0)))
(t_1 (* (floor w) dX.u))
(t_2 (* (floor h) dX.v))
(t_3 (pow (* dY.u (floor w)) 2.0))
(t_4 (pow (* dY.v (floor h)) 2.0))
(t_5 (fmax t_0 t_4))
(t_6 (fmax t_0 (+ t_3 t_4)))
(t_7 (/ (sqrt t_6) (floor maxAniso)))
(t_8 (* (floor w) dY.u))
(t_9 (pow t_6 -0.5))
(t_10 (* (floor h) (floor w)))
(t_11 (fmax t_0 (+ t_4 t_3)))
(t_12 (/ (sqrt t_11) (floor maxAniso)))
(t_13 (* (floor h) dY.v))
(t_14 (fabs (- (* t_2 t_8) (* t_1 t_13))))
(t_15 (fmax (+ (* t_1 t_1) (* t_2 t_2)) (+ (* t_8 t_8) (* t_13 t_13))))
(t_16 (sqrt t_15))
(t_17 (/ t_15 t_14))
(t_18 (> t_17 (floor maxAniso)))
(t_19 (if t_18 (/ t_16 (floor maxAniso)) (/ t_14 t_16)))
(t_20 (if t_18 (floor maxAniso) t_17))
(t_21 (fma dY.u dX.v (* (- dY.v) dX.u)))
(t_22 (fabs t_21))
(t_23 (* (* (pow t_11 -0.5) t_22) t_10))
(t_24 (/ t_11 (* (* t_22 (floor w)) (floor h))))
(t_25 (> t_24 (floor maxAniso)))
(t_26 (if t_25 (floor maxAniso) t_24))
(t_27 (* t_10 t_21))
(t_28 (/ t_6 t_27))
(t_29 (> t_28 (floor maxAniso)))
(t_30 (if t_29 (floor maxAniso) t_28)))
(if (<= (if (< t_19 1.0) (fmax 1.0 (* t_20 t_19)) t_20) 10.0)
(if (<
(if (> (/ t_5 t_27) (floor maxAniso))
t_7
(* (* (* (* dY.u dX.v) (floor h)) (floor w)) t_9))
1.0)
(fmax 1.0 (* (if t_29 t_7 (* t_9 t_27)) t_30))
t_30)
(if (< (if (> (/ (/ t_5 t_22) t_10) (floor maxAniso)) t_12 t_23) 1.0)
(fmax 1.0 (* (if t_25 t_12 t_23) t_26))
t_26))))
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 = powf((dX_46_v * floorf(h)), 2.0f) + powf((dX_46_u * floorf(w)), 2.0f);
float t_1 = floorf(w) * dX_46_u;
float t_2 = floorf(h) * dX_46_v;
float t_3 = powf((dY_46_u * floorf(w)), 2.0f);
float t_4 = powf((dY_46_v * floorf(h)), 2.0f);
float t_5 = fmaxf(t_0, t_4);
float t_6 = fmaxf(t_0, (t_3 + t_4));
float t_7 = sqrtf(t_6) / floorf(maxAniso);
float t_8 = floorf(w) * dY_46_u;
float t_9 = powf(t_6, -0.5f);
float t_10 = floorf(h) * floorf(w);
float t_11 = fmaxf(t_0, (t_4 + t_3));
float t_12 = sqrtf(t_11) / floorf(maxAniso);
float t_13 = floorf(h) * dY_46_v;
float t_14 = fabsf(((t_2 * t_8) - (t_1 * t_13)));
float t_15 = fmaxf(((t_1 * t_1) + (t_2 * t_2)), ((t_8 * t_8) + (t_13 * t_13)));
float t_16 = sqrtf(t_15);
float t_17 = t_15 / t_14;
int t_18 = t_17 > floorf(maxAniso);
float tmp;
if (t_18) {
tmp = t_16 / floorf(maxAniso);
} else {
tmp = t_14 / t_16;
}
float t_19 = tmp;
float tmp_1;
if (t_18) {
tmp_1 = floorf(maxAniso);
} else {
tmp_1 = t_17;
}
float t_20 = tmp_1;
float t_21 = fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u));
float t_22 = fabsf(t_21);
float t_23 = (powf(t_11, -0.5f) * t_22) * t_10;
float t_24 = t_11 / ((t_22 * floorf(w)) * floorf(h));
int t_25 = t_24 > floorf(maxAniso);
float tmp_2;
if (t_25) {
tmp_2 = floorf(maxAniso);
} else {
tmp_2 = t_24;
}
float t_26 = tmp_2;
float t_27 = t_10 * t_21;
float t_28 = t_6 / t_27;
int t_29 = t_28 > floorf(maxAniso);
float tmp_3;
if (t_29) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_28;
}
float t_30 = tmp_3;
float tmp_4;
if (t_19 < 1.0f) {
tmp_4 = fmaxf(1.0f, (t_20 * t_19));
} else {
tmp_4 = t_20;
}
float tmp_5;
if (((t_5 / t_22) / t_10) > floorf(maxAniso)) {
tmp_5 = t_12;
} else {
tmp_5 = t_23;
}
float tmp_10;
if (tmp_4 <= 10.0f) {
float tmp_11;
if ((t_5 / t_27) > floorf(maxAniso)) {
tmp_11 = t_7;
} else {
tmp_11 = (((dY_46_u * dX_46_v) * floorf(h)) * floorf(w)) * t_9;
}
float tmp_13;
if (tmp_11 < 1.0f) {
float tmp_14;
if (t_29) {
tmp_14 = t_7;
} else {
tmp_14 = t_9 * t_27;
}
tmp_13 = fmaxf(1.0f, (tmp_14 * t_30));
} else {
tmp_13 = t_30;
}
tmp_10 = tmp_13;
} else if (tmp_5 < 1.0f) {
float tmp_15;
if (t_25) {
tmp_15 = t_12;
} else {
tmp_15 = t_23;
}
tmp_10 = fmaxf(1.0f, (tmp_15 * t_26));
} else {
tmp_10 = t_26;
}
return tmp_10;
}
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)) ^ Float32(2.0)) + (Float32(dX_46_u * floor(w)) ^ Float32(2.0))) t_1 = Float32(floor(w) * dX_46_u) t_2 = Float32(floor(h) * dX_46_v) t_3 = Float32(dY_46_u * floor(w)) ^ Float32(2.0) t_4 = Float32(dY_46_v * floor(h)) ^ Float32(2.0) t_5 = (t_0 != t_0) ? t_4 : ((t_4 != t_4) ? t_0 : max(t_0, t_4)) t_6 = (t_0 != t_0) ? Float32(t_3 + t_4) : ((Float32(t_3 + t_4) != Float32(t_3 + t_4)) ? t_0 : max(t_0, Float32(t_3 + t_4))) t_7 = Float32(sqrt(t_6) / floor(maxAniso)) t_8 = Float32(floor(w) * dY_46_u) t_9 = t_6 ^ Float32(-0.5) t_10 = Float32(floor(h) * floor(w)) t_11 = (t_0 != t_0) ? Float32(t_4 + t_3) : ((Float32(t_4 + t_3) != Float32(t_4 + t_3)) ? t_0 : max(t_0, Float32(t_4 + t_3))) t_12 = Float32(sqrt(t_11) / floor(maxAniso)) t_13 = Float32(floor(h) * dY_46_v) t_14 = abs(Float32(Float32(t_2 * t_8) - Float32(t_1 * t_13))) t_15 = (Float32(Float32(t_1 * t_1) + Float32(t_2 * t_2)) != Float32(Float32(t_1 * t_1) + Float32(t_2 * t_2))) ? Float32(Float32(t_8 * t_8) + Float32(t_13 * t_13)) : ((Float32(Float32(t_8 * t_8) + Float32(t_13 * t_13)) != Float32(Float32(t_8 * t_8) + Float32(t_13 * t_13))) ? Float32(Float32(t_1 * t_1) + Float32(t_2 * t_2)) : max(Float32(Float32(t_1 * t_1) + Float32(t_2 * t_2)), Float32(Float32(t_8 * t_8) + Float32(t_13 * t_13)))) t_16 = sqrt(t_15) t_17 = Float32(t_15 / t_14) t_18 = t_17 > floor(maxAniso) tmp = Float32(0.0) if (t_18) tmp = Float32(t_16 / floor(maxAniso)); else tmp = Float32(t_14 / t_16); end t_19 = tmp tmp_1 = Float32(0.0) if (t_18) tmp_1 = floor(maxAniso); else tmp_1 = t_17; end t_20 = tmp_1 t_21 = fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) t_22 = abs(t_21) t_23 = Float32(Float32((t_11 ^ Float32(-0.5)) * t_22) * t_10) t_24 = Float32(t_11 / Float32(Float32(t_22 * floor(w)) * floor(h))) t_25 = t_24 > floor(maxAniso) tmp_2 = Float32(0.0) if (t_25) tmp_2 = floor(maxAniso); else tmp_2 = t_24; end t_26 = tmp_2 t_27 = Float32(t_10 * t_21) t_28 = Float32(t_6 / t_27) t_29 = t_28 > floor(maxAniso) tmp_3 = Float32(0.0) if (t_29) tmp_3 = floor(maxAniso); else tmp_3 = t_28; end t_30 = tmp_3 tmp_4 = Float32(0.0) if (t_19 < Float32(1.0)) tmp_4 = (Float32(1.0) != Float32(1.0)) ? Float32(t_20 * t_19) : ((Float32(t_20 * t_19) != Float32(t_20 * t_19)) ? Float32(1.0) : max(Float32(1.0), Float32(t_20 * t_19))); else tmp_4 = t_20; end tmp_5 = Float32(0.0) if (Float32(Float32(t_5 / t_22) / t_10) > floor(maxAniso)) tmp_5 = t_12; else tmp_5 = t_23; end tmp_10 = Float32(0.0) if (tmp_4 <= Float32(10.0)) tmp_11 = Float32(0.0) if (Float32(t_5 / t_27) > floor(maxAniso)) tmp_11 = t_7; else tmp_11 = Float32(Float32(Float32(Float32(dY_46_u * dX_46_v) * floor(h)) * floor(w)) * t_9); end tmp_13 = Float32(0.0) if (tmp_11 < Float32(1.0)) tmp_14 = Float32(0.0) if (t_29) tmp_14 = t_7; else tmp_14 = Float32(t_9 * t_27); end tmp_13 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_14 * t_30) : ((Float32(tmp_14 * t_30) != Float32(tmp_14 * t_30)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_14 * t_30))); else tmp_13 = t_30; end tmp_10 = tmp_13; elseif (tmp_5 < Float32(1.0)) tmp_15 = Float32(0.0) if (t_25) tmp_15 = t_12; else tmp_15 = t_23; end tmp_10 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_15 * t_26) : ((Float32(tmp_15 * t_26) != Float32(tmp_15 * t_26)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_15 * t_26))); else tmp_10 = t_26; end return tmp_10 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + {\left(dX.u \cdot \left\lfloor w\right\rfloor \right)}^{2}\\
t_1 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_2 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_3 := {\left(dY.u \cdot \left\lfloor w\right\rfloor \right)}^{2}\\
t_4 := {\left(dY.v \cdot \left\lfloor h\right\rfloor \right)}^{2}\\
t_5 := \mathsf{max}\left(t\_0, t\_4\right)\\
t_6 := \mathsf{max}\left(t\_0, t\_3 + t\_4\right)\\
t_7 := \frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
t_8 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_9 := {t\_6}^{-0.5}\\
t_10 := \left\lfloor h\right\rfloor \cdot \left\lfloor w\right\rfloor \\
t_11 := \mathsf{max}\left(t\_0, t\_4 + t\_3\right)\\
t_12 := \frac{\sqrt{t\_11}}{\left\lfloor maxAniso\right\rfloor }\\
t_13 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_14 := \left|t\_2 \cdot t\_8 - t\_1 \cdot t\_13\right|\\
t_15 := \mathsf{max}\left(t\_1 \cdot t\_1 + t\_2 \cdot t\_2, t\_8 \cdot t\_8 + t\_13 \cdot t\_13\right)\\
t_16 := \sqrt{t\_15}\\
t_17 := \frac{t\_15}{t\_14}\\
t_18 := t\_17 > \left\lfloor maxAniso\right\rfloor \\
t_19 := \begin{array}{l}
\mathbf{if}\;t\_18:\\
\;\;\;\;\frac{t\_16}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_14}{t\_16}\\
\end{array}\\
t_20 := \begin{array}{l}
\mathbf{if}\;t\_18:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_17\\
\end{array}\\
t_21 := \mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right)\\
t_22 := \left|t\_21\right|\\
t_23 := \left({t\_11}^{-0.5} \cdot t\_22\right) \cdot t\_10\\
t_24 := \frac{t\_11}{\left(t\_22 \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor h\right\rfloor }\\
t_25 := t\_24 > \left\lfloor maxAniso\right\rfloor \\
t_26 := \begin{array}{l}
\mathbf{if}\;t\_25:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_24\\
\end{array}\\
t_27 := t\_10 \cdot t\_21\\
t_28 := \frac{t\_6}{t\_27}\\
t_29 := t\_28 > \left\lfloor maxAniso\right\rfloor \\
t_30 := \begin{array}{l}
\mathbf{if}\;t\_29:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_28\\
\end{array}\\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;t\_19 < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_20 \cdot t\_19\right)\\
\mathbf{else}:\\
\;\;\;\;t\_20\\
\end{array} \leq 10:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{t\_5}{t\_27} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_7\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\left(dY.u \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \cdot t\_9\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_29:\\
\;\;\;\;t\_7\\
\mathbf{else}:\\
\;\;\;\;t\_9 \cdot t\_27\\
\end{array} \cdot t\_30\right)\\
\mathbf{else}:\\
\;\;\;\;t\_30\\
\end{array}\\
\mathbf{elif}\;\begin{array}{l}
\mathbf{if}\;\frac{\frac{t\_5}{t\_22}}{t\_10} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_12\\
\mathbf{else}:\\
\;\;\;\;t\_23\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_25:\\
\;\;\;\;t\_12\\
\mathbf{else}:\\
\;\;\;\;t\_23\\
\end{array} \cdot t\_26\right)\\
\mathbf{else}:\\
\;\;\;\;t\_26\\
\end{array}
\end{array}
if (if (<.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))) #s(literal 1 binary32)) (fmax.f32 #s(literal 1 binary32) (*.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))))) < 10Initial program 100.0%
Taylor expanded in w around 0
Applied rewrites24.7%
Taylor expanded in dY.u around 0
Applied rewrites23.5%
Taylor expanded in dX.u around 0
Applied rewrites56.3%
Applied rewrites77.1%
if 10 < (if (<.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))) #s(literal 1 binary32)) (fmax.f32 #s(literal 1 binary32) (*.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))))) Initial program 96.7%
Taylor expanded in w around 0
Applied rewrites41.4%
Taylor expanded in dY.u around 0
Applied rewrites50.7%
Applied rewrites74.1%
Final simplification75.0%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor h) 2.0))
(t_1 (* dX.u (floor w)))
(t_2 (* (floor w) dX.u))
(t_3 (* (* t_0 dY.v) dY.v))
(t_4 (* (floor h) dX.v))
(t_5 (pow (* dX.v (floor h)) 2.0))
(t_6 (+ t_5 (pow t_1 2.0)))
(t_7 (pow (* dY.v (floor h)) 2.0))
(t_8 (fmax t_6 (+ (pow (* dY.u (floor w)) 2.0) t_7)))
(t_9 (/ (sqrt t_8) (floor maxAniso)))
(t_10 (* (floor w) dY.u))
(t_11 (pow t_8 -0.5))
(t_12 (pow (floor w) 2.0))
(t_13 (fma (* t_12 dY.u) dY.u t_3))
(t_14 (fma (* t_12 dX.u) dX.u (* (* t_0 dX.v) dX.v)))
(t_15 (fmax t_14 t_13))
(t_16 (/ (sqrt t_15) (floor maxAniso)))
(t_17 (* (floor h) dY.v))
(t_18
(fmax (+ (* t_2 t_2) (* t_4 t_4)) (+ (* t_10 t_10) (* t_17 t_17))))
(t_19 (fabs (- (* t_4 t_10) (* t_2 t_17))))
(t_20 (sqrt t_18))
(t_21 (/ t_18 t_19))
(t_22 (> t_21 (floor maxAniso)))
(t_23 (if t_22 (/ t_20 (floor maxAniso)) (/ t_19 t_20)))
(t_24 (if t_22 (floor maxAniso) t_21))
(t_25 (fma dY.u dX.v (* (- dY.v) dX.u)))
(t_26 (fabs (* t_25 (* (floor w) (floor h)))))
(t_27 (/ t_15 t_26))
(t_28 (> t_27 (floor maxAniso)))
(t_29 (* (sqrt (/ 1.0 t_15)) t_26))
(t_30 (* (* (floor h) (floor w)) t_25))
(t_31 (/ t_8 t_30))
(t_32 (> t_31 (floor maxAniso)))
(t_33 (if t_32 (floor maxAniso) t_31)))
(if (<= (if (< t_23 1.0) (fmax 1.0 (* t_24 t_23)) t_24) 10.0)
(if (<
(if (> (/ (fmax t_6 t_7) t_30) (floor maxAniso))
t_9
(* (* (* (* dY.u dX.v) (floor h)) (floor w)) t_11))
1.0)
(fmax 1.0 (* (if t_32 t_9 (* t_11 t_30)) t_33))
t_33)
(if (< (if (> (/ (fmax t_14 t_3) t_26) (floor maxAniso)) t_16 t_29) 1.0)
(fmax 1.0 (* (if t_28 (floor maxAniso) t_27) (if t_28 t_16 t_29)))
(if (> (/ (fmax (+ t_5 (* t_1 t_1)) t_13) t_26) (floor maxAniso))
(floor maxAniso)
t_27)))))
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 = powf(floorf(h), 2.0f);
float t_1 = dX_46_u * floorf(w);
float t_2 = floorf(w) * dX_46_u;
float t_3 = (t_0 * dY_46_v) * dY_46_v;
float t_4 = floorf(h) * dX_46_v;
float t_5 = powf((dX_46_v * floorf(h)), 2.0f);
float t_6 = t_5 + powf(t_1, 2.0f);
float t_7 = powf((dY_46_v * floorf(h)), 2.0f);
float t_8 = fmaxf(t_6, (powf((dY_46_u * floorf(w)), 2.0f) + t_7));
float t_9 = sqrtf(t_8) / floorf(maxAniso);
float t_10 = floorf(w) * dY_46_u;
float t_11 = powf(t_8, -0.5f);
float t_12 = powf(floorf(w), 2.0f);
float t_13 = fmaf((t_12 * dY_46_u), dY_46_u, t_3);
float t_14 = fmaf((t_12 * dX_46_u), dX_46_u, ((t_0 * dX_46_v) * dX_46_v));
float t_15 = fmaxf(t_14, t_13);
float t_16 = sqrtf(t_15) / floorf(maxAniso);
float t_17 = floorf(h) * dY_46_v;
float t_18 = fmaxf(((t_2 * t_2) + (t_4 * t_4)), ((t_10 * t_10) + (t_17 * t_17)));
float t_19 = fabsf(((t_4 * t_10) - (t_2 * t_17)));
float t_20 = sqrtf(t_18);
float t_21 = t_18 / t_19;
int t_22 = t_21 > floorf(maxAniso);
float tmp;
if (t_22) {
tmp = t_20 / floorf(maxAniso);
} else {
tmp = t_19 / t_20;
}
float t_23 = tmp;
float tmp_1;
if (t_22) {
tmp_1 = floorf(maxAniso);
} else {
tmp_1 = t_21;
}
float t_24 = tmp_1;
float t_25 = fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u));
float t_26 = fabsf((t_25 * (floorf(w) * floorf(h))));
float t_27 = t_15 / t_26;
int t_28 = t_27 > floorf(maxAniso);
float t_29 = sqrtf((1.0f / t_15)) * t_26;
float t_30 = (floorf(h) * floorf(w)) * t_25;
float t_31 = t_8 / t_30;
int t_32 = t_31 > floorf(maxAniso);
float tmp_2;
if (t_32) {
tmp_2 = floorf(maxAniso);
} else {
tmp_2 = t_31;
}
float t_33 = tmp_2;
float tmp_3;
if (t_23 < 1.0f) {
tmp_3 = fmaxf(1.0f, (t_24 * t_23));
} else {
tmp_3 = t_24;
}
float tmp_4;
if ((fmaxf(t_14, t_3) / t_26) > floorf(maxAniso)) {
tmp_4 = t_16;
} else {
tmp_4 = t_29;
}
float tmp_9;
if (tmp_3 <= 10.0f) {
float tmp_10;
if ((fmaxf(t_6, t_7) / t_30) > floorf(maxAniso)) {
tmp_10 = t_9;
} else {
tmp_10 = (((dY_46_u * dX_46_v) * floorf(h)) * floorf(w)) * t_11;
}
float tmp_12;
if (tmp_10 < 1.0f) {
float tmp_13;
if (t_32) {
tmp_13 = t_9;
} else {
tmp_13 = t_11 * t_30;
}
tmp_12 = fmaxf(1.0f, (tmp_13 * t_33));
} else {
tmp_12 = t_33;
}
tmp_9 = tmp_12;
} else if (tmp_4 < 1.0f) {
float tmp_14;
if (t_28) {
tmp_14 = floorf(maxAniso);
} else {
tmp_14 = t_27;
}
float tmp_15;
if (t_28) {
tmp_15 = t_16;
} else {
tmp_15 = t_29;
}
tmp_9 = fmaxf(1.0f, (tmp_14 * tmp_15));
} else if ((fmaxf((t_5 + (t_1 * t_1)), t_13) / t_26) > floorf(maxAniso)) {
tmp_9 = floorf(maxAniso);
} else {
tmp_9 = t_27;
}
return tmp_9;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(h) ^ Float32(2.0) t_1 = Float32(dX_46_u * floor(w)) t_2 = Float32(floor(w) * dX_46_u) t_3 = Float32(Float32(t_0 * dY_46_v) * dY_46_v) t_4 = Float32(floor(h) * dX_46_v) t_5 = Float32(dX_46_v * floor(h)) ^ Float32(2.0) t_6 = Float32(t_5 + (t_1 ^ Float32(2.0))) t_7 = Float32(dY_46_v * floor(h)) ^ Float32(2.0) t_8 = (t_6 != t_6) ? Float32((Float32(dY_46_u * floor(w)) ^ Float32(2.0)) + t_7) : ((Float32((Float32(dY_46_u * floor(w)) ^ Float32(2.0)) + t_7) != Float32((Float32(dY_46_u * floor(w)) ^ Float32(2.0)) + t_7)) ? t_6 : max(t_6, Float32((Float32(dY_46_u * floor(w)) ^ Float32(2.0)) + t_7))) t_9 = Float32(sqrt(t_8) / floor(maxAniso)) t_10 = Float32(floor(w) * dY_46_u) t_11 = t_8 ^ Float32(-0.5) t_12 = floor(w) ^ Float32(2.0) t_13 = fma(Float32(t_12 * dY_46_u), dY_46_u, t_3) t_14 = fma(Float32(t_12 * dX_46_u), dX_46_u, Float32(Float32(t_0 * dX_46_v) * dX_46_v)) t_15 = (t_14 != t_14) ? t_13 : ((t_13 != t_13) ? t_14 : max(t_14, t_13)) t_16 = Float32(sqrt(t_15) / floor(maxAniso)) t_17 = Float32(floor(h) * dY_46_v) t_18 = (Float32(Float32(t_2 * t_2) + Float32(t_4 * t_4)) != Float32(Float32(t_2 * t_2) + Float32(t_4 * t_4))) ? Float32(Float32(t_10 * t_10) + Float32(t_17 * t_17)) : ((Float32(Float32(t_10 * t_10) + Float32(t_17 * t_17)) != Float32(Float32(t_10 * t_10) + Float32(t_17 * t_17))) ? Float32(Float32(t_2 * t_2) + Float32(t_4 * t_4)) : max(Float32(Float32(t_2 * t_2) + Float32(t_4 * t_4)), Float32(Float32(t_10 * t_10) + Float32(t_17 * t_17)))) t_19 = abs(Float32(Float32(t_4 * t_10) - Float32(t_2 * t_17))) t_20 = sqrt(t_18) t_21 = Float32(t_18 / t_19) t_22 = t_21 > floor(maxAniso) tmp = Float32(0.0) if (t_22) tmp = Float32(t_20 / floor(maxAniso)); else tmp = Float32(t_19 / t_20); end t_23 = tmp tmp_1 = Float32(0.0) if (t_22) tmp_1 = floor(maxAniso); else tmp_1 = t_21; end t_24 = tmp_1 t_25 = fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) t_26 = abs(Float32(t_25 * Float32(floor(w) * floor(h)))) t_27 = Float32(t_15 / t_26) t_28 = t_27 > floor(maxAniso) t_29 = Float32(sqrt(Float32(Float32(1.0) / t_15)) * t_26) t_30 = Float32(Float32(floor(h) * floor(w)) * t_25) t_31 = Float32(t_8 / t_30) t_32 = t_31 > floor(maxAniso) tmp_2 = Float32(0.0) if (t_32) tmp_2 = floor(maxAniso); else tmp_2 = t_31; end t_33 = tmp_2 tmp_3 = Float32(0.0) if (t_23 < Float32(1.0)) tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(t_24 * t_23) : ((Float32(t_24 * t_23) != Float32(t_24 * t_23)) ? Float32(1.0) : max(Float32(1.0), Float32(t_24 * t_23))); else tmp_3 = t_24; end tmp_4 = Float32(0.0) if (Float32(((t_14 != t_14) ? t_3 : ((t_3 != t_3) ? t_14 : max(t_14, t_3))) / t_26) > floor(maxAniso)) tmp_4 = t_16; else tmp_4 = t_29; end tmp_9 = Float32(0.0) if (tmp_3 <= Float32(10.0)) tmp_10 = Float32(0.0) if (Float32(((t_6 != t_6) ? t_7 : ((t_7 != t_7) ? t_6 : max(t_6, t_7))) / t_30) > floor(maxAniso)) tmp_10 = t_9; else tmp_10 = Float32(Float32(Float32(Float32(dY_46_u * dX_46_v) * floor(h)) * floor(w)) * t_11); end tmp_12 = Float32(0.0) if (tmp_10 < Float32(1.0)) tmp_13 = Float32(0.0) if (t_32) tmp_13 = t_9; else tmp_13 = Float32(t_11 * t_30); end tmp_12 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_13 * t_33) : ((Float32(tmp_13 * t_33) != Float32(tmp_13 * t_33)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_13 * t_33))); else tmp_12 = t_33; end tmp_9 = tmp_12; elseif (tmp_4 < Float32(1.0)) tmp_14 = Float32(0.0) if (t_28) tmp_14 = floor(maxAniso); else tmp_14 = t_27; end tmp_15 = Float32(0.0) if (t_28) tmp_15 = t_16; else tmp_15 = t_29; end tmp_9 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_14 * tmp_15) : ((Float32(tmp_14 * tmp_15) != Float32(tmp_14 * tmp_15)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_14 * tmp_15))); elseif (Float32(((Float32(t_5 + Float32(t_1 * t_1)) != Float32(t_5 + Float32(t_1 * t_1))) ? t_13 : ((t_13 != t_13) ? Float32(t_5 + Float32(t_1 * t_1)) : max(Float32(t_5 + Float32(t_1 * t_1)), t_13))) / t_26) > floor(maxAniso)) tmp_9 = floor(maxAniso); else tmp_9 = t_27; end return tmp_9 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_1 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_2 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_3 := \left(t\_0 \cdot dY.v\right) \cdot dY.v\\
t_4 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_5 := {\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2}\\
t_6 := t\_5 + {t\_1}^{2}\\
t_7 := {\left(dY.v \cdot \left\lfloor h\right\rfloor \right)}^{2}\\
t_8 := \mathsf{max}\left(t\_6, {\left(dY.u \cdot \left\lfloor w\right\rfloor \right)}^{2} + t\_7\right)\\
t_9 := \frac{\sqrt{t\_8}}{\left\lfloor maxAniso\right\rfloor }\\
t_10 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_11 := {t\_8}^{-0.5}\\
t_12 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_13 := \mathsf{fma}\left(t\_12 \cdot dY.u, dY.u, t\_3\right)\\
t_14 := \mathsf{fma}\left(t\_12 \cdot dX.u, dX.u, \left(t\_0 \cdot dX.v\right) \cdot dX.v\right)\\
t_15 := \mathsf{max}\left(t\_14, t\_13\right)\\
t_16 := \frac{\sqrt{t\_15}}{\left\lfloor maxAniso\right\rfloor }\\
t_17 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_18 := \mathsf{max}\left(t\_2 \cdot t\_2 + t\_4 \cdot t\_4, t\_10 \cdot t\_10 + t\_17 \cdot t\_17\right)\\
t_19 := \left|t\_4 \cdot t\_10 - t\_2 \cdot t\_17\right|\\
t_20 := \sqrt{t\_18}\\
t_21 := \frac{t\_18}{t\_19}\\
t_22 := t\_21 > \left\lfloor maxAniso\right\rfloor \\
t_23 := \begin{array}{l}
\mathbf{if}\;t\_22:\\
\;\;\;\;\frac{t\_20}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_19}{t\_20}\\
\end{array}\\
t_24 := \begin{array}{l}
\mathbf{if}\;t\_22:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_21\\
\end{array}\\
t_25 := \mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right)\\
t_26 := \left|t\_25 \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_27 := \frac{t\_15}{t\_26}\\
t_28 := t\_27 > \left\lfloor maxAniso\right\rfloor \\
t_29 := \sqrt{\frac{1}{t\_15}} \cdot t\_26\\
t_30 := \left(\left\lfloor h\right\rfloor \cdot \left\lfloor w\right\rfloor \right) \cdot t\_25\\
t_31 := \frac{t\_8}{t\_30}\\
t_32 := t\_31 > \left\lfloor maxAniso\right\rfloor \\
t_33 := \begin{array}{l}
\mathbf{if}\;t\_32:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_31\\
\end{array}\\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;t\_23 < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_24 \cdot t\_23\right)\\
\mathbf{else}:\\
\;\;\;\;t\_24\\
\end{array} \leq 10:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_6, t\_7\right)}{t\_30} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\left(dY.u \cdot dX.v\right) \cdot \left\lfloor h\right\rfloor \right) \cdot \left\lfloor w\right\rfloor \right) \cdot t\_11\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_32:\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;t\_11 \cdot t\_30\\
\end{array} \cdot t\_33\right)\\
\mathbf{else}:\\
\;\;\;\;t\_33\\
\end{array}\\
\mathbf{elif}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_14, t\_3\right)}{t\_26} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_16\\
\mathbf{else}:\\
\;\;\;\;t\_29\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_28:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_27\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_28:\\
\;\;\;\;t\_16\\
\mathbf{else}:\\
\;\;\;\;t\_29\\
\end{array}\right)\\
\mathbf{elif}\;\frac{\mathsf{max}\left(t\_5 + t\_1 \cdot t\_1, t\_13\right)}{t\_26} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_27\\
\end{array}
\end{array}
if (if (<.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))) #s(literal 1 binary32)) (fmax.f32 #s(literal 1 binary32) (*.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))))) < 10Initial program 100.0%
Taylor expanded in w around 0
Applied rewrites24.6%
Taylor expanded in dY.u around 0
Applied rewrites23.5%
Taylor expanded in dX.u around 0
Applied rewrites56.3%
Applied rewrites77.1%
if 10 < (if (<.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))) #s(literal 1 binary32)) (fmax.f32 #s(literal 1 binary32) (*.f32 (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (/.f32 (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))) (floor.f32 maxAniso)) (/.f32 (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u)))) (sqrt.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v))))))))) (if (>.f32 (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))) (floor.f32 maxAniso)) (floor.f32 maxAniso) (/.f32 (fmax.f32 (+.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 w) dX.u)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 h) dX.v))) (+.f32 (*.f32 (*.f32 (floor.f32 w) dY.u) (*.f32 (floor.f32 w) dY.u)) (*.f32 (*.f32 (floor.f32 h) dY.v) (*.f32 (floor.f32 h) dY.v)))) (fabs.f32 (-.f32 (*.f32 (*.f32 (floor.f32 w) dX.u) (*.f32 (floor.f32 h) dY.v)) (*.f32 (*.f32 (floor.f32 h) dX.v) (*.f32 (floor.f32 w) dY.u))))))) Initial program 96.7%
Taylor expanded in w around 0
Applied rewrites41.7%
Taylor expanded in dY.u around 0
Applied rewrites51.1%
Applied rewrites65.7%
Final simplification64.0%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor w) 2.0))
(t_1 (* (floor h) dY.v))
(t_2 (* (floor h) dX.v))
(t_3 (pow (floor h) 2.0))
(t_4 (* (floor w) dY.u))
(t_5 (* (floor w) dX.u))
(t_6 (fmax (+ (* t_5 t_5) (* t_2 t_2)) (+ (* t_4 t_4) (* t_1 t_1))))
(t_7 (sqrt t_6))
(t_8 (fabs (- (* t_2 t_4) (* t_5 t_1))))
(t_9 (/ t_6 t_8))
(t_10 (> t_9 (floor maxAniso)))
(t_11 (if t_10 (/ t_7 (floor maxAniso)) (/ t_8 t_7))))
(if (< t_11 1.0)
(fmax
1.0
(*
(if t_10
(floor maxAniso)
(/
(fmax
(fma (* t_0 dX.u) dX.u (* (* t_3 dX.v) dX.v))
(fma (* t_0 dY.u) dY.u (* (* t_3 dY.v) dY.v)))
(fabs
(* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h))))))
t_11))
(if (>
(/
t_6
(fabs
(fma
(* (* (- dY.u) (floor w)) (floor h))
dX.v
(* (* (* dY.v (floor w)) dX.u) (floor h)))))
(floor maxAniso))
(floor maxAniso)
t_9))))
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 = powf(floorf(w), 2.0f);
float t_1 = floorf(h) * dY_46_v;
float t_2 = floorf(h) * dX_46_v;
float t_3 = powf(floorf(h), 2.0f);
float t_4 = floorf(w) * dY_46_u;
float t_5 = floorf(w) * dX_46_u;
float t_6 = fmaxf(((t_5 * t_5) + (t_2 * t_2)), ((t_4 * t_4) + (t_1 * t_1)));
float t_7 = sqrtf(t_6);
float t_8 = fabsf(((t_2 * t_4) - (t_5 * t_1)));
float t_9 = t_6 / t_8;
int t_10 = t_9 > floorf(maxAniso);
float tmp;
if (t_10) {
tmp = t_7 / floorf(maxAniso);
} else {
tmp = t_8 / t_7;
}
float t_11 = tmp;
float tmp_2;
if (t_11 < 1.0f) {
float tmp_3;
if (t_10) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = fmaxf(fmaf((t_0 * dX_46_u), dX_46_u, ((t_3 * dX_46_v) * dX_46_v)), fmaf((t_0 * dY_46_u), dY_46_u, ((t_3 * dY_46_v) * dY_46_v))) / fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
}
tmp_2 = fmaxf(1.0f, (tmp_3 * t_11));
} else if ((t_6 / fabsf(fmaf(((-dY_46_u * floorf(w)) * floorf(h)), dX_46_v, (((dY_46_v * floorf(w)) * dX_46_u) * floorf(h))))) > floorf(maxAniso)) {
tmp_2 = floorf(maxAniso);
} else {
tmp_2 = t_9;
}
return tmp_2;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(w) ^ Float32(2.0) t_1 = Float32(floor(h) * dY_46_v) t_2 = Float32(floor(h) * dX_46_v) t_3 = floor(h) ^ Float32(2.0) t_4 = Float32(floor(w) * dY_46_u) t_5 = Float32(floor(w) * dX_46_u) t_6 = (Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)) != Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2))) ? Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)) : ((Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)) != Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1))) ? Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)) : max(Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)), Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)))) t_7 = sqrt(t_6) t_8 = abs(Float32(Float32(t_2 * t_4) - Float32(t_5 * t_1))) t_9 = Float32(t_6 / t_8) t_10 = t_9 > floor(maxAniso) tmp = Float32(0.0) if (t_10) tmp = Float32(t_7 / floor(maxAniso)); else tmp = Float32(t_8 / t_7); end t_11 = tmp tmp_2 = Float32(0.0) if (t_11 < Float32(1.0)) tmp_3 = Float32(0.0) if (t_10) tmp_3 = floor(maxAniso); else tmp_3 = Float32(((fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)) != fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v))) ? fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v)) : ((fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v)) != fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v))) ? fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)) : max(fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)), fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v))))) / abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h))))); end tmp_2 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_3 * t_11) : ((Float32(tmp_3 * t_11) != Float32(tmp_3 * t_11)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_3 * t_11))); elseif (Float32(t_6 / abs(fma(Float32(Float32(Float32(-dY_46_u) * floor(w)) * floor(h)), dX_46_v, Float32(Float32(Float32(dY_46_v * floor(w)) * dX_46_u) * floor(h))))) > floor(maxAniso)) tmp_2 = floor(maxAniso); else tmp_2 = t_9; end return tmp_2 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_3 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_4 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_5 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_6 := \mathsf{max}\left(t\_5 \cdot t\_5 + t\_2 \cdot t\_2, t\_4 \cdot t\_4 + t\_1 \cdot t\_1\right)\\
t_7 := \sqrt{t\_6}\\
t_8 := \left|t\_2 \cdot t\_4 - t\_5 \cdot t\_1\right|\\
t_9 := \frac{t\_6}{t\_8}\\
t_10 := t\_9 > \left\lfloor maxAniso\right\rfloor \\
t_11 := \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\frac{t\_7}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_8}{t\_7}\\
\end{array}\\
\mathbf{if}\;t\_11 < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{max}\left(\mathsf{fma}\left(t\_0 \cdot dX.u, dX.u, \left(t\_3 \cdot dX.v\right) \cdot dX.v\right), \mathsf{fma}\left(t\_0 \cdot dY.u, dY.u, \left(t\_3 \cdot dY.v\right) \cdot dY.v\right)\right)}{\left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|}\\
\end{array} \cdot t\_11\right)\\
\mathbf{elif}\;\frac{t\_6}{\left|\mathsf{fma}\left(\left(\left(-dY.u\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor h\right\rfloor , dX.v, \left(\left(dY.v \cdot \left\lfloor w\right\rfloor \right) \cdot dX.u\right) \cdot \left\lfloor h\right\rfloor \right)\right|} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
lift--.f32N/A
lift-*.f32N/A
*-commutativeN/A
fp-cancel-sub-sign-invN/A
lift-*.f32N/A
*-commutativeN/A
distribute-lft-neg-outN/A
lift-neg.f32N/A
lift-*.f32N/A
lift-*.f32N/A
*-commutativeN/A
lift-*.f32N/A
lift-*.f32N/A
+-commutativeN/A
Applied rewrites97.2%
Final simplification97.2%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor w) 2.0))
(t_1 (* (floor h) dY.v))
(t_2 (* (floor h) dX.v))
(t_3 (pow (floor h) 2.0))
(t_4 (* (floor w) dY.u))
(t_5 (* (floor w) dX.u))
(t_6 (fmax (+ (* t_5 t_5) (* t_2 t_2)) (+ (* t_4 t_4) (* t_1 t_1))))
(t_7 (sqrt t_6))
(t_8 (fabs (- (* t_2 t_4) (* t_5 t_1))))
(t_9 (/ t_6 t_8))
(t_10 (> t_9 (floor maxAniso)))
(t_11 (if t_10 (/ t_7 (floor maxAniso)) (/ t_8 t_7))))
(if (< t_11 1.0)
(fmax
1.0
(*
(if t_10
(floor maxAniso)
(/
(fmax
(fma (* t_0 dX.u) dX.u (* (* t_3 dX.v) dX.v))
(fma (* t_0 dY.u) dY.u (* (* t_3 dY.v) dY.v)))
(fabs
(* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h))))))
t_11))
(if t_10 (floor maxAniso) t_9))))
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 = powf(floorf(w), 2.0f);
float t_1 = floorf(h) * dY_46_v;
float t_2 = floorf(h) * dX_46_v;
float t_3 = powf(floorf(h), 2.0f);
float t_4 = floorf(w) * dY_46_u;
float t_5 = floorf(w) * dX_46_u;
float t_6 = fmaxf(((t_5 * t_5) + (t_2 * t_2)), ((t_4 * t_4) + (t_1 * t_1)));
float t_7 = sqrtf(t_6);
float t_8 = fabsf(((t_2 * t_4) - (t_5 * t_1)));
float t_9 = t_6 / t_8;
int t_10 = t_9 > floorf(maxAniso);
float tmp;
if (t_10) {
tmp = t_7 / floorf(maxAniso);
} else {
tmp = t_8 / t_7;
}
float t_11 = tmp;
float tmp_2;
if (t_11 < 1.0f) {
float tmp_3;
if (t_10) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = fmaxf(fmaf((t_0 * dX_46_u), dX_46_u, ((t_3 * dX_46_v) * dX_46_v)), fmaf((t_0 * dY_46_u), dY_46_u, ((t_3 * dY_46_v) * dY_46_v))) / fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
}
tmp_2 = fmaxf(1.0f, (tmp_3 * t_11));
} else if (t_10) {
tmp_2 = floorf(maxAniso);
} else {
tmp_2 = t_9;
}
return tmp_2;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(w) ^ Float32(2.0) t_1 = Float32(floor(h) * dY_46_v) t_2 = Float32(floor(h) * dX_46_v) t_3 = floor(h) ^ Float32(2.0) t_4 = Float32(floor(w) * dY_46_u) t_5 = Float32(floor(w) * dX_46_u) t_6 = (Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)) != Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2))) ? Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)) : ((Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)) != Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1))) ? Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)) : max(Float32(Float32(t_5 * t_5) + Float32(t_2 * t_2)), Float32(Float32(t_4 * t_4) + Float32(t_1 * t_1)))) t_7 = sqrt(t_6) t_8 = abs(Float32(Float32(t_2 * t_4) - Float32(t_5 * t_1))) t_9 = Float32(t_6 / t_8) t_10 = t_9 > floor(maxAniso) tmp = Float32(0.0) if (t_10) tmp = Float32(t_7 / floor(maxAniso)); else tmp = Float32(t_8 / t_7); end t_11 = tmp tmp_2 = Float32(0.0) if (t_11 < Float32(1.0)) tmp_3 = Float32(0.0) if (t_10) tmp_3 = floor(maxAniso); else tmp_3 = Float32(((fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)) != fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v))) ? fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v)) : ((fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v)) != fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v))) ? fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)) : max(fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)), fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_3 * dY_46_v) * dY_46_v))))) / abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h))))); end tmp_2 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_3 * t_11) : ((Float32(tmp_3 * t_11) != Float32(tmp_3 * t_11)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_3 * t_11))); elseif (t_10) tmp_2 = floor(maxAniso); else tmp_2 = t_9; end return tmp_2 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_3 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_4 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_5 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_6 := \mathsf{max}\left(t\_5 \cdot t\_5 + t\_2 \cdot t\_2, t\_4 \cdot t\_4 + t\_1 \cdot t\_1\right)\\
t_7 := \sqrt{t\_6}\\
t_8 := \left|t\_2 \cdot t\_4 - t\_5 \cdot t\_1\right|\\
t_9 := \frac{t\_6}{t\_8}\\
t_10 := t\_9 > \left\lfloor maxAniso\right\rfloor \\
t_11 := \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\frac{t\_7}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_8}{t\_7}\\
\end{array}\\
\mathbf{if}\;t\_11 < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;\frac{\mathsf{max}\left(\mathsf{fma}\left(t\_0 \cdot dX.u, dX.u, \left(t\_3 \cdot dX.v\right) \cdot dX.v\right), \mathsf{fma}\left(t\_0 \cdot dY.u, dY.u, \left(t\_3 \cdot dY.v\right) \cdot dY.v\right)\right)}{\left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|}\\
\end{array} \cdot t\_11\right)\\
\mathbf{elif}\;t\_10:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
Final simplification96.9%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor w) 2.0))
(t_1 (* (floor h) dX.v))
(t_2 (pow (floor h) 2.0))
(t_3 (* (floor w) dY.u))
(t_4 (* (floor h) dY.v))
(t_5
(fmax
(fma (* t_0 dX.u) dX.u (* (* t_2 dX.v) dX.v))
(fma (* t_0 dY.u) dY.u (* (* t_2 dY.v) dY.v))))
(t_6 (* (floor w) dX.u))
(t_7 (fmax (+ (* t_6 t_6) (* t_1 t_1)) (+ (* t_3 t_3) (* t_4 t_4))))
(t_8 (sqrt t_7))
(t_9 (/ t_8 (floor maxAniso)))
(t_10 (fabs (- (* t_1 t_3) (* t_6 t_4))))
(t_11 (/ t_7 t_10))
(t_12 (> t_11 (floor maxAniso))))
(if (< (if t_12 t_9 (/ t_10 t_8)) 1.0)
(fmax
1.0
(*
(if t_12
(floor maxAniso)
(/
t_5
(fabs
(* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h))))))
(if (>
(/
t_5
(fabs
(* (* (- (* dY.v dX.u) (* dY.u dX.v)) (floor w)) (floor h))))
(floor maxAniso))
t_9
(/ (fabs (* (* (floor w) dY.v) (* (floor h) dX.u))) t_8))))
(if t_12 (floor maxAniso) t_11))))
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 = powf(floorf(w), 2.0f);
float t_1 = floorf(h) * dX_46_v;
float t_2 = powf(floorf(h), 2.0f);
float t_3 = floorf(w) * dY_46_u;
float t_4 = floorf(h) * dY_46_v;
float t_5 = fmaxf(fmaf((t_0 * dX_46_u), dX_46_u, ((t_2 * dX_46_v) * dX_46_v)), fmaf((t_0 * dY_46_u), dY_46_u, ((t_2 * dY_46_v) * dY_46_v)));
float t_6 = floorf(w) * dX_46_u;
float t_7 = fmaxf(((t_6 * t_6) + (t_1 * t_1)), ((t_3 * t_3) + (t_4 * t_4)));
float t_8 = sqrtf(t_7);
float t_9 = t_8 / floorf(maxAniso);
float t_10 = fabsf(((t_1 * t_3) - (t_6 * t_4)));
float t_11 = t_7 / t_10;
int t_12 = t_11 > floorf(maxAniso);
float tmp;
if (t_12) {
tmp = t_9;
} else {
tmp = t_10 / t_8;
}
float tmp_3;
if (tmp < 1.0f) {
float tmp_4;
if (t_12) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_5 / fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
}
float tmp_5;
if ((t_5 / fabsf(((((dY_46_v * dX_46_u) - (dY_46_u * dX_46_v)) * floorf(w)) * floorf(h)))) > floorf(maxAniso)) {
tmp_5 = t_9;
} else {
tmp_5 = fabsf(((floorf(w) * dY_46_v) * (floorf(h) * dX_46_u))) / t_8;
}
tmp_3 = fmaxf(1.0f, (tmp_4 * tmp_5));
} else if (t_12) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_11;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(w) ^ Float32(2.0) t_1 = Float32(floor(h) * dX_46_v) t_2 = floor(h) ^ Float32(2.0) t_3 = Float32(floor(w) * dY_46_u) t_4 = Float32(floor(h) * dY_46_v) t_5 = (fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_2 * dX_46_v) * dX_46_v)) != fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_2 * dX_46_v) * dX_46_v))) ? fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_2 * dY_46_v) * dY_46_v)) : ((fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_2 * dY_46_v) * dY_46_v)) != fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_2 * dY_46_v) * dY_46_v))) ? fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_2 * dX_46_v) * dX_46_v)) : max(fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_2 * dX_46_v) * dX_46_v)), fma(Float32(t_0 * dY_46_u), dY_46_u, Float32(Float32(t_2 * dY_46_v) * dY_46_v)))) t_6 = Float32(floor(w) * dX_46_u) t_7 = (Float32(Float32(t_6 * t_6) + Float32(t_1 * t_1)) != Float32(Float32(t_6 * t_6) + Float32(t_1 * t_1))) ? Float32(Float32(t_3 * t_3) + Float32(t_4 * t_4)) : ((Float32(Float32(t_3 * t_3) + Float32(t_4 * t_4)) != Float32(Float32(t_3 * t_3) + Float32(t_4 * t_4))) ? Float32(Float32(t_6 * t_6) + Float32(t_1 * t_1)) : max(Float32(Float32(t_6 * t_6) + Float32(t_1 * t_1)), Float32(Float32(t_3 * t_3) + Float32(t_4 * t_4)))) t_8 = sqrt(t_7) t_9 = Float32(t_8 / floor(maxAniso)) t_10 = abs(Float32(Float32(t_1 * t_3) - Float32(t_6 * t_4))) t_11 = Float32(t_7 / t_10) t_12 = t_11 > floor(maxAniso) tmp = Float32(0.0) if (t_12) tmp = t_9; else tmp = Float32(t_10 / t_8); end tmp_3 = Float32(0.0) if (tmp < Float32(1.0)) tmp_4 = Float32(0.0) if (t_12) tmp_4 = floor(maxAniso); else tmp_4 = Float32(t_5 / abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h))))); end tmp_5 = Float32(0.0) if (Float32(t_5 / abs(Float32(Float32(Float32(Float32(dY_46_v * dX_46_u) - Float32(dY_46_u * dX_46_v)) * floor(w)) * floor(h)))) > floor(maxAniso)) tmp_5 = t_9; else tmp_5 = Float32(abs(Float32(Float32(floor(w) * dY_46_v) * Float32(floor(h) * dX_46_u))) / t_8); end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_4 * tmp_5) : ((Float32(tmp_4 * tmp_5) != Float32(tmp_4 * tmp_5)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_4 * tmp_5))); elseif (t_12) tmp_3 = floor(maxAniso); else tmp_3 = t_11; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_1 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_2 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_3 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_4 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_5 := \mathsf{max}\left(\mathsf{fma}\left(t\_0 \cdot dX.u, dX.u, \left(t\_2 \cdot dX.v\right) \cdot dX.v\right), \mathsf{fma}\left(t\_0 \cdot dY.u, dY.u, \left(t\_2 \cdot dY.v\right) \cdot dY.v\right)\right)\\
t_6 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_7 := \mathsf{max}\left(t\_6 \cdot t\_6 + t\_1 \cdot t\_1, t\_3 \cdot t\_3 + t\_4 \cdot t\_4\right)\\
t_8 := \sqrt{t\_7}\\
t_9 := \frac{t\_8}{\left\lfloor maxAniso\right\rfloor }\\
t_10 := \left|t\_1 \cdot t\_3 - t\_6 \cdot t\_4\right|\\
t_11 := \frac{t\_7}{t\_10}\\
t_12 := t\_11 > \left\lfloor maxAniso\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;t\_12:\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_10}{t\_8}\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_12:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;\frac{t\_5}{\left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|}\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;\frac{t\_5}{\left|\left(\left(dY.v \cdot dX.u - dY.u \cdot dX.v\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor h\right\rfloor \right|} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;\frac{\left|\left(\left\lfloor w\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.u\right)\right|}{t\_8}\\
\end{array}\right)\\
\mathbf{elif}\;t\_12:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_11\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
Taylor expanded in dX.u around inf
*-commutativeN/A
associate-*r*N/A
associate-*r*N/A
associate-*l*N/A
*-commutativeN/A
lower-*.f32N/A
lower-*.f32N/A
lower-floor.f32N/A
*-commutativeN/A
lower-*.f32N/A
lower-floor.f3296.9
Applied rewrites96.9%
Final simplification96.9%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor h) 2.0))
(t_1 (* (floor h) dY.v))
(t_2 (* (floor h) dX.v))
(t_3 (pow (floor w) 2.0))
(t_4
(fmax
(fma (* t_3 dX.u) dX.u (* (* t_0 dX.v) dX.v))
(fma (* t_3 dY.u) dY.u (* (* t_0 dY.v) dY.v))))
(t_5 (* (floor w) dY.u))
(t_6 (* (floor w) dX.u))
(t_7 (fmax (+ (* t_6 t_6) (* t_2 t_2)) (+ (* t_5 t_5) (* t_1 t_1))))
(t_8 (sqrt t_7))
(t_9 (/ t_8 (floor maxAniso)))
(t_10 (fabs (- (* t_2 t_5) (* t_6 t_1))))
(t_11 (/ t_7 t_10))
(t_12 (> t_11 (floor maxAniso))))
(if (<
(if t_12 t_9 (/ (fabs (* (* (floor w) dY.v) (* (floor h) dX.u))) t_8))
1.0)
(fmax
1.0
(*
(if t_12
(floor maxAniso)
(/
t_4
(fabs
(* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h))))))
(if (>
(/
t_4
(fabs
(* (* (- (* dY.v dX.u) (* dY.u dX.v)) (floor w)) (floor h))))
(floor maxAniso))
t_9
(/ t_10 t_8))))
(if t_12 (floor maxAniso) t_11))))
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 = powf(floorf(h), 2.0f);
float t_1 = floorf(h) * dY_46_v;
float t_2 = floorf(h) * dX_46_v;
float t_3 = powf(floorf(w), 2.0f);
float t_4 = fmaxf(fmaf((t_3 * dX_46_u), dX_46_u, ((t_0 * dX_46_v) * dX_46_v)), fmaf((t_3 * dY_46_u), dY_46_u, ((t_0 * dY_46_v) * dY_46_v)));
float t_5 = floorf(w) * dY_46_u;
float t_6 = floorf(w) * dX_46_u;
float t_7 = fmaxf(((t_6 * t_6) + (t_2 * t_2)), ((t_5 * t_5) + (t_1 * t_1)));
float t_8 = sqrtf(t_7);
float t_9 = t_8 / floorf(maxAniso);
float t_10 = fabsf(((t_2 * t_5) - (t_6 * t_1)));
float t_11 = t_7 / t_10;
int t_12 = t_11 > floorf(maxAniso);
float tmp;
if (t_12) {
tmp = t_9;
} else {
tmp = fabsf(((floorf(w) * dY_46_v) * (floorf(h) * dX_46_u))) / t_8;
}
float tmp_3;
if (tmp < 1.0f) {
float tmp_4;
if (t_12) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_4 / fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
}
float tmp_5;
if ((t_4 / fabsf(((((dY_46_v * dX_46_u) - (dY_46_u * dX_46_v)) * floorf(w)) * floorf(h)))) > floorf(maxAniso)) {
tmp_5 = t_9;
} else {
tmp_5 = t_10 / t_8;
}
tmp_3 = fmaxf(1.0f, (tmp_4 * tmp_5));
} else if (t_12) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_11;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(h) ^ Float32(2.0) t_1 = Float32(floor(h) * dY_46_v) t_2 = Float32(floor(h) * dX_46_v) t_3 = floor(w) ^ Float32(2.0) t_4 = (fma(Float32(t_3 * dX_46_u), dX_46_u, Float32(Float32(t_0 * dX_46_v) * dX_46_v)) != fma(Float32(t_3 * dX_46_u), dX_46_u, Float32(Float32(t_0 * dX_46_v) * dX_46_v))) ? fma(Float32(t_3 * dY_46_u), dY_46_u, Float32(Float32(t_0 * dY_46_v) * dY_46_v)) : ((fma(Float32(t_3 * dY_46_u), dY_46_u, Float32(Float32(t_0 * dY_46_v) * dY_46_v)) != fma(Float32(t_3 * dY_46_u), dY_46_u, Float32(Float32(t_0 * dY_46_v) * dY_46_v))) ? fma(Float32(t_3 * dX_46_u), dX_46_u, Float32(Float32(t_0 * dX_46_v) * dX_46_v)) : max(fma(Float32(t_3 * dX_46_u), dX_46_u, Float32(Float32(t_0 * dX_46_v) * dX_46_v)), fma(Float32(t_3 * dY_46_u), dY_46_u, Float32(Float32(t_0 * dY_46_v) * dY_46_v)))) t_5 = Float32(floor(w) * dY_46_u) t_6 = Float32(floor(w) * dX_46_u) t_7 = (Float32(Float32(t_6 * t_6) + Float32(t_2 * t_2)) != Float32(Float32(t_6 * t_6) + Float32(t_2 * t_2))) ? Float32(Float32(t_5 * t_5) + Float32(t_1 * t_1)) : ((Float32(Float32(t_5 * t_5) + Float32(t_1 * t_1)) != Float32(Float32(t_5 * t_5) + Float32(t_1 * t_1))) ? Float32(Float32(t_6 * t_6) + Float32(t_2 * t_2)) : max(Float32(Float32(t_6 * t_6) + Float32(t_2 * t_2)), Float32(Float32(t_5 * t_5) + Float32(t_1 * t_1)))) t_8 = sqrt(t_7) t_9 = Float32(t_8 / floor(maxAniso)) t_10 = abs(Float32(Float32(t_2 * t_5) - Float32(t_6 * t_1))) t_11 = Float32(t_7 / t_10) t_12 = t_11 > floor(maxAniso) tmp = Float32(0.0) if (t_12) tmp = t_9; else tmp = Float32(abs(Float32(Float32(floor(w) * dY_46_v) * Float32(floor(h) * dX_46_u))) / t_8); end tmp_3 = Float32(0.0) if (tmp < Float32(1.0)) tmp_4 = Float32(0.0) if (t_12) tmp_4 = floor(maxAniso); else tmp_4 = Float32(t_4 / abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h))))); end tmp_5 = Float32(0.0) if (Float32(t_4 / abs(Float32(Float32(Float32(Float32(dY_46_v * dX_46_u) - Float32(dY_46_u * dX_46_v)) * floor(w)) * floor(h)))) > floor(maxAniso)) tmp_5 = t_9; else tmp_5 = Float32(t_10 / t_8); end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_4 * tmp_5) : ((Float32(tmp_4 * tmp_5) != Float32(tmp_4 * tmp_5)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_4 * tmp_5))); elseif (t_12) tmp_3 = floor(maxAniso); else tmp_3 = t_11; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_1 := \left\lfloor h\right\rfloor \cdot dY.v\\
t_2 := \left\lfloor h\right\rfloor \cdot dX.v\\
t_3 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_4 := \mathsf{max}\left(\mathsf{fma}\left(t\_3 \cdot dX.u, dX.u, \left(t\_0 \cdot dX.v\right) \cdot dX.v\right), \mathsf{fma}\left(t\_3 \cdot dY.u, dY.u, \left(t\_0 \cdot dY.v\right) \cdot dY.v\right)\right)\\
t_5 := \left\lfloor w\right\rfloor \cdot dY.u\\
t_6 := \left\lfloor w\right\rfloor \cdot dX.u\\
t_7 := \mathsf{max}\left(t\_6 \cdot t\_6 + t\_2 \cdot t\_2, t\_5 \cdot t\_5 + t\_1 \cdot t\_1\right)\\
t_8 := \sqrt{t\_7}\\
t_9 := \frac{t\_8}{\left\lfloor maxAniso\right\rfloor }\\
t_10 := \left|t\_2 \cdot t\_5 - t\_6 \cdot t\_1\right|\\
t_11 := \frac{t\_7}{t\_10}\\
t_12 := t\_11 > \left\lfloor maxAniso\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;t\_12:\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;\frac{\left|\left(\left\lfloor w\right\rfloor \cdot dY.v\right) \cdot \left(\left\lfloor h\right\rfloor \cdot dX.u\right)\right|}{t\_8}\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_12:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;\frac{t\_4}{\left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|}\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;\frac{t\_4}{\left|\left(\left(dY.v \cdot dX.u - dY.u \cdot dX.v\right) \cdot \left\lfloor w\right\rfloor \right) \cdot \left\lfloor h\right\rfloor \right|} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_9\\
\mathbf{else}:\\
\;\;\;\;\frac{t\_10}{t\_8}\\
\end{array}\right)\\
\mathbf{elif}\;t\_12:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_11\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
Taylor expanded in w around 0
Applied rewrites96.9%
Taylor expanded in dX.u around inf
*-commutativeN/A
associate-*r*N/A
associate-*r*N/A
associate-*l*N/A
*-commutativeN/A
lower-*.f32N/A
lower-*.f32N/A
lower-floor.f32N/A
*-commutativeN/A
lower-*.f32N/A
lower-floor.f3296.8
Applied rewrites96.8%
Final simplification96.8%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (* dX.u (floor w)))
(t_1 (pow (floor h) 2.0))
(t_2 (* (* t_1 dY.v) dY.v))
(t_3 (* dY.v (floor h)))
(t_4 (pow (floor w) 2.0))
(t_5 (* t_4 dX.u))
(t_6 (fma t_5 dX.u (* (* t_1 dX.v) dX.v)))
(t_7
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_8 (* dY.u (floor w)))
(t_9 (fma (* t_4 dY.u) dY.u t_2))
(t_10 (fmax t_6 t_9))
(t_11 (/ (sqrt t_10) (floor maxAniso)))
(t_12 (/ t_10 t_7))
(t_13 (* (sqrt (/ 1.0 t_10)) t_7))
(t_14 (> t_12 (floor maxAniso)))
(t_15 (if t_14 (floor maxAniso) t_12))
(t_16 (if t_14 t_11 t_13)))
(if (<= dY.u -1.999999943436137e-9)
(if (< t_16 1.0)
(fmax
1.0
(*
t_15
(if (> (/ (fmax (* t_5 dX.u) t_9) t_7) (floor maxAniso)) t_11 t_13)))
(if (>
(/
(fmax
t_6
(/
(- (pow t_3 4.0) (pow t_8 4.0))
(- (pow t_3 2.0) (pow t_8 2.0))))
t_7)
(floor maxAniso))
(floor maxAniso)
t_12))
(if (< (if (> (/ (fmax t_6 t_2) t_7) (floor maxAniso)) t_11 t_13) 1.0)
(fmax 1.0 (* t_15 t_16))
(if (>
(/ (fmax (+ (pow (* dX.v (floor h)) 2.0) (* t_0 t_0)) t_9) t_7)
(floor maxAniso))
(floor maxAniso)
t_12)))))
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_u * floorf(w);
float t_1 = powf(floorf(h), 2.0f);
float t_2 = (t_1 * dY_46_v) * dY_46_v;
float t_3 = dY_46_v * floorf(h);
float t_4 = powf(floorf(w), 2.0f);
float t_5 = t_4 * dX_46_u;
float t_6 = fmaf(t_5, dX_46_u, ((t_1 * dX_46_v) * dX_46_v));
float t_7 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_8 = dY_46_u * floorf(w);
float t_9 = fmaf((t_4 * dY_46_u), dY_46_u, t_2);
float t_10 = fmaxf(t_6, t_9);
float t_11 = sqrtf(t_10) / floorf(maxAniso);
float t_12 = t_10 / t_7;
float t_13 = sqrtf((1.0f / t_10)) * t_7;
int t_14 = t_12 > floorf(maxAniso);
float tmp;
if (t_14) {
tmp = floorf(maxAniso);
} else {
tmp = t_12;
}
float t_15 = tmp;
float tmp_1;
if (t_14) {
tmp_1 = t_11;
} else {
tmp_1 = t_13;
}
float t_16 = tmp_1;
float tmp_2;
if ((fmaxf(t_6, t_2) / t_7) > floorf(maxAniso)) {
tmp_2 = t_11;
} else {
tmp_2 = t_13;
}
float tmp_6;
if (dY_46_u <= -1.999999943436137e-9f) {
float tmp_8;
if (t_16 < 1.0f) {
float tmp_9;
if ((fmaxf((t_5 * dX_46_u), t_9) / t_7) > floorf(maxAniso)) {
tmp_9 = t_11;
} else {
tmp_9 = t_13;
}
tmp_8 = fmaxf(1.0f, (t_15 * tmp_9));
} else if ((fmaxf(t_6, ((powf(t_3, 4.0f) - powf(t_8, 4.0f)) / (powf(t_3, 2.0f) - powf(t_8, 2.0f)))) / t_7) > floorf(maxAniso)) {
tmp_8 = floorf(maxAniso);
} else {
tmp_8 = t_12;
}
tmp_6 = tmp_8;
} else if (tmp_2 < 1.0f) {
tmp_6 = fmaxf(1.0f, (t_15 * t_16));
} else if ((fmaxf((powf((dX_46_v * floorf(h)), 2.0f) + (t_0 * t_0)), t_9) / t_7) > floorf(maxAniso)) {
tmp_6 = floorf(maxAniso);
} else {
tmp_6 = t_12;
}
return tmp_6;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = Float32(dX_46_u * floor(w)) t_1 = floor(h) ^ Float32(2.0) t_2 = Float32(Float32(t_1 * dY_46_v) * dY_46_v) t_3 = Float32(dY_46_v * floor(h)) t_4 = floor(w) ^ Float32(2.0) t_5 = Float32(t_4 * dX_46_u) t_6 = fma(t_5, dX_46_u, Float32(Float32(t_1 * dX_46_v) * dX_46_v)) t_7 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_8 = Float32(dY_46_u * floor(w)) t_9 = fma(Float32(t_4 * dY_46_u), dY_46_u, t_2) t_10 = (t_6 != t_6) ? t_9 : ((t_9 != t_9) ? t_6 : max(t_6, t_9)) t_11 = Float32(sqrt(t_10) / floor(maxAniso)) t_12 = Float32(t_10 / t_7) t_13 = Float32(sqrt(Float32(Float32(1.0) / t_10)) * t_7) t_14 = t_12 > floor(maxAniso) tmp = Float32(0.0) if (t_14) tmp = floor(maxAniso); else tmp = t_12; end t_15 = tmp tmp_1 = Float32(0.0) if (t_14) tmp_1 = t_11; else tmp_1 = t_13; end t_16 = tmp_1 tmp_2 = Float32(0.0) if (Float32(((t_6 != t_6) ? t_2 : ((t_2 != t_2) ? t_6 : max(t_6, t_2))) / t_7) > floor(maxAniso)) tmp_2 = t_11; else tmp_2 = t_13; end tmp_6 = Float32(0.0) if (dY_46_u <= Float32(-1.999999943436137e-9)) tmp_8 = Float32(0.0) if (t_16 < Float32(1.0)) tmp_9 = Float32(0.0) if (Float32(((Float32(t_5 * dX_46_u) != Float32(t_5 * dX_46_u)) ? t_9 : ((t_9 != t_9) ? Float32(t_5 * dX_46_u) : max(Float32(t_5 * dX_46_u), t_9))) / t_7) > floor(maxAniso)) tmp_9 = t_11; else tmp_9 = t_13; end tmp_8 = (Float32(1.0) != Float32(1.0)) ? Float32(t_15 * tmp_9) : ((Float32(t_15 * tmp_9) != Float32(t_15 * tmp_9)) ? Float32(1.0) : max(Float32(1.0), Float32(t_15 * tmp_9))); elseif (Float32(((t_6 != t_6) ? Float32(Float32((t_3 ^ Float32(4.0)) - (t_8 ^ Float32(4.0))) / Float32((t_3 ^ Float32(2.0)) - (t_8 ^ Float32(2.0)))) : ((Float32(Float32((t_3 ^ Float32(4.0)) - (t_8 ^ Float32(4.0))) / Float32((t_3 ^ Float32(2.0)) - (t_8 ^ Float32(2.0)))) != Float32(Float32((t_3 ^ Float32(4.0)) - (t_8 ^ Float32(4.0))) / Float32((t_3 ^ Float32(2.0)) - (t_8 ^ Float32(2.0))))) ? t_6 : max(t_6, Float32(Float32((t_3 ^ Float32(4.0)) - (t_8 ^ Float32(4.0))) / Float32((t_3 ^ Float32(2.0)) - (t_8 ^ Float32(2.0))))))) / t_7) > floor(maxAniso)) tmp_8 = floor(maxAniso); else tmp_8 = t_12; end tmp_6 = tmp_8; elseif (tmp_2 < Float32(1.0)) tmp_6 = (Float32(1.0) != Float32(1.0)) ? Float32(t_15 * t_16) : ((Float32(t_15 * t_16) != Float32(t_15 * t_16)) ? Float32(1.0) : max(Float32(1.0), Float32(t_15 * t_16))); elseif (Float32(((Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) != Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0))) ? t_9 : ((t_9 != t_9) ? Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) : max(Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)), t_9))) / t_7) > floor(maxAniso)) tmp_6 = floor(maxAniso); else tmp_6 = t_12; end return tmp_6 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_1 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_2 := \left(t\_1 \cdot dY.v\right) \cdot dY.v\\
t_3 := dY.v \cdot \left\lfloor h\right\rfloor \\
t_4 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_5 := t\_4 \cdot dX.u\\
t_6 := \mathsf{fma}\left(t\_5, dX.u, \left(t\_1 \cdot dX.v\right) \cdot dX.v\right)\\
t_7 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_8 := dY.u \cdot \left\lfloor w\right\rfloor \\
t_9 := \mathsf{fma}\left(t\_4 \cdot dY.u, dY.u, t\_2\right)\\
t_10 := \mathsf{max}\left(t\_6, t\_9\right)\\
t_11 := \frac{\sqrt{t\_10}}{\left\lfloor maxAniso\right\rfloor }\\
t_12 := \frac{t\_10}{t\_7}\\
t_13 := \sqrt{\frac{1}{t\_10}} \cdot t\_7\\
t_14 := t\_12 > \left\lfloor maxAniso\right\rfloor \\
t_15 := \begin{array}{l}
\mathbf{if}\;t\_14:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}\\
t_16 := \begin{array}{l}
\mathbf{if}\;t\_14:\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_13\\
\end{array}\\
\mathbf{if}\;dY.u \leq -1.999999943436137 \cdot 10^{-9}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;t\_16 < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_15 \cdot \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_5 \cdot dX.u, t\_9\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_13\\
\end{array}\right)\\
\mathbf{elif}\;\frac{\mathsf{max}\left(t\_6, \frac{{t\_3}^{4} - {t\_8}^{4}}{{t\_3}^{2} - {t\_8}^{2}}\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}\\
\mathbf{elif}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_6, t\_2\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_13\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_15 \cdot t\_16\right)\\
\mathbf{elif}\;\frac{\mathsf{max}\left({\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_0 \cdot t\_0, t\_9\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}
\end{array}
if dY.u < -1.99999994e-9Initial program 98.8%
Taylor expanded in w around 0
Applied rewrites43.0%
Applied rewrites63.8%
Taylor expanded in dX.u around inf
Applied rewrites63.7%
if -1.99999994e-9 < dY.u Initial program 95.9%
Taylor expanded in w around 0
Applied rewrites38.8%
Taylor expanded in dY.u around 0
Applied rewrites48.0%
Applied rewrites64.5%
Final simplification59.1%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (* dY.u (floor w)))
(t_1 (pow (floor w) 2.0))
(t_2
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_3 (pow (floor h) 2.0))
(t_4 (fma (* t_1 dX.u) dX.u (* (* t_3 dX.v) dX.v)))
(t_5 (* dX.u (floor w)))
(t_6 (* (* t_3 dY.v) dY.v))
(t_7 (fma (* t_1 dY.u) dY.u t_6))
(t_8 (fmax t_4 t_7))
(t_9 (/ t_8 t_2))
(t_10 (> t_9 (floor maxAniso)))
(t_11 (/ (sqrt t_8) (floor maxAniso)))
(t_12 (* (sqrt (/ 1.0 t_8)) t_2))
(t_13
(fmax 1.0 (* (if t_10 (floor maxAniso) t_9) (if t_10 t_11 t_12))))
(t_14
(< (if (> (/ (fmax t_4 t_6) t_2) (floor maxAniso)) t_11 t_12) 1.0)))
(if (<= dY.u -1.999999943436137e-9)
(if t_14
t_13
(if (>
(/ (fmax t_4 (+ (pow (* dY.v (floor h)) 2.0) (* t_0 t_0))) t_2)
(floor maxAniso))
(floor maxAniso)
t_9))
(if t_14
t_13
(if (>
(/ (fmax (+ (pow (* dX.v (floor h)) 2.0) (* t_5 t_5)) t_7) t_2)
(floor maxAniso))
(floor maxAniso)
t_9)))))
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 = dY_46_u * floorf(w);
float t_1 = powf(floorf(w), 2.0f);
float t_2 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_3 = powf(floorf(h), 2.0f);
float t_4 = fmaf((t_1 * dX_46_u), dX_46_u, ((t_3 * dX_46_v) * dX_46_v));
float t_5 = dX_46_u * floorf(w);
float t_6 = (t_3 * dY_46_v) * dY_46_v;
float t_7 = fmaf((t_1 * dY_46_u), dY_46_u, t_6);
float t_8 = fmaxf(t_4, t_7);
float t_9 = t_8 / t_2;
int t_10 = t_9 > floorf(maxAniso);
float t_11 = sqrtf(t_8) / floorf(maxAniso);
float t_12 = sqrtf((1.0f / t_8)) * t_2;
float tmp;
if (t_10) {
tmp = floorf(maxAniso);
} else {
tmp = t_9;
}
float tmp_1;
if (t_10) {
tmp_1 = t_11;
} else {
tmp_1 = t_12;
}
float t_13 = fmaxf(1.0f, (tmp * tmp_1));
float tmp_2;
if ((fmaxf(t_4, t_6) / t_2) > floorf(maxAniso)) {
tmp_2 = t_11;
} else {
tmp_2 = t_12;
}
int t_14 = tmp_2 < 1.0f;
float tmp_4;
if (dY_46_u <= -1.999999943436137e-9f) {
float tmp_5;
if (t_14) {
tmp_5 = t_13;
} else if ((fmaxf(t_4, (powf((dY_46_v * floorf(h)), 2.0f) + (t_0 * t_0))) / t_2) > floorf(maxAniso)) {
tmp_5 = floorf(maxAniso);
} else {
tmp_5 = t_9;
}
tmp_4 = tmp_5;
} else if (t_14) {
tmp_4 = t_13;
} else if ((fmaxf((powf((dX_46_v * floorf(h)), 2.0f) + (t_5 * t_5)), t_7) / t_2) > floorf(maxAniso)) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_9;
}
return tmp_4;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = Float32(dY_46_u * floor(w)) t_1 = floor(w) ^ Float32(2.0) t_2 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_3 = floor(h) ^ Float32(2.0) t_4 = fma(Float32(t_1 * dX_46_u), dX_46_u, Float32(Float32(t_3 * dX_46_v) * dX_46_v)) t_5 = Float32(dX_46_u * floor(w)) t_6 = Float32(Float32(t_3 * dY_46_v) * dY_46_v) t_7 = fma(Float32(t_1 * dY_46_u), dY_46_u, t_6) t_8 = (t_4 != t_4) ? t_7 : ((t_7 != t_7) ? t_4 : max(t_4, t_7)) t_9 = Float32(t_8 / t_2) t_10 = t_9 > floor(maxAniso) t_11 = Float32(sqrt(t_8) / floor(maxAniso)) t_12 = Float32(sqrt(Float32(Float32(1.0) / t_8)) * t_2) tmp = Float32(0.0) if (t_10) tmp = floor(maxAniso); else tmp = t_9; end tmp_1 = Float32(0.0) if (t_10) tmp_1 = t_11; else tmp_1 = t_12; end t_13 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp * tmp_1) : ((Float32(tmp * tmp_1) != Float32(tmp * tmp_1)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp * tmp_1))) tmp_2 = Float32(0.0) if (Float32(((t_4 != t_4) ? t_6 : ((t_6 != t_6) ? t_4 : max(t_4, t_6))) / t_2) > floor(maxAniso)) tmp_2 = t_11; else tmp_2 = t_12; end t_14 = tmp_2 < Float32(1.0) tmp_4 = Float32(0.0) if (dY_46_u <= Float32(-1.999999943436137e-9)) tmp_5 = Float32(0.0) if (t_14) tmp_5 = t_13; elseif (Float32(((t_4 != t_4) ? Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) : ((Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) != Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0))) ? t_4 : max(t_4, Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0))))) / t_2) > floor(maxAniso)) tmp_5 = floor(maxAniso); else tmp_5 = t_9; end tmp_4 = tmp_5; elseif (t_14) tmp_4 = t_13; elseif (Float32(((Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_5 * t_5)) != Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_5 * t_5))) ? t_7 : ((t_7 != t_7) ? Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_5 * t_5)) : max(Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_5 * t_5)), t_7))) / t_2) > floor(maxAniso)) tmp_4 = floor(maxAniso); else tmp_4 = t_9; end return tmp_4 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := dY.u \cdot \left\lfloor w\right\rfloor \\
t_1 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_2 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_3 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_4 := \mathsf{fma}\left(t\_1 \cdot dX.u, dX.u, \left(t\_3 \cdot dX.v\right) \cdot dX.v\right)\\
t_5 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_6 := \left(t\_3 \cdot dY.v\right) \cdot dY.v\\
t_7 := \mathsf{fma}\left(t\_1 \cdot dY.u, dY.u, t\_6\right)\\
t_8 := \mathsf{max}\left(t\_4, t\_7\right)\\
t_9 := \frac{t\_8}{t\_2}\\
t_10 := t\_9 > \left\lfloor maxAniso\right\rfloor \\
t_11 := \frac{\sqrt{t\_8}}{\left\lfloor maxAniso\right\rfloor }\\
t_12 := \sqrt{\frac{1}{t\_8}} \cdot t\_2\\
t_13 := \mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}\right)\\
t_14 := \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_4, t\_6\right)}{t\_2} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array} < 1\\
\mathbf{if}\;dY.u \leq -1.999999943436137 \cdot 10^{-9}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;t\_14:\\
\;\;\;\;t\_13\\
\mathbf{elif}\;\frac{\mathsf{max}\left(t\_4, {\left(dY.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_0 \cdot t\_0\right)}{t\_2} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}\\
\mathbf{elif}\;t\_14:\\
\;\;\;\;t\_13\\
\mathbf{elif}\;\frac{\mathsf{max}\left({\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_5 \cdot t\_5, t\_7\right)}{t\_2} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}
\end{array}
if dY.u < -1.99999994e-9Initial program 98.8%
Taylor expanded in w around 0
Applied rewrites43.6%
Taylor expanded in dY.u around 0
Applied rewrites50.8%
Applied rewrites62.3%
if -1.99999994e-9 < dY.u Initial program 95.9%
Taylor expanded in w around 0
Applied rewrites38.2%
Taylor expanded in dY.u around 0
Applied rewrites49.1%
Applied rewrites64.1%
Final simplification63.4%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor w) 2.0))
(t_1 (pow (floor h) 2.0))
(t_2 (* (* t_1 dY.v) dY.v))
(t_3 (fma (* t_0 dY.u) dY.u t_2))
(t_4 (fma (* t_0 dX.u) dX.u (* (* t_1 dX.v) dX.v)))
(t_5 (fmax t_4 t_3))
(t_6 (/ (sqrt t_5) (floor maxAniso)))
(t_7
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_8 (/ t_5 t_7))
(t_9 (> t_8 (floor maxAniso)))
(t_10 (* (sqrt (/ 1.0 t_5)) t_7))
(t_11 (* dX.u (floor w))))
(if (< (if (> (/ (fmax t_4 t_2) t_7) (floor maxAniso)) t_6 t_10) 1.0)
(fmax 1.0 (* (if t_9 (floor maxAniso) t_8) (if t_9 t_6 t_10)))
(if (>
(/ (fmax (+ (pow (* dX.v (floor h)) 2.0) (* t_11 t_11)) t_3) t_7)
(floor maxAniso))
(floor maxAniso)
t_8))))
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 = powf(floorf(w), 2.0f);
float t_1 = powf(floorf(h), 2.0f);
float t_2 = (t_1 * dY_46_v) * dY_46_v;
float t_3 = fmaf((t_0 * dY_46_u), dY_46_u, t_2);
float t_4 = fmaf((t_0 * dX_46_u), dX_46_u, ((t_1 * dX_46_v) * dX_46_v));
float t_5 = fmaxf(t_4, t_3);
float t_6 = sqrtf(t_5) / floorf(maxAniso);
float t_7 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_8 = t_5 / t_7;
int t_9 = t_8 > floorf(maxAniso);
float t_10 = sqrtf((1.0f / t_5)) * t_7;
float t_11 = dX_46_u * floorf(w);
float tmp;
if ((fmaxf(t_4, t_2) / t_7) > floorf(maxAniso)) {
tmp = t_6;
} else {
tmp = t_10;
}
float tmp_3;
if (tmp < 1.0f) {
float tmp_4;
if (t_9) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_8;
}
float tmp_5;
if (t_9) {
tmp_5 = t_6;
} else {
tmp_5 = t_10;
}
tmp_3 = fmaxf(1.0f, (tmp_4 * tmp_5));
} else if ((fmaxf((powf((dX_46_v * floorf(h)), 2.0f) + (t_11 * t_11)), t_3) / t_7) > floorf(maxAniso)) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_8;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(w) ^ Float32(2.0) t_1 = floor(h) ^ Float32(2.0) t_2 = Float32(Float32(t_1 * dY_46_v) * dY_46_v) t_3 = fma(Float32(t_0 * dY_46_u), dY_46_u, t_2) t_4 = fma(Float32(t_0 * dX_46_u), dX_46_u, Float32(Float32(t_1 * dX_46_v) * dX_46_v)) t_5 = (t_4 != t_4) ? t_3 : ((t_3 != t_3) ? t_4 : max(t_4, t_3)) t_6 = Float32(sqrt(t_5) / floor(maxAniso)) t_7 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_8 = Float32(t_5 / t_7) t_9 = t_8 > floor(maxAniso) t_10 = Float32(sqrt(Float32(Float32(1.0) / t_5)) * t_7) t_11 = Float32(dX_46_u * floor(w)) tmp = Float32(0.0) if (Float32(((t_4 != t_4) ? t_2 : ((t_2 != t_2) ? t_4 : max(t_4, t_2))) / t_7) > floor(maxAniso)) tmp = t_6; else tmp = t_10; end tmp_3 = Float32(0.0) if (tmp < Float32(1.0)) tmp_4 = Float32(0.0) if (t_9) tmp_4 = floor(maxAniso); else tmp_4 = t_8; end tmp_5 = Float32(0.0) if (t_9) tmp_5 = t_6; else tmp_5 = t_10; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_4 * tmp_5) : ((Float32(tmp_4 * tmp_5) != Float32(tmp_4 * tmp_5)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_4 * tmp_5))); elseif (Float32(((Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) != Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11))) ? t_3 : ((t_3 != t_3) ? Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) : max(Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)), t_3))) / t_7) > floor(maxAniso)) tmp_3 = floor(maxAniso); else tmp_3 = t_8; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_1 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_2 := \left(t\_1 \cdot dY.v\right) \cdot dY.v\\
t_3 := \mathsf{fma}\left(t\_0 \cdot dY.u, dY.u, t\_2\right)\\
t_4 := \mathsf{fma}\left(t\_0 \cdot dX.u, dX.u, \left(t\_1 \cdot dX.v\right) \cdot dX.v\right)\\
t_5 := \mathsf{max}\left(t\_4, t\_3\right)\\
t_6 := \frac{\sqrt{t\_5}}{\left\lfloor maxAniso\right\rfloor }\\
t_7 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_8 := \frac{t\_5}{t\_7}\\
t_9 := t\_8 > \left\lfloor maxAniso\right\rfloor \\
t_10 := \sqrt{\frac{1}{t\_5}} \cdot t\_7\\
t_11 := dX.u \cdot \left\lfloor w\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_4, t\_2\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_6\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_8\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;t\_6\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}\right)\\
\mathbf{elif}\;\frac{\mathsf{max}\left({\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_11 \cdot t\_11, t\_3\right)}{t\_7} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_8\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites40.4%
Taylor expanded in dY.u around 0
Applied rewrites50.1%
Applied rewrites63.4%
Final simplification64.2%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (* dY.u (floor w)))
(t_1 (pow (floor h) 2.0))
(t_2 (* (* t_1 dX.v) dX.v))
(t_3 (* dX.u (floor w)))
(t_4 (* (* t_1 dY.v) dY.v))
(t_5
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_6 (pow (floor w) 2.0))
(t_7 (fma (* t_6 dX.u) dX.u t_2))
(t_8 (fma (* t_6 dY.u) dY.u t_4))
(t_9 (fmax t_7 t_8))
(t_10 (* (sqrt (/ 1.0 t_9)) t_5))
(t_11 (/ (sqrt t_9) (floor maxAniso)))
(t_12 (/ t_9 t_5))
(t_13 (> t_12 (floor maxAniso)))
(t_14
(fmax 1.0 (* (if t_13 (floor maxAniso) t_12) (if t_13 t_11 t_10))))
(t_15
(< (if (> (/ (fmax t_2 t_4) t_5) (floor maxAniso)) t_11 t_10) 1.0)))
(if (<= dY.u -9.999999747378752e-5)
(if t_15
t_14
(if (>
(/ (fmax t_7 (+ (pow (* dY.v (floor h)) 2.0) (* t_0 t_0))) t_5)
(floor maxAniso))
(floor maxAniso)
t_12))
(if t_15
t_14
(if (>
(/ (fmax (+ (pow (* dX.v (floor h)) 2.0) (* t_3 t_3)) t_8) t_5)
(floor maxAniso))
(floor maxAniso)
t_12)))))
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 = dY_46_u * floorf(w);
float t_1 = powf(floorf(h), 2.0f);
float t_2 = (t_1 * dX_46_v) * dX_46_v;
float t_3 = dX_46_u * floorf(w);
float t_4 = (t_1 * dY_46_v) * dY_46_v;
float t_5 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_6 = powf(floorf(w), 2.0f);
float t_7 = fmaf((t_6 * dX_46_u), dX_46_u, t_2);
float t_8 = fmaf((t_6 * dY_46_u), dY_46_u, t_4);
float t_9 = fmaxf(t_7, t_8);
float t_10 = sqrtf((1.0f / t_9)) * t_5;
float t_11 = sqrtf(t_9) / floorf(maxAniso);
float t_12 = t_9 / t_5;
int t_13 = t_12 > floorf(maxAniso);
float tmp;
if (t_13) {
tmp = floorf(maxAniso);
} else {
tmp = t_12;
}
float tmp_1;
if (t_13) {
tmp_1 = t_11;
} else {
tmp_1 = t_10;
}
float t_14 = fmaxf(1.0f, (tmp * tmp_1));
float tmp_2;
if ((fmaxf(t_2, t_4) / t_5) > floorf(maxAniso)) {
tmp_2 = t_11;
} else {
tmp_2 = t_10;
}
int t_15 = tmp_2 < 1.0f;
float tmp_4;
if (dY_46_u <= -9.999999747378752e-5f) {
float tmp_5;
if (t_15) {
tmp_5 = t_14;
} else if ((fmaxf(t_7, (powf((dY_46_v * floorf(h)), 2.0f) + (t_0 * t_0))) / t_5) > floorf(maxAniso)) {
tmp_5 = floorf(maxAniso);
} else {
tmp_5 = t_12;
}
tmp_4 = tmp_5;
} else if (t_15) {
tmp_4 = t_14;
} else if ((fmaxf((powf((dX_46_v * floorf(h)), 2.0f) + (t_3 * t_3)), t_8) / t_5) > floorf(maxAniso)) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_12;
}
return tmp_4;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = Float32(dY_46_u * floor(w)) t_1 = floor(h) ^ Float32(2.0) t_2 = Float32(Float32(t_1 * dX_46_v) * dX_46_v) t_3 = Float32(dX_46_u * floor(w)) t_4 = Float32(Float32(t_1 * dY_46_v) * dY_46_v) t_5 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_6 = floor(w) ^ Float32(2.0) t_7 = fma(Float32(t_6 * dX_46_u), dX_46_u, t_2) t_8 = fma(Float32(t_6 * dY_46_u), dY_46_u, t_4) t_9 = (t_7 != t_7) ? t_8 : ((t_8 != t_8) ? t_7 : max(t_7, t_8)) t_10 = Float32(sqrt(Float32(Float32(1.0) / t_9)) * t_5) t_11 = Float32(sqrt(t_9) / floor(maxAniso)) t_12 = Float32(t_9 / t_5) t_13 = t_12 > floor(maxAniso) tmp = Float32(0.0) if (t_13) tmp = floor(maxAniso); else tmp = t_12; end tmp_1 = Float32(0.0) if (t_13) tmp_1 = t_11; else tmp_1 = t_10; end t_14 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp * tmp_1) : ((Float32(tmp * tmp_1) != Float32(tmp * tmp_1)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp * tmp_1))) tmp_2 = Float32(0.0) if (Float32(((t_2 != t_2) ? t_4 : ((t_4 != t_4) ? t_2 : max(t_2, t_4))) / t_5) > floor(maxAniso)) tmp_2 = t_11; else tmp_2 = t_10; end t_15 = tmp_2 < Float32(1.0) tmp_4 = Float32(0.0) if (dY_46_u <= Float32(-9.999999747378752e-5)) tmp_5 = Float32(0.0) if (t_15) tmp_5 = t_14; elseif (Float32(((t_7 != t_7) ? Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) : ((Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0)) != Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0))) ? t_7 : max(t_7, Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_0 * t_0))))) / t_5) > floor(maxAniso)) tmp_5 = floor(maxAniso); else tmp_5 = t_12; end tmp_4 = tmp_5; elseif (t_15) tmp_4 = t_14; elseif (Float32(((Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_3 * t_3)) != Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_3 * t_3))) ? t_8 : ((t_8 != t_8) ? Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_3 * t_3)) : max(Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_3 * t_3)), t_8))) / t_5) > floor(maxAniso)) tmp_4 = floor(maxAniso); else tmp_4 = t_12; end return tmp_4 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := dY.u \cdot \left\lfloor w\right\rfloor \\
t_1 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_2 := \left(t\_1 \cdot dX.v\right) \cdot dX.v\\
t_3 := dX.u \cdot \left\lfloor w\right\rfloor \\
t_4 := \left(t\_1 \cdot dY.v\right) \cdot dY.v\\
t_5 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_6 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_7 := \mathsf{fma}\left(t\_6 \cdot dX.u, dX.u, t\_2\right)\\
t_8 := \mathsf{fma}\left(t\_6 \cdot dY.u, dY.u, t\_4\right)\\
t_9 := \mathsf{max}\left(t\_7, t\_8\right)\\
t_10 := \sqrt{\frac{1}{t\_9}} \cdot t\_5\\
t_11 := \frac{\sqrt{t\_9}}{\left\lfloor maxAniso\right\rfloor }\\
t_12 := \frac{t\_9}{t\_5}\\
t_13 := t\_12 > \left\lfloor maxAniso\right\rfloor \\
t_14 := \mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_13:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_13:\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}\right)\\
t_15 := \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_2, t\_4\right)}{t\_5} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_11\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array} < 1\\
\mathbf{if}\;dY.u \leq -9.999999747378752 \cdot 10^{-5}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;t\_15:\\
\;\;\;\;t\_14\\
\mathbf{elif}\;\frac{\mathsf{max}\left(t\_7, {\left(dY.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_0 \cdot t\_0\right)}{t\_5} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}\\
\mathbf{elif}\;t\_15:\\
\;\;\;\;t\_14\\
\mathbf{elif}\;\frac{\mathsf{max}\left({\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_3 \cdot t\_3, t\_8\right)}{t\_5} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_12\\
\end{array}
\end{array}
if dY.u < -9.99999975e-5Initial program 98.7%
Taylor expanded in w around 0
Applied rewrites44.4%
Taylor expanded in dY.u around 0
Applied rewrites47.7%
Taylor expanded in dX.u around 0
Applied rewrites25.8%
Applied rewrites53.6%
if -9.99999975e-5 < dY.u Initial program 96.1%
Taylor expanded in w around 0
Applied rewrites39.2%
Taylor expanded in dY.u around 0
Applied rewrites49.9%
Taylor expanded in dX.u around 0
Applied rewrites33.9%
Applied rewrites58.5%
Final simplification56.8%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_1 (pow (floor w) 2.0))
(t_2 (pow (floor h) 2.0))
(t_3 (* (* t_2 dY.v) dY.v))
(t_4 (fma (* t_1 dY.u) dY.u t_3))
(t_5 (* (* t_2 dX.v) dX.v))
(t_6 (fmax (fma (* t_1 dX.u) dX.u t_5) t_4))
(t_7 (* (sqrt (/ 1.0 t_6)) t_0))
(t_8 (/ (sqrt t_6) (floor maxAniso)))
(t_9 (/ t_6 t_0))
(t_10 (> t_9 (floor maxAniso)))
(t_11 (* dX.u (floor w))))
(if (< (if (> (/ (fmax t_5 t_3) t_0) (floor maxAniso)) t_8 t_7) 1.0)
(fmax 1.0 (* (if t_10 (floor maxAniso) t_9) (if t_10 t_8 t_7)))
(if (>
(/ (fmax (+ (pow (* dX.v (floor h)) 2.0) (* t_11 t_11)) t_4) t_0)
(floor maxAniso))
(floor maxAniso)
t_9))))
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 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_1 = powf(floorf(w), 2.0f);
float t_2 = powf(floorf(h), 2.0f);
float t_3 = (t_2 * dY_46_v) * dY_46_v;
float t_4 = fmaf((t_1 * dY_46_u), dY_46_u, t_3);
float t_5 = (t_2 * dX_46_v) * dX_46_v;
float t_6 = fmaxf(fmaf((t_1 * dX_46_u), dX_46_u, t_5), t_4);
float t_7 = sqrtf((1.0f / t_6)) * t_0;
float t_8 = sqrtf(t_6) / floorf(maxAniso);
float t_9 = t_6 / t_0;
int t_10 = t_9 > floorf(maxAniso);
float t_11 = dX_46_u * floorf(w);
float tmp;
if ((fmaxf(t_5, t_3) / t_0) > floorf(maxAniso)) {
tmp = t_8;
} else {
tmp = t_7;
}
float tmp_3;
if (tmp < 1.0f) {
float tmp_4;
if (t_10) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_9;
}
float tmp_5;
if (t_10) {
tmp_5 = t_8;
} else {
tmp_5 = t_7;
}
tmp_3 = fmaxf(1.0f, (tmp_4 * tmp_5));
} else if ((fmaxf((powf((dX_46_v * floorf(h)), 2.0f) + (t_11 * t_11)), t_4) / t_0) > floorf(maxAniso)) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_9;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_1 = floor(w) ^ Float32(2.0) t_2 = floor(h) ^ Float32(2.0) t_3 = Float32(Float32(t_2 * dY_46_v) * dY_46_v) t_4 = fma(Float32(t_1 * dY_46_u), dY_46_u, t_3) t_5 = Float32(Float32(t_2 * dX_46_v) * dX_46_v) t_6 = (fma(Float32(t_1 * dX_46_u), dX_46_u, t_5) != fma(Float32(t_1 * dX_46_u), dX_46_u, t_5)) ? t_4 : ((t_4 != t_4) ? fma(Float32(t_1 * dX_46_u), dX_46_u, t_5) : max(fma(Float32(t_1 * dX_46_u), dX_46_u, t_5), t_4)) t_7 = Float32(sqrt(Float32(Float32(1.0) / t_6)) * t_0) t_8 = Float32(sqrt(t_6) / floor(maxAniso)) t_9 = Float32(t_6 / t_0) t_10 = t_9 > floor(maxAniso) t_11 = Float32(dX_46_u * floor(w)) tmp = Float32(0.0) if (Float32(((t_5 != t_5) ? t_3 : ((t_3 != t_3) ? t_5 : max(t_5, t_3))) / t_0) > floor(maxAniso)) tmp = t_8; else tmp = t_7; end tmp_3 = Float32(0.0) if (tmp < Float32(1.0)) tmp_4 = Float32(0.0) if (t_10) tmp_4 = floor(maxAniso); else tmp_4 = t_9; end tmp_5 = Float32(0.0) if (t_10) tmp_5 = t_8; else tmp_5 = t_7; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_4 * tmp_5) : ((Float32(tmp_4 * tmp_5) != Float32(tmp_4 * tmp_5)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_4 * tmp_5))); elseif (Float32(((Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) != Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11))) ? t_4 : ((t_4 != t_4) ? Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) : max(Float32((Float32(dX_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)), t_4))) / t_0) > floor(maxAniso)) tmp_3 = floor(maxAniso); else tmp_3 = t_9; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_1 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_2 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_3 := \left(t\_2 \cdot dY.v\right) \cdot dY.v\\
t_4 := \mathsf{fma}\left(t\_1 \cdot dY.u, dY.u, t\_3\right)\\
t_5 := \left(t\_2 \cdot dX.v\right) \cdot dX.v\\
t_6 := \mathsf{max}\left(\mathsf{fma}\left(t\_1 \cdot dX.u, dX.u, t\_5\right), t\_4\right)\\
t_7 := \sqrt{\frac{1}{t\_6}} \cdot t\_0\\
t_8 := \frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
t_9 := \frac{t\_6}{t\_0}\\
t_10 := t\_9 > \left\lfloor maxAniso\right\rfloor \\
t_11 := dX.u \cdot \left\lfloor w\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_5, t\_3\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_10:\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\right)\\
\mathbf{elif}\;\frac{\mathsf{max}\left({\left(dX.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_11 \cdot t\_11, t\_4\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites39.7%
Taylor expanded in dY.u around 0
Applied rewrites48.8%
Taylor expanded in dX.u around 0
Applied rewrites33.2%
Applied rewrites53.8%
Final simplification53.2%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0 (pow (floor h) 2.0))
(t_1 (* (* t_0 dY.v) dY.v))
(t_2
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_3 (pow (floor w) 2.0))
(t_4 (* (* t_0 dX.v) dX.v))
(t_5 (fma (* t_3 dX.u) dX.u t_4))
(t_6 (fmax t_5 (fma (* t_3 dY.u) dY.u t_1)))
(t_7 (/ t_6 t_2))
(t_8 (* (sqrt (/ 1.0 t_6)) t_2))
(t_9 (> t_7 (floor maxAniso)))
(t_10 (if t_9 (floor maxAniso) t_7))
(t_11 (* dY.u (floor w))))
(if (<
(if (> (/ (fmax t_4 t_1) t_2) (floor maxAniso))
(/
(sqrt (fmax t_5 (+ (pow (* dY.v (floor h)) 2.0) (* t_11 t_11))))
(floor maxAniso))
t_8)
1.0)
(fmax 1.0 (* t_10 (if t_9 (/ (sqrt t_6) (floor maxAniso)) t_8)))
t_10)))
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 = powf(floorf(h), 2.0f);
float t_1 = (t_0 * dY_46_v) * dY_46_v;
float t_2 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_3 = powf(floorf(w), 2.0f);
float t_4 = (t_0 * dX_46_v) * dX_46_v;
float t_5 = fmaf((t_3 * dX_46_u), dX_46_u, t_4);
float t_6 = fmaxf(t_5, fmaf((t_3 * dY_46_u), dY_46_u, t_1));
float t_7 = t_6 / t_2;
float t_8 = sqrtf((1.0f / t_6)) * t_2;
int t_9 = t_7 > floorf(maxAniso);
float tmp;
if (t_9) {
tmp = floorf(maxAniso);
} else {
tmp = t_7;
}
float t_10 = tmp;
float t_11 = dY_46_u * floorf(w);
float tmp_1;
if ((fmaxf(t_4, t_1) / t_2) > floorf(maxAniso)) {
tmp_1 = sqrtf(fmaxf(t_5, (powf((dY_46_v * floorf(h)), 2.0f) + (t_11 * t_11)))) / floorf(maxAniso);
} else {
tmp_1 = t_8;
}
float tmp_3;
if (tmp_1 < 1.0f) {
float tmp_4;
if (t_9) {
tmp_4 = sqrtf(t_6) / floorf(maxAniso);
} else {
tmp_4 = t_8;
}
tmp_3 = fmaxf(1.0f, (t_10 * tmp_4));
} else {
tmp_3 = t_10;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = floor(h) ^ Float32(2.0) t_1 = Float32(Float32(t_0 * dY_46_v) * dY_46_v) t_2 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_3 = floor(w) ^ Float32(2.0) t_4 = Float32(Float32(t_0 * dX_46_v) * dX_46_v) t_5 = fma(Float32(t_3 * dX_46_u), dX_46_u, t_4) t_6 = (t_5 != t_5) ? fma(Float32(t_3 * dY_46_u), dY_46_u, t_1) : ((fma(Float32(t_3 * dY_46_u), dY_46_u, t_1) != fma(Float32(t_3 * dY_46_u), dY_46_u, t_1)) ? t_5 : max(t_5, fma(Float32(t_3 * dY_46_u), dY_46_u, t_1))) t_7 = Float32(t_6 / t_2) t_8 = Float32(sqrt(Float32(Float32(1.0) / t_6)) * t_2) t_9 = t_7 > floor(maxAniso) tmp = Float32(0.0) if (t_9) tmp = floor(maxAniso); else tmp = t_7; end t_10 = tmp t_11 = Float32(dY_46_u * floor(w)) tmp_1 = Float32(0.0) if (Float32(((t_4 != t_4) ? t_1 : ((t_1 != t_1) ? t_4 : max(t_4, t_1))) / t_2) > floor(maxAniso)) tmp_1 = Float32(sqrt(((t_5 != t_5) ? Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) : ((Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)) != Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11))) ? t_5 : max(t_5, Float32((Float32(dY_46_v * floor(h)) ^ Float32(2.0)) + Float32(t_11 * t_11)))))) / floor(maxAniso)); else tmp_1 = t_8; end tmp_3 = Float32(0.0) if (tmp_1 < Float32(1.0)) tmp_4 = Float32(0.0) if (t_9) tmp_4 = Float32(sqrt(t_6) / floor(maxAniso)); else tmp_4 = t_8; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * tmp_4) : ((Float32(t_10 * tmp_4) != Float32(t_10 * tmp_4)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * tmp_4))); else tmp_3 = t_10; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_1 := \left(t\_0 \cdot dY.v\right) \cdot dY.v\\
t_2 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_3 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_4 := \left(t\_0 \cdot dX.v\right) \cdot dX.v\\
t_5 := \mathsf{fma}\left(t\_3 \cdot dX.u, dX.u, t\_4\right)\\
t_6 := \mathsf{max}\left(t\_5, \mathsf{fma}\left(t\_3 \cdot dY.u, dY.u, t\_1\right)\right)\\
t_7 := \frac{t\_6}{t\_2}\\
t_8 := \sqrt{\frac{1}{t\_6}} \cdot t\_2\\
t_9 := t\_7 > \left\lfloor maxAniso\right\rfloor \\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\\
t_11 := dY.u \cdot \left\lfloor w\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_4, t\_1\right)}{t\_2} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\frac{\sqrt{\mathsf{max}\left(t\_5, {\left(dY.v \cdot \left\lfloor h\right\rfloor \right)}^{2} + t\_11 \cdot t\_11\right)}}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;t\_8\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;\frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
\mathbf{else}:\\
\;\;\;\;t\_8\\
\end{array}\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites39.7%
Taylor expanded in dY.u around 0
Applied rewrites49.9%
Taylor expanded in dX.u around 0
Applied rewrites32.0%
Applied rewrites56.6%
Final simplification58.2%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_1 (pow (floor w) 2.0))
(t_2 (pow (floor h) 2.0))
(t_3 (* (* t_2 dX.v) dX.v))
(t_4 (* (* t_2 dY.v) dY.v))
(t_5 (fma (* t_1 dY.u) dY.u t_4))
(t_6 (fmax (fma (* t_1 dX.u) dX.u t_3) t_5))
(t_7 (/ (sqrt t_6) (floor maxAniso)))
(t_8 (/ t_6 t_0))
(t_9 (> t_8 (floor maxAniso)))
(t_10 (if t_9 (floor maxAniso) t_8)))
(if (<
(if (> (/ (fmax t_3 t_4) t_0) (floor maxAniso))
t_7
(* (sqrt (/ 1.0 (fmax t_3 t_5))) t_0))
1.0)
(fmax 1.0 (* t_10 (if t_9 t_7 (* (sqrt (/ 1.0 t_6)) t_0))))
t_10)))
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 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_1 = powf(floorf(w), 2.0f);
float t_2 = powf(floorf(h), 2.0f);
float t_3 = (t_2 * dX_46_v) * dX_46_v;
float t_4 = (t_2 * dY_46_v) * dY_46_v;
float t_5 = fmaf((t_1 * dY_46_u), dY_46_u, t_4);
float t_6 = fmaxf(fmaf((t_1 * dX_46_u), dX_46_u, t_3), t_5);
float t_7 = sqrtf(t_6) / floorf(maxAniso);
float t_8 = t_6 / t_0;
int t_9 = t_8 > floorf(maxAniso);
float tmp;
if (t_9) {
tmp = floorf(maxAniso);
} else {
tmp = t_8;
}
float t_10 = tmp;
float tmp_1;
if ((fmaxf(t_3, t_4) / t_0) > floorf(maxAniso)) {
tmp_1 = t_7;
} else {
tmp_1 = sqrtf((1.0f / fmaxf(t_3, t_5))) * t_0;
}
float tmp_3;
if (tmp_1 < 1.0f) {
float tmp_4;
if (t_9) {
tmp_4 = t_7;
} else {
tmp_4 = sqrtf((1.0f / t_6)) * t_0;
}
tmp_3 = fmaxf(1.0f, (t_10 * tmp_4));
} else {
tmp_3 = t_10;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_1 = floor(w) ^ Float32(2.0) t_2 = floor(h) ^ Float32(2.0) t_3 = Float32(Float32(t_2 * dX_46_v) * dX_46_v) t_4 = Float32(Float32(t_2 * dY_46_v) * dY_46_v) t_5 = fma(Float32(t_1 * dY_46_u), dY_46_u, t_4) t_6 = (fma(Float32(t_1 * dX_46_u), dX_46_u, t_3) != fma(Float32(t_1 * dX_46_u), dX_46_u, t_3)) ? t_5 : ((t_5 != t_5) ? fma(Float32(t_1 * dX_46_u), dX_46_u, t_3) : max(fma(Float32(t_1 * dX_46_u), dX_46_u, t_3), t_5)) t_7 = Float32(sqrt(t_6) / floor(maxAniso)) t_8 = Float32(t_6 / t_0) t_9 = t_8 > floor(maxAniso) tmp = Float32(0.0) if (t_9) tmp = floor(maxAniso); else tmp = t_8; end t_10 = tmp tmp_1 = Float32(0.0) if (Float32(((t_3 != t_3) ? t_4 : ((t_4 != t_4) ? t_3 : max(t_3, t_4))) / t_0) > floor(maxAniso)) tmp_1 = t_7; else tmp_1 = Float32(sqrt(Float32(Float32(1.0) / ((t_3 != t_3) ? t_5 : ((t_5 != t_5) ? t_3 : max(t_3, t_5))))) * t_0); end tmp_3 = Float32(0.0) if (tmp_1 < Float32(1.0)) tmp_4 = Float32(0.0) if (t_9) tmp_4 = t_7; else tmp_4 = Float32(sqrt(Float32(Float32(1.0) / t_6)) * t_0); end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * tmp_4) : ((Float32(t_10 * tmp_4) != Float32(t_10 * tmp_4)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * tmp_4))); else tmp_3 = t_10; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_1 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_2 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_3 := \left(t\_2 \cdot dX.v\right) \cdot dX.v\\
t_4 := \left(t\_2 \cdot dY.v\right) \cdot dY.v\\
t_5 := \mathsf{fma}\left(t\_1 \cdot dY.u, dY.u, t\_4\right)\\
t_6 := \mathsf{max}\left(\mathsf{fma}\left(t\_1 \cdot dX.u, dX.u, t\_3\right), t\_5\right)\\
t_7 := \frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
t_8 := \frac{t\_6}{t\_0}\\
t_9 := t\_8 > \left\lfloor maxAniso\right\rfloor \\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_8\\
\end{array}\\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_3, t\_4\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_7\\
\mathbf{else}:\\
\;\;\;\;\sqrt{\frac{1}{\mathsf{max}\left(t\_3, t\_5\right)}} \cdot t\_0\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot \begin{array}{l}
\mathbf{if}\;t\_9:\\
\;\;\;\;t\_7\\
\mathbf{else}:\\
\;\;\;\;\sqrt{\frac{1}{t\_6}} \cdot t\_0\\
\end{array}\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites39.7%
Taylor expanded in dY.u around 0
Applied rewrites49.3%
Taylor expanded in dX.u around 0
Applied rewrites31.6%
Taylor expanded in dX.u around 0
Applied rewrites32.5%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_1 (pow (floor w) 2.0))
(t_2 (pow (floor h) 2.0))
(t_3 (* (* t_2 dY.v) dY.v))
(t_4 (* (* t_2 dX.v) dX.v))
(t_5 (fma (* t_1 dX.u) dX.u t_4))
(t_6 (fmax t_5 (fma (* t_1 dY.u) dY.u t_3)))
(t_7 (* (sqrt (/ 1.0 t_6)) t_0))
(t_8 (/ (sqrt t_6) (floor maxAniso)))
(t_9 (/ t_6 t_0))
(t_10 (if (> t_9 (floor maxAniso)) (floor maxAniso) t_9)))
(if (< (if (> (/ (fmax t_4 t_3) t_0) (floor maxAniso)) t_8 t_7) 1.0)
(fmax
1.0
(* t_10 (if (> (/ (fmax t_5 t_3) t_0) (floor maxAniso)) t_8 t_7)))
t_10)))
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 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_1 = powf(floorf(w), 2.0f);
float t_2 = powf(floorf(h), 2.0f);
float t_3 = (t_2 * dY_46_v) * dY_46_v;
float t_4 = (t_2 * dX_46_v) * dX_46_v;
float t_5 = fmaf((t_1 * dX_46_u), dX_46_u, t_4);
float t_6 = fmaxf(t_5, fmaf((t_1 * dY_46_u), dY_46_u, t_3));
float t_7 = sqrtf((1.0f / t_6)) * t_0;
float t_8 = sqrtf(t_6) / floorf(maxAniso);
float t_9 = t_6 / t_0;
float tmp;
if (t_9 > floorf(maxAniso)) {
tmp = floorf(maxAniso);
} else {
tmp = t_9;
}
float t_10 = tmp;
float tmp_1;
if ((fmaxf(t_4, t_3) / t_0) > floorf(maxAniso)) {
tmp_1 = t_8;
} else {
tmp_1 = t_7;
}
float tmp_3;
if (tmp_1 < 1.0f) {
float tmp_4;
if ((fmaxf(t_5, t_3) / t_0) > floorf(maxAniso)) {
tmp_4 = t_8;
} else {
tmp_4 = t_7;
}
tmp_3 = fmaxf(1.0f, (t_10 * tmp_4));
} else {
tmp_3 = t_10;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_1 = floor(w) ^ Float32(2.0) t_2 = floor(h) ^ Float32(2.0) t_3 = Float32(Float32(t_2 * dY_46_v) * dY_46_v) t_4 = Float32(Float32(t_2 * dX_46_v) * dX_46_v) t_5 = fma(Float32(t_1 * dX_46_u), dX_46_u, t_4) t_6 = (t_5 != t_5) ? fma(Float32(t_1 * dY_46_u), dY_46_u, t_3) : ((fma(Float32(t_1 * dY_46_u), dY_46_u, t_3) != fma(Float32(t_1 * dY_46_u), dY_46_u, t_3)) ? t_5 : max(t_5, fma(Float32(t_1 * dY_46_u), dY_46_u, t_3))) t_7 = Float32(sqrt(Float32(Float32(1.0) / t_6)) * t_0) t_8 = Float32(sqrt(t_6) / floor(maxAniso)) t_9 = Float32(t_6 / t_0) tmp = Float32(0.0) if (t_9 > floor(maxAniso)) tmp = floor(maxAniso); else tmp = t_9; end t_10 = tmp tmp_1 = Float32(0.0) if (Float32(((t_4 != t_4) ? t_3 : ((t_3 != t_3) ? t_4 : max(t_4, t_3))) / t_0) > floor(maxAniso)) tmp_1 = t_8; else tmp_1 = t_7; end tmp_3 = Float32(0.0) if (tmp_1 < Float32(1.0)) tmp_4 = Float32(0.0) if (Float32(((t_5 != t_5) ? t_3 : ((t_3 != t_3) ? t_5 : max(t_5, t_3))) / t_0) > floor(maxAniso)) tmp_4 = t_8; else tmp_4 = t_7; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * tmp_4) : ((Float32(t_10 * tmp_4) != Float32(t_10 * tmp_4)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * tmp_4))); else tmp_3 = t_10; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_1 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_2 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_3 := \left(t\_2 \cdot dY.v\right) \cdot dY.v\\
t_4 := \left(t\_2 \cdot dX.v\right) \cdot dX.v\\
t_5 := \mathsf{fma}\left(t\_1 \cdot dX.u, dX.u, t\_4\right)\\
t_6 := \mathsf{max}\left(t\_5, \mathsf{fma}\left(t\_1 \cdot dY.u, dY.u, t\_3\right)\right)\\
t_7 := \sqrt{\frac{1}{t\_6}} \cdot t\_0\\
t_8 := \frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
t_9 := \frac{t\_6}{t\_0}\\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_9 > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}\\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_4, t\_3\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_5, t\_3\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites39.7%
Taylor expanded in dY.u around 0
Applied rewrites49.3%
Taylor expanded in dX.u around 0
Applied rewrites31.9%
Taylor expanded in dY.u around 0
Applied rewrites31.4%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_1 (pow (floor w) 2.0))
(t_2 (pow (floor h) 2.0))
(t_3 (* (* t_2 dY.v) dY.v))
(t_4 (fma (* t_1 dY.u) dY.u t_3))
(t_5 (* (* t_2 dX.v) dX.v))
(t_6 (fmax (fma (* t_1 dX.u) dX.u t_5) t_4))
(t_7 (* (sqrt (/ 1.0 t_6)) t_0))
(t_8 (/ (sqrt t_6) (floor maxAniso)))
(t_9 (/ t_6 t_0))
(t_10 (if (> t_9 (floor maxAniso)) (floor maxAniso) t_9)))
(if (< (if (> (/ (fmax t_5 t_3) t_0) (floor maxAniso)) t_8 t_7) 1.0)
(fmax
1.0
(* t_10 (if (> (/ (fmax t_5 t_4) t_0) (floor maxAniso)) t_8 t_7)))
t_10)))
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 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_1 = powf(floorf(w), 2.0f);
float t_2 = powf(floorf(h), 2.0f);
float t_3 = (t_2 * dY_46_v) * dY_46_v;
float t_4 = fmaf((t_1 * dY_46_u), dY_46_u, t_3);
float t_5 = (t_2 * dX_46_v) * dX_46_v;
float t_6 = fmaxf(fmaf((t_1 * dX_46_u), dX_46_u, t_5), t_4);
float t_7 = sqrtf((1.0f / t_6)) * t_0;
float t_8 = sqrtf(t_6) / floorf(maxAniso);
float t_9 = t_6 / t_0;
float tmp;
if (t_9 > floorf(maxAniso)) {
tmp = floorf(maxAniso);
} else {
tmp = t_9;
}
float t_10 = tmp;
float tmp_1;
if ((fmaxf(t_5, t_3) / t_0) > floorf(maxAniso)) {
tmp_1 = t_8;
} else {
tmp_1 = t_7;
}
float tmp_3;
if (tmp_1 < 1.0f) {
float tmp_4;
if ((fmaxf(t_5, t_4) / t_0) > floorf(maxAniso)) {
tmp_4 = t_8;
} else {
tmp_4 = t_7;
}
tmp_3 = fmaxf(1.0f, (t_10 * tmp_4));
} else {
tmp_3 = t_10;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_1 = floor(w) ^ Float32(2.0) t_2 = floor(h) ^ Float32(2.0) t_3 = Float32(Float32(t_2 * dY_46_v) * dY_46_v) t_4 = fma(Float32(t_1 * dY_46_u), dY_46_u, t_3) t_5 = Float32(Float32(t_2 * dX_46_v) * dX_46_v) t_6 = (fma(Float32(t_1 * dX_46_u), dX_46_u, t_5) != fma(Float32(t_1 * dX_46_u), dX_46_u, t_5)) ? t_4 : ((t_4 != t_4) ? fma(Float32(t_1 * dX_46_u), dX_46_u, t_5) : max(fma(Float32(t_1 * dX_46_u), dX_46_u, t_5), t_4)) t_7 = Float32(sqrt(Float32(Float32(1.0) / t_6)) * t_0) t_8 = Float32(sqrt(t_6) / floor(maxAniso)) t_9 = Float32(t_6 / t_0) tmp = Float32(0.0) if (t_9 > floor(maxAniso)) tmp = floor(maxAniso); else tmp = t_9; end t_10 = tmp tmp_1 = Float32(0.0) if (Float32(((t_5 != t_5) ? t_3 : ((t_3 != t_3) ? t_5 : max(t_5, t_3))) / t_0) > floor(maxAniso)) tmp_1 = t_8; else tmp_1 = t_7; end tmp_3 = Float32(0.0) if (tmp_1 < Float32(1.0)) tmp_4 = Float32(0.0) if (Float32(((t_5 != t_5) ? t_4 : ((t_4 != t_4) ? t_5 : max(t_5, t_4))) / t_0) > floor(maxAniso)) tmp_4 = t_8; else tmp_4 = t_7; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(t_10 * tmp_4) : ((Float32(t_10 * tmp_4) != Float32(t_10 * tmp_4)) ? Float32(1.0) : max(Float32(1.0), Float32(t_10 * tmp_4))); else tmp_3 = t_10; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_1 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_2 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_3 := \left(t\_2 \cdot dY.v\right) \cdot dY.v\\
t_4 := \mathsf{fma}\left(t\_1 \cdot dY.u, dY.u, t\_3\right)\\
t_5 := \left(t\_2 \cdot dX.v\right) \cdot dX.v\\
t_6 := \mathsf{max}\left(\mathsf{fma}\left(t\_1 \cdot dX.u, dX.u, t\_5\right), t\_4\right)\\
t_7 := \sqrt{\frac{1}{t\_6}} \cdot t\_0\\
t_8 := \frac{\sqrt{t\_6}}{\left\lfloor maxAniso\right\rfloor }\\
t_9 := \frac{t\_6}{t\_0}\\
t_10 := \begin{array}{l}
\mathbf{if}\;t\_9 > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}\\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_5, t\_3\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, t\_10 \cdot \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_5, t\_4\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_7\\
\end{array}\right)\\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites38.9%
Taylor expanded in dY.u around 0
Applied rewrites50.0%
Taylor expanded in dX.u around 0
Applied rewrites31.6%
Taylor expanded in dX.u around 0
Applied rewrites32.2%
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:precision binary32
(let* ((t_0
(fabs (* (fma dY.u dX.v (* (- dY.v) dX.u)) (* (floor w) (floor h)))))
(t_1 (pow (floor h) 2.0))
(t_2 (* (* t_1 dY.v) dY.v))
(t_3 (* (* t_1 dX.v) dX.v))
(t_4 (pow (floor w) 2.0))
(t_5 (* t_4 dY.u))
(t_6 (fma (* t_4 dX.u) dX.u t_3))
(t_7 (fmax t_6 (fma t_5 dY.u t_2)))
(t_8 (/ (sqrt t_7) (floor maxAniso)))
(t_9 (* (sqrt (/ 1.0 t_7)) t_0))
(t_10 (/ t_7 t_0))
(t_11 (> t_10 (floor maxAniso))))
(if (< (if (> (/ (fmax t_3 t_2) t_0) (floor maxAniso)) t_8 t_9) 1.0)
(fmax
1.0
(*
(if (> (/ (fmax t_6 (* t_5 dY.u)) t_0) (floor maxAniso))
(floor maxAniso)
t_10)
(if t_11 t_8 t_9)))
(if t_11 (floor maxAniso) t_10))))
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 = fabsf((fmaf(dY_46_u, dX_46_v, (-dY_46_v * dX_46_u)) * (floorf(w) * floorf(h))));
float t_1 = powf(floorf(h), 2.0f);
float t_2 = (t_1 * dY_46_v) * dY_46_v;
float t_3 = (t_1 * dX_46_v) * dX_46_v;
float t_4 = powf(floorf(w), 2.0f);
float t_5 = t_4 * dY_46_u;
float t_6 = fmaf((t_4 * dX_46_u), dX_46_u, t_3);
float t_7 = fmaxf(t_6, fmaf(t_5, dY_46_u, t_2));
float t_8 = sqrtf(t_7) / floorf(maxAniso);
float t_9 = sqrtf((1.0f / t_7)) * t_0;
float t_10 = t_7 / t_0;
int t_11 = t_10 > floorf(maxAniso);
float tmp;
if ((fmaxf(t_3, t_2) / t_0) > floorf(maxAniso)) {
tmp = t_8;
} else {
tmp = t_9;
}
float tmp_3;
if (tmp < 1.0f) {
float tmp_4;
if ((fmaxf(t_6, (t_5 * dY_46_u)) / t_0) > floorf(maxAniso)) {
tmp_4 = floorf(maxAniso);
} else {
tmp_4 = t_10;
}
float tmp_5;
if (t_11) {
tmp_5 = t_8;
} else {
tmp_5 = t_9;
}
tmp_3 = fmaxf(1.0f, (tmp_4 * tmp_5));
} else if (t_11) {
tmp_3 = floorf(maxAniso);
} else {
tmp_3 = t_10;
}
return tmp_3;
}
function code(w, h, dX_46_u, dX_46_v, dY_46_u, dY_46_v, maxAniso) t_0 = abs(Float32(fma(dY_46_u, dX_46_v, Float32(Float32(-dY_46_v) * dX_46_u)) * Float32(floor(w) * floor(h)))) t_1 = floor(h) ^ Float32(2.0) t_2 = Float32(Float32(t_1 * dY_46_v) * dY_46_v) t_3 = Float32(Float32(t_1 * dX_46_v) * dX_46_v) t_4 = floor(w) ^ Float32(2.0) t_5 = Float32(t_4 * dY_46_u) t_6 = fma(Float32(t_4 * dX_46_u), dX_46_u, t_3) t_7 = (t_6 != t_6) ? fma(t_5, dY_46_u, t_2) : ((fma(t_5, dY_46_u, t_2) != fma(t_5, dY_46_u, t_2)) ? t_6 : max(t_6, fma(t_5, dY_46_u, t_2))) t_8 = Float32(sqrt(t_7) / floor(maxAniso)) t_9 = Float32(sqrt(Float32(Float32(1.0) / t_7)) * t_0) t_10 = Float32(t_7 / t_0) t_11 = t_10 > floor(maxAniso) tmp = Float32(0.0) if (Float32(((t_3 != t_3) ? t_2 : ((t_2 != t_2) ? t_3 : max(t_3, t_2))) / t_0) > floor(maxAniso)) tmp = t_8; else tmp = t_9; end tmp_3 = Float32(0.0) if (tmp < Float32(1.0)) tmp_4 = Float32(0.0) if (Float32(((t_6 != t_6) ? Float32(t_5 * dY_46_u) : ((Float32(t_5 * dY_46_u) != Float32(t_5 * dY_46_u)) ? t_6 : max(t_6, Float32(t_5 * dY_46_u)))) / t_0) > floor(maxAniso)) tmp_4 = floor(maxAniso); else tmp_4 = t_10; end tmp_5 = Float32(0.0) if (t_11) tmp_5 = t_8; else tmp_5 = t_9; end tmp_3 = (Float32(1.0) != Float32(1.0)) ? Float32(tmp_4 * tmp_5) : ((Float32(tmp_4 * tmp_5) != Float32(tmp_4 * tmp_5)) ? Float32(1.0) : max(Float32(1.0), Float32(tmp_4 * tmp_5))); elseif (t_11) tmp_3 = floor(maxAniso); else tmp_3 = t_10; end return tmp_3 end
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \left|\mathsf{fma}\left(dY.u, dX.v, \left(-dY.v\right) \cdot dX.u\right) \cdot \left(\left\lfloor w\right\rfloor \cdot \left\lfloor h\right\rfloor \right)\right|\\
t_1 := {\left(\left\lfloor h\right\rfloor \right)}^{2}\\
t_2 := \left(t\_1 \cdot dY.v\right) \cdot dY.v\\
t_3 := \left(t\_1 \cdot dX.v\right) \cdot dX.v\\
t_4 := {\left(\left\lfloor w\right\rfloor \right)}^{2}\\
t_5 := t\_4 \cdot dY.u\\
t_6 := \mathsf{fma}\left(t\_4 \cdot dX.u, dX.u, t\_3\right)\\
t_7 := \mathsf{max}\left(t\_6, \mathsf{fma}\left(t\_5, dY.u, t\_2\right)\right)\\
t_8 := \frac{\sqrt{t\_7}}{\left\lfloor maxAniso\right\rfloor }\\
t_9 := \sqrt{\frac{1}{t\_7}} \cdot t\_0\\
t_10 := \frac{t\_7}{t\_0}\\
t_11 := t\_10 > \left\lfloor maxAniso\right\rfloor \\
\mathbf{if}\;\begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_3, t\_2\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array} < 1:\\
\;\;\;\;\mathsf{max}\left(1, \begin{array}{l}
\mathbf{if}\;\frac{\mathsf{max}\left(t\_6, t\_5 \cdot dY.u\right)}{t\_0} > \left\lfloor maxAniso\right\rfloor :\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array} \cdot \begin{array}{l}
\mathbf{if}\;t\_11:\\
\;\;\;\;t\_8\\
\mathbf{else}:\\
\;\;\;\;t\_9\\
\end{array}\right)\\
\mathbf{elif}\;t\_11:\\
\;\;\;\;\left\lfloor maxAniso\right\rfloor \\
\mathbf{else}:\\
\;\;\;\;t\_10\\
\end{array}
\end{array}
Initial program 96.9%
Taylor expanded in w around 0
Applied rewrites39.3%
Taylor expanded in dY.u around 0
Applied rewrites48.9%
Taylor expanded in dX.u around 0
Applied rewrites31.2%
Taylor expanded in dY.u around inf
Applied rewrites33.5%
herbie shell --seed 2024333
(FPCore (w h dX.u dX.v dY.u dY.v maxAniso)
:name "Anisotropic x16 LOD (ratio of anisotropy)"
: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 (< (if (> (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u))))) (floor maxAniso)) (/ (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 maxAniso)) (/ (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u)))) (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))))))) 1.0) (fmax 1.0 (* (if (> (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u))))) (floor maxAniso)) (floor maxAniso) (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u)))))) (if (> (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u))))) (floor maxAniso)) (/ (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 maxAniso)) (/ (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u)))) (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))))))))) (if (> (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u))))) (floor maxAniso)) (floor maxAniso) (/ (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)))) (fabs (- (* (* (floor w) dX.u) (* (floor h) dY.v)) (* (* (floor h) dX.v) (* (floor w) dY.u))))))))