Average Error: 0.0 → 0.0
Time: 1.2s
Precision: binary64
\[-\log \left(\frac{1}{x} - 1\right) \]
\[-\mathsf{log1p}\left(-1 + \left(\frac{1}{x} + -1\right)\right) \]
(FPCore (x) :precision binary64 (- (log (- (/ 1.0 x) 1.0))))
(FPCore (x) :precision binary64 (- (log1p (+ -1.0 (+ (/ 1.0 x) -1.0)))))
double code(double x) {
	return -log(((1.0 / x) - 1.0));
}
double code(double x) {
	return -log1p((-1.0 + ((1.0 / x) + -1.0)));
}
public static double code(double x) {
	return -Math.log(((1.0 / x) - 1.0));
}
public static double code(double x) {
	return -Math.log1p((-1.0 + ((1.0 / x) + -1.0)));
}
def code(x):
	return -math.log(((1.0 / x) - 1.0))
def code(x):
	return -math.log1p((-1.0 + ((1.0 / x) + -1.0)))
function code(x)
	return Float64(-log(Float64(Float64(1.0 / x) - 1.0)))
end
function code(x)
	return Float64(-log1p(Float64(-1.0 + Float64(Float64(1.0 / x) + -1.0))))
end
code[x_] := (-N[Log[N[(N[(1.0 / x), $MachinePrecision] - 1.0), $MachinePrecision]], $MachinePrecision])
code[x_] := (-N[Log[1 + N[(-1.0 + N[(N[(1.0 / x), $MachinePrecision] + -1.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision])
-\log \left(\frac{1}{x} - 1\right)
-\mathsf{log1p}\left(-1 + \left(\frac{1}{x} + -1\right)\right)

Error

Bits error versus x

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 0.0

    \[-\log \left(\frac{1}{x} - 1\right) \]
  2. Applied egg-rr0.0

    \[\leadsto -\color{blue}{\mathsf{log1p}\left(\left(\frac{1}{x} + -1\right) - 1\right)} \]
  3. Final simplification0.0

    \[\leadsto -\mathsf{log1p}\left(-1 + \left(\frac{1}{x} + -1\right)\right) \]

Reproduce

herbie shell --seed 2022150 
(FPCore (x)
  :name "neg log"
  :precision binary64
  (- (log (- (/ 1.0 x) 1.0))))