\[\left(x \cdot y + z\right) \cdot y + t
\]
↓
\[\mathsf{fma}\left(\mathsf{fma}\left(x, y, z\right), y, t\right)
\]
(FPCore (x y z t) :precision binary64 (+ (* (+ (* x y) z) y) t))
↓
(FPCore (x y z t) :precision binary64 (fma (fma x y z) y t))
double code(double x, double y, double z, double t) {
return (((x * y) + z) * y) + t;
}
↓
double code(double x, double y, double z, double t) {
return fma(fma(x, y, z), y, t);
}
function code(x, y, z, t)
return Float64(Float64(Float64(Float64(x * y) + z) * y) + t)
end
↓
function code(x, y, z, t)
return fma(fma(x, y, z), y, t)
end
code[x_, y_, z_, t_] := N[(N[(N[(N[(x * y), $MachinePrecision] + z), $MachinePrecision] * y), $MachinePrecision] + t), $MachinePrecision]
↓
code[x_, y_, z_, t_] := N[(N[(x * y + z), $MachinePrecision] * y + t), $MachinePrecision]
\left(x \cdot y + z\right) \cdot y + t
↓
\mathsf{fma}\left(\mathsf{fma}\left(x, y, z\right), y, t\right)
Alternatives
| Alternative 1 |
|---|
| Error | 26.0 |
|---|
| Cost | 720 |
|---|
\[\begin{array}{l}
\mathbf{if}\;z \leq -1.15 \cdot 10^{+121}:\\
\;\;\;\;y \cdot z\\
\mathbf{elif}\;z \leq -1.05 \cdot 10^{-283}:\\
\;\;\;\;t\\
\mathbf{elif}\;z \leq 4.4 \cdot 10^{-300}:\\
\;\;\;\;y \cdot \left(x \cdot y\right)\\
\mathbf{elif}\;z \leq 6.2 \cdot 10^{+71}:\\
\;\;\;\;t\\
\mathbf{else}:\\
\;\;\;\;y \cdot z\\
\end{array}
\]
| Alternative 2 |
|---|
| Error | 9.9 |
|---|
| Cost | 713 |
|---|
\[\begin{array}{l}
\mathbf{if}\;y \leq -2.4 \cdot 10^{+82} \lor \neg \left(y \leq 3.1 \cdot 10^{+59}\right):\\
\;\;\;\;y \cdot \left(z + x \cdot y\right)\\
\mathbf{else}:\\
\;\;\;\;t + y \cdot z\\
\end{array}
\]
| Alternative 3 |
|---|
| Error | 4.7 |
|---|
| Cost | 713 |
|---|
\[\begin{array}{l}
\mathbf{if}\;z \leq -4 \cdot 10^{+33} \lor \neg \left(z \leq 6.4 \cdot 10^{-21}\right):\\
\;\;\;\;t + y \cdot z\\
\mathbf{else}:\\
\;\;\;\;t + y \cdot \left(x \cdot y\right)\\
\end{array}
\]
| Alternative 4 |
|---|
| Error | 13.5 |
|---|
| Cost | 585 |
|---|
\[\begin{array}{l}
\mathbf{if}\;z \leq -1.12 \cdot 10^{-283} \lor \neg \left(z \leq 4.4 \cdot 10^{-300}\right):\\
\;\;\;\;t + y \cdot z\\
\mathbf{else}:\\
\;\;\;\;y \cdot \left(x \cdot y\right)\\
\end{array}
\]
| Alternative 5 |
|---|
| Error | 0.1 |
|---|
| Cost | 576 |
|---|
\[t + y \cdot \left(z + x \cdot y\right)
\]
| Alternative 6 |
|---|
| Error | 25.5 |
|---|
| Cost | 456 |
|---|
\[\begin{array}{l}
\mathbf{if}\;z \leq -1.05 \cdot 10^{+121}:\\
\;\;\;\;y \cdot z\\
\mathbf{elif}\;z \leq 4.2 \cdot 10^{+74}:\\
\;\;\;\;t\\
\mathbf{else}:\\
\;\;\;\;y \cdot z\\
\end{array}
\]
| Alternative 7 |
|---|
| Error | 29.9 |
|---|
| Cost | 64 |
|---|
\[t
\]