| Alternative 1 | |
|---|---|
| Accuracy | 99.6% |
| Cost | 26304 |
\[\log \left(x + y\right) + \mathsf{fma}\left(a + -0.5, \log t, \log z - t\right)
\]

(FPCore (x y z t a) :precision binary64 (+ (- (+ (log (+ x y)) (log z)) t) (* (- a 0.5) (log t))))
(FPCore (x y z t a) :precision binary64 (+ (log (+ x y)) (fma (+ a -0.5) (log t) (- (log z) t))))
double code(double x, double y, double z, double t, double a) {
return ((log((x + y)) + log(z)) - t) + ((a - 0.5) * log(t));
}
double code(double x, double y, double z, double t, double a) {
return log((x + y)) + fma((a + -0.5), log(t), (log(z) - t));
}
function code(x, y, z, t, a) return Float64(Float64(Float64(log(Float64(x + y)) + log(z)) - t) + Float64(Float64(a - 0.5) * log(t))) end
function code(x, y, z, t, a) return Float64(log(Float64(x + y)) + fma(Float64(a + -0.5), log(t), Float64(log(z) - t))) end
code[x_, y_, z_, t_, a_] := N[(N[(N[(N[Log[N[(x + y), $MachinePrecision]], $MachinePrecision] + N[Log[z], $MachinePrecision]), $MachinePrecision] - t), $MachinePrecision] + N[(N[(a - 0.5), $MachinePrecision] * N[Log[t], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
code[x_, y_, z_, t_, a_] := N[(N[Log[N[(x + y), $MachinePrecision]], $MachinePrecision] + N[(N[(a + -0.5), $MachinePrecision] * N[Log[t], $MachinePrecision] + N[(N[Log[z], $MachinePrecision] - t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(a - 0.5\right) \cdot \log t
\log \left(x + y\right) + \mathsf{fma}\left(a + -0.5, \log t, \log z - t\right)
Herbie found 17 alternatives:
| Alternative | Accuracy | Speedup |
|---|
| Original | 99.6% |
|---|---|
| Target | 99.6% |
| Herbie | 99.6% |
Initial program 99.6%
Simplified99.6%
[Start]99.6% | \[ \left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(a - 0.5\right) \cdot \log t
\] |
|---|---|
associate--l+ [=>]99.6% | \[ \color{blue}{\left(\log \left(x + y\right) + \left(\log z - t\right)\right)} + \left(a - 0.5\right) \cdot \log t
\] |
associate-+l+ [=>]99.6% | \[ \color{blue}{\log \left(x + y\right) + \left(\left(\log z - t\right) + \left(a - 0.5\right) \cdot \log t\right)}
\] |
+-commutative [=>]99.6% | \[ \log \left(x + y\right) + \color{blue}{\left(\left(a - 0.5\right) \cdot \log t + \left(\log z - t\right)\right)}
\] |
fma-def [=>]99.6% | \[ \log \left(x + y\right) + \color{blue}{\mathsf{fma}\left(a - 0.5, \log t, \log z - t\right)}
\] |
remove-double-neg [<=]99.6% | \[ \log \left(x + y\right) + \mathsf{fma}\left(\color{blue}{-\left(-\left(a - 0.5\right)\right)}, \log t, \log z - t\right)
\] |
remove-double-neg [=>]99.6% | \[ \log \left(x + y\right) + \mathsf{fma}\left(\color{blue}{a - 0.5}, \log t, \log z - t\right)
\] |
sub-neg [=>]99.6% | \[ \log \left(x + y\right) + \mathsf{fma}\left(\color{blue}{a + \left(-0.5\right)}, \log t, \log z - t\right)
\] |
metadata-eval [=>]99.6% | \[ \log \left(x + y\right) + \mathsf{fma}\left(a + \color{blue}{-0.5}, \log t, \log z - t\right)
\] |
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 99.6% |
| Cost | 26304 |
| Alternative 2 | |
|---|---|
| Accuracy | 75.4% |
| Cost | 20108 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.6% |
| Cost | 20032 |
| Alternative 4 | |
|---|---|
| Accuracy | 80.3% |
| Cost | 19908 |
| Alternative 5 | |
|---|---|
| Accuracy | 80.4% |
| Cost | 19908 |
| Alternative 6 | |
|---|---|
| Accuracy | 68.8% |
| Cost | 19904 |
| Alternative 7 | |
|---|---|
| Accuracy | 84.2% |
| Cost | 13900 |
| Alternative 8 | |
|---|---|
| Accuracy | 73.6% |
| Cost | 13708 |
| Alternative 9 | |
|---|---|
| Accuracy | 73.1% |
| Cost | 13641 |
| Alternative 10 | |
|---|---|
| Accuracy | 66.2% |
| Cost | 13636 |
| Alternative 11 | |
|---|---|
| Accuracy | 73.0% |
| Cost | 13577 |
| Alternative 12 | |
|---|---|
| Accuracy | 77.2% |
| Cost | 13184 |
| Alternative 13 | |
|---|---|
| Accuracy | 56.6% |
| Cost | 7048 |
| Alternative 14 | |
|---|---|
| Accuracy | 56.6% |
| Cost | 6857 |
| Alternative 15 | |
|---|---|
| Accuracy | 40.6% |
| Cost | 6724 |
| Alternative 16 | |
|---|---|
| Accuracy | 62.0% |
| Cost | 6724 |
| Alternative 17 | |
|---|---|
| Accuracy | 37.4% |
| Cost | 128 |
herbie shell --seed 2023171
(FPCore (x y z t a)
:name "Numeric.SpecFunctions:logGammaL from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(+ (log (+ x y)) (+ (- (log z) t) (* (- a 0.5) (log t))))
(+ (- (+ (log (+ x y)) (log z)) t) (* (- a 0.5) (log t))))