| Alternative 1 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 13376 |
\[\log t + \left(\left(\log y \cdot x - y\right) - z\right)
\]
(FPCore (x y z t) :precision binary64 (+ (- (- (* x (log y)) y) z) (log t)))
(FPCore (x y z t) :precision binary64 (fma (log y) x (- (log t) (+ y z))))
double code(double x, double y, double z, double t) {
return (((x * log(y)) - y) - z) + log(t);
}
double code(double x, double y, double z, double t) {
return fma(log(y), x, (log(t) - (y + z)));
}
function code(x, y, z, t) return Float64(Float64(Float64(Float64(x * log(y)) - y) - z) + log(t)) end
function code(x, y, z, t) return fma(log(y), x, Float64(log(t) - Float64(y + z))) end
code[x_, y_, z_, t_] := N[(N[(N[(N[(x * N[Log[y], $MachinePrecision]), $MachinePrecision] - y), $MachinePrecision] - z), $MachinePrecision] + N[Log[t], $MachinePrecision]), $MachinePrecision]
code[x_, y_, z_, t_] := N[(N[Log[y], $MachinePrecision] * x + N[(N[Log[t], $MachinePrecision] - N[(y + z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\left(\left(x \cdot \log y - y\right) - z\right) + \log t
\mathsf{fma}\left(\log y, x, \log t - \left(y + z\right)\right)
Initial program 99.9%
Simplified99.9%
[Start]99.9 | \[ \left(\left(x \cdot \log y - y\right) - z\right) + \log t
\] |
|---|---|
associate-+l- [=>]99.9 | \[ \color{blue}{\left(x \cdot \log y - y\right) - \left(z - \log t\right)}
\] |
Taylor expanded in x around 0 99.9%
Simplified99.9%
[Start]99.9 | \[ \left(\log y \cdot x + \log t\right) - \left(y + z\right)
\] |
|---|---|
+-commutative [=>]99.9 | \[ \color{blue}{\left(\log t + \log y \cdot x\right)} - \left(y + z\right)
\] |
remove-double-neg [<=]99.9 | \[ \left(\color{blue}{\left(-\left(-\log t\right)\right)} + \log y \cdot x\right) - \left(y + z\right)
\] |
neg-mul-1 [=>]99.9 | \[ \left(\color{blue}{-1 \cdot \left(-\log t\right)} + \log y \cdot x\right) - \left(y + z\right)
\] |
mul-1-neg [<=]99.9 | \[ \left(-1 \cdot \color{blue}{\left(-1 \cdot \log t\right)} + \log y \cdot x\right) - \left(y + z\right)
\] |
associate-*r* [=>]99.9 | \[ \left(\color{blue}{\left(-1 \cdot -1\right) \cdot \log t} + \log y \cdot x\right) - \left(y + z\right)
\] |
metadata-eval [=>]99.9 | \[ \left(\color{blue}{1} \cdot \log t + \log y \cdot x\right) - \left(y + z\right)
\] |
*-commutative [<=]99.9 | \[ \left(\color{blue}{\log t \cdot 1} + \log y \cdot x\right) - \left(y + z\right)
\] |
*-commutative [=>]99.9 | \[ \left(\log t \cdot 1 + \color{blue}{x \cdot \log y}\right) - \left(y + z\right)
\] |
associate-+r- [<=]99.9 | \[ \color{blue}{\log t \cdot 1 + \left(x \cdot \log y - \left(y + z\right)\right)}
\] |
*-rgt-identity [<=]99.9 | \[ \log t \cdot 1 + \color{blue}{\left(x \cdot \log y - \left(y + z\right)\right) \cdot 1}
\] |
distribute-rgt-in [<=]99.9 | \[ \color{blue}{1 \cdot \left(\log t + \left(x \cdot \log y - \left(y + z\right)\right)\right)}
\] |
*-lft-identity [=>]99.9 | \[ \color{blue}{\log t + \left(x \cdot \log y - \left(y + z\right)\right)}
\] |
+-commutative [=>]99.9 | \[ \color{blue}{\left(x \cdot \log y - \left(y + z\right)\right) + \log t}
\] |
associate-+l- [=>]99.9 | \[ \color{blue}{x \cdot \log y - \left(\left(y + z\right) - \log t\right)}
\] |
associate-+r- [<=]99.9 | \[ x \cdot \log y - \color{blue}{\left(y + \left(z - \log t\right)\right)}
\] |
unsub-neg [<=]99.9 | \[ \color{blue}{x \cdot \log y + \left(-\left(y + \left(z - \log t\right)\right)\right)}
\] |
*-commutative [<=]99.9 | \[ \color{blue}{\log y \cdot x} + \left(-\left(y + \left(z - \log t\right)\right)\right)
\] |
fma-udef [<=]99.9 | \[ \color{blue}{\mathsf{fma}\left(\log y, x, -\left(y + \left(z - \log t\right)\right)\right)}
\] |
distribute-neg-in [=>]99.9 | \[ \mathsf{fma}\left(\log y, x, \color{blue}{\left(-y\right) + \left(-\left(z - \log t\right)\right)}\right)
\] |
sub-neg [<=]99.9 | \[ \mathsf{fma}\left(\log y, x, \color{blue}{\left(-y\right) - \left(z - \log t\right)}\right)
\] |
associate--r- [=>]99.9 | \[ \mathsf{fma}\left(\log y, x, \color{blue}{\left(\left(-y\right) - z\right) + \log t}\right)
\] |
+-commutative [=>]99.9 | \[ \mathsf{fma}\left(\log y, x, \color{blue}{\log t + \left(\left(-y\right) - z\right)}\right)
\] |
Final simplification99.9%
| Alternative 1 | |
|---|---|
| Accuracy | 99.9% |
| Cost | 13376 |
| Alternative 2 | |
|---|---|
| Accuracy | 65.8% |
| Cost | 7253 |
| Alternative 3 | |
|---|---|
| Accuracy | 98.8% |
| Cost | 7113 |
| Alternative 4 | |
|---|---|
| Accuracy | 84.7% |
| Cost | 6985 |
| Alternative 5 | |
|---|---|
| Accuracy | 88.7% |
| Cost | 6985 |
| Alternative 6 | |
|---|---|
| Accuracy | 89.1% |
| Cost | 6985 |
| Alternative 7 | |
|---|---|
| Accuracy | 72.3% |
| Cost | 6857 |
| Alternative 8 | |
|---|---|
| Accuracy | 48.3% |
| Cost | 260 |
| Alternative 9 | |
|---|---|
| Accuracy | 58.3% |
| Cost | 256 |
| Alternative 10 | |
|---|---|
| Accuracy | 29.6% |
| Cost | 128 |
herbie shell --seed 2023133
(FPCore (x y z t)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, A"
:precision binary64
(+ (- (- (* x (log y)) y) z) (log t)))