Math FPCore C Julia Wolfram TeX \[\left(\left(x - 1\right) \cdot \log y + \left(z - 1\right) \cdot \log \left(1 - y\right)\right) - t
\]
↓
\[\mathsf{fma}\left(z + -1, \mathsf{log1p}\left(-y\right), \left(x + -1\right) \cdot \log y - t\right)
\]
(FPCore (x y z t)
:precision binary64
(- (+ (* (- x 1.0) (log y)) (* (- z 1.0) (log (- 1.0 y)))) t)) ↓
(FPCore (x y z t)
:precision binary64
(fma (+ z -1.0) (log1p (- y)) (- (* (+ x -1.0) (log y)) t))) double code(double x, double y, double z, double t) {
return (((x - 1.0) * log(y)) + ((z - 1.0) * log((1.0 - y)))) - t;
}
↓
double code(double x, double y, double z, double t) {
return fma((z + -1.0), log1p(-y), (((x + -1.0) * log(y)) - t));
}
function code(x, y, z, t)
return Float64(Float64(Float64(Float64(x - 1.0) * log(y)) + Float64(Float64(z - 1.0) * log(Float64(1.0 - y)))) - t)
end
↓
function code(x, y, z, t)
return fma(Float64(z + -1.0), log1p(Float64(-y)), Float64(Float64(Float64(x + -1.0) * log(y)) - t))
end
code[x_, y_, z_, t_] := N[(N[(N[(N[(x - 1.0), $MachinePrecision] * N[Log[y], $MachinePrecision]), $MachinePrecision] + N[(N[(z - 1.0), $MachinePrecision] * N[Log[N[(1.0 - y), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - t), $MachinePrecision]
↓
code[x_, y_, z_, t_] := N[(N[(z + -1.0), $MachinePrecision] * N[Log[1 + (-y)], $MachinePrecision] + N[(N[(N[(x + -1.0), $MachinePrecision] * N[Log[y], $MachinePrecision]), $MachinePrecision] - t), $MachinePrecision]), $MachinePrecision]
\left(\left(x - 1\right) \cdot \log y + \left(z - 1\right) \cdot \log \left(1 - y\right)\right) - t
↓
\mathsf{fma}\left(z + -1, \mathsf{log1p}\left(-y\right), \left(x + -1\right) \cdot \log y - t\right)
Alternatives Alternative 1 Accuracy 99.8% Cost 19968
\[\mathsf{fma}\left(z + -1, \mathsf{log1p}\left(-y\right), \left(x + -1\right) \cdot \log y - t\right)
\]
Alternative 2 Accuracy 99.8% Cost 19968
\[\mathsf{log1p}\left(-y\right) \cdot \left(z + -1\right) - \mathsf{fma}\left(\log y, 1 - x, t\right)
\]
Alternative 3 Accuracy 99.5% Cost 14144
\[\left(\mathsf{fma}\left(\log y, x + -1, \left(y \cdot y\right) \cdot \left(\left(z + -1\right) \cdot -0.5\right)\right) - y \cdot \left(z + -1\right)\right) - t
\]
Alternative 4 Accuracy 99.5% Cost 7616
\[\left(\left(z + -1\right) \cdot \left(y \cdot \left(y \cdot -0.5\right) - y\right) + \left(x + -1\right) \cdot \log y\right) - t
\]
Alternative 5 Accuracy 88.3% Cost 7497
\[\begin{array}{l}
\mathbf{if}\;x + -1 \leq -1 \lor \neg \left(x + -1 \leq -0.99999986\right):\\
\;\;\;\;\left(x + -1\right) \cdot \log y - t\\
\mathbf{else}:\\
\;\;\;\;\left(y - z \cdot y\right) - \left(\log y + t\right)\\
\end{array}
\]
Alternative 6 Accuracy 88.3% Cost 7433
\[\begin{array}{l}
\mathbf{if}\;x + -1 \leq -1 \lor \neg \left(x + -1 \leq -0.99999986\right):\\
\;\;\;\;\left(x + -1\right) \cdot \log y - t\\
\mathbf{else}:\\
\;\;\;\;\left(\left(-\log y\right) - z \cdot y\right) - t\\
\end{array}
\]
Alternative 7 Accuracy 77.0% Cost 7248
\[\begin{array}{l}
t_1 := \left(x + -1\right) \cdot \log y\\
t_2 := \left(-t\right) - z \cdot y\\
\mathbf{if}\;t \leq -1.25 \cdot 10^{+27}:\\
\;\;\;\;t_2\\
\mathbf{elif}\;t \leq 14000000:\\
\;\;\;\;t_1\\
\mathbf{elif}\;t \leq 2.6 \cdot 10^{+129}:\\
\;\;\;\;-0.5 \cdot \left(y \cdot \left(y \cdot \left(z + -1\right)\right)\right) + \left(\left(y - z \cdot y\right) - t\right)\\
\mathbf{elif}\;t \leq 3.4 \cdot 10^{+165}:\\
\;\;\;\;t_1\\
\mathbf{else}:\\
\;\;\;\;t_2\\
\end{array}
\]
Alternative 8 Accuracy 99.2% Cost 7232
\[\left(\left(x + -1\right) \cdot \log y - y \cdot \left(z + -1\right)\right) - t
\]
Alternative 9 Accuracy 99.0% Cost 7104
\[\left(\left(x + -1\right) \cdot \log y - z \cdot y\right) - t
\]
Alternative 10 Accuracy 73.7% Cost 6921
\[\begin{array}{l}
\mathbf{if}\;x \leq -1.8 \cdot 10^{+157} \lor \neg \left(x \leq 1.7 \cdot 10^{+27}\right):\\
\;\;\;\;x \cdot \log y\\
\mathbf{else}:\\
\;\;\;\;\left(-\log y\right) - t\\
\end{array}
\]
Alternative 11 Accuracy 65.2% Cost 6857
\[\begin{array}{l}
\mathbf{if}\;x \leq -1.8 \cdot 10^{+157} \lor \neg \left(x \leq 10^{+26}\right):\\
\;\;\;\;x \cdot \log y\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \left(y \cdot \left(y \cdot \left(z + -1\right)\right)\right) + \left(\left(y - z \cdot y\right) - t\right)\\
\end{array}
\]
Alternative 12 Accuracy 88.3% Cost 6848
\[\left(x + -1\right) \cdot \log y - t
\]
Alternative 13 Accuracy 46.7% Cost 1088
\[-0.5 \cdot \left(y \cdot \left(y \cdot \left(z + -1\right)\right)\right) + \left(\left(y - z \cdot y\right) - t\right)
\]
Alternative 14 Accuracy 42.9% Cost 520
\[\begin{array}{l}
\mathbf{if}\;t \leq -1.6 \cdot 10^{+27}:\\
\;\;\;\;-t\\
\mathbf{elif}\;t \leq 210000000:\\
\;\;\;\;z \cdot \left(-y\right)\\
\mathbf{else}:\\
\;\;\;\;-t\\
\end{array}
\]
Alternative 15 Accuracy 46.4% Cost 448
\[y \cdot \left(1 - z\right) - t
\]
Alternative 16 Accuracy 46.2% Cost 384
\[\left(-t\right) - z \cdot y
\]
Alternative 17 Accuracy 36.1% Cost 128
\[-t
\]