| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 6784 |
\[-\log \left(-1 + \frac{1}{x}\right)
\]
(FPCore (x) :precision binary64 (- (log (- (/ 1.0 x) 1.0))))
(FPCore (x) :precision binary64 (* (log (sqrt (+ -1.0 (/ 1.0 x)))) -2.0))
double code(double x) {
return -log(((1.0 / x) - 1.0));
}
double code(double x) {
return log(sqrt((-1.0 + (1.0 / x)))) * -2.0;
}
real(8) function code(x)
real(8), intent (in) :: x
code = -log(((1.0d0 / x) - 1.0d0))
end function
real(8) function code(x)
real(8), intent (in) :: x
code = log(sqrt(((-1.0d0) + (1.0d0 / x)))) * (-2.0d0)
end function
public static double code(double x) {
return -Math.log(((1.0 / x) - 1.0));
}
public static double code(double x) {
return Math.log(Math.sqrt((-1.0 + (1.0 / x)))) * -2.0;
}
def code(x): return -math.log(((1.0 / x) - 1.0))
def code(x): return math.log(math.sqrt((-1.0 + (1.0 / x)))) * -2.0
function code(x) return Float64(-log(Float64(Float64(1.0 / x) - 1.0))) end
function code(x) return Float64(log(sqrt(Float64(-1.0 + Float64(1.0 / x)))) * -2.0) end
function tmp = code(x) tmp = -log(((1.0 / x) - 1.0)); end
function tmp = code(x) tmp = log(sqrt((-1.0 + (1.0 / x)))) * -2.0; end
code[x_] := (-N[Log[N[(N[(1.0 / x), $MachinePrecision] - 1.0), $MachinePrecision]], $MachinePrecision])
code[x_] := N[(N[Log[N[Sqrt[N[(-1.0 + N[(1.0 / x), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]], $MachinePrecision] * -2.0), $MachinePrecision]
-\log \left(\frac{1}{x} - 1\right)
\log \left(\sqrt{-1 + \frac{1}{x}}\right) \cdot -2
Results
Initial program 0.0
Applied egg-rr32.1
Applied egg-rr0.0
Final simplification0.0
| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 6784 |
| Alternative 2 | |
|---|---|
| Error | 0.6 |
| Cost | 6592 |
| Alternative 3 | |
|---|---|
| Error | 1.2 |
| Cost | 6464 |
| Alternative 4 | |
|---|---|
| Error | 62.6 |
| Cost | 64 |
herbie shell --seed 2022328
(FPCore (x)
:name "neg log"
:precision binary64
(- (log (- (/ 1.0 x) 1.0))))