| Alternative 1 | |
|---|---|
| Error | 1.4 |
| Cost | 6720 |
\[0.5 \cdot \mathsf{log1p}\left(2 \cdot x\right)
\]
(FPCore (x) :precision binary64 (* 0.5 (log1p (/ (* 2.0 x) (- 1.0 x)))))
(FPCore (x) :precision binary64 (* 0.5 (log1p (* x (/ 2.0 (- 1.0 x))))))
double code(double x) {
return 0.5 * log1p(((2.0 * x) / (1.0 - x)));
}
double code(double x) {
return 0.5 * log1p((x * (2.0 / (1.0 - x))));
}
public static double code(double x) {
return 0.5 * Math.log1p(((2.0 * x) / (1.0 - x)));
}
public static double code(double x) {
return 0.5 * Math.log1p((x * (2.0 / (1.0 - x))));
}
def code(x): return 0.5 * math.log1p(((2.0 * x) / (1.0 - x)))
def code(x): return 0.5 * math.log1p((x * (2.0 / (1.0 - x))))
function code(x) return Float64(0.5 * log1p(Float64(Float64(2.0 * x) / Float64(1.0 - x)))) end
function code(x) return Float64(0.5 * log1p(Float64(x * Float64(2.0 / Float64(1.0 - x))))) end
code[x_] := N[(0.5 * N[Log[1 + N[(N[(2.0 * x), $MachinePrecision] / N[(1.0 - x), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
code[x_] := N[(0.5 * N[Log[1 + N[(x * N[(2.0 / N[(1.0 - x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
0.5 \cdot \mathsf{log1p}\left(\frac{2 \cdot x}{1 - x}\right)
0.5 \cdot \mathsf{log1p}\left(x \cdot \frac{2}{1 - x}\right)
Results
Initial program 0.0
Simplified0.0
[Start]0.0 | \[ 0.5 \cdot \mathsf{log1p}\left(\frac{2 \cdot x}{1 - x}\right)
\] |
|---|---|
associate-*l/ [<=]0.0 | \[ 0.5 \cdot \mathsf{log1p}\left(\color{blue}{\frac{2}{1 - x} \cdot x}\right)
\] |
Final simplification0.0
| Alternative 1 | |
|---|---|
| Error | 1.4 |
| Cost | 6720 |
| Alternative 2 | |
|---|---|
| Error | 64.0 |
| Cost | 6592 |
herbie shell --seed 2023039
(FPCore (x)
:name "Rust f64::atanh"
:precision binary64
(* 0.5 (log1p (/ (* 2.0 x) (- 1.0 x)))))