| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 12992 |
\[\sqrt{1 + e^{x}}
\]
(FPCore (x) :precision binary64 (sqrt (/ (- (exp (* 2.0 x)) 1.0) (- (exp x) 1.0))))
(FPCore (x) :precision binary64 (hypot 1.0 (sqrt (exp x))))
double code(double x) {
return sqrt(((exp((2.0 * x)) - 1.0) / (exp(x) - 1.0)));
}
double code(double x) {
return hypot(1.0, sqrt(exp(x)));
}
public static double code(double x) {
return Math.sqrt(((Math.exp((2.0 * x)) - 1.0) / (Math.exp(x) - 1.0)));
}
public static double code(double x) {
return Math.hypot(1.0, Math.sqrt(Math.exp(x)));
}
def code(x): return math.sqrt(((math.exp((2.0 * x)) - 1.0) / (math.exp(x) - 1.0)))
def code(x): return math.hypot(1.0, math.sqrt(math.exp(x)))
function code(x) return sqrt(Float64(Float64(exp(Float64(2.0 * x)) - 1.0) / Float64(exp(x) - 1.0))) end
function code(x) return hypot(1.0, sqrt(exp(x))) end
function tmp = code(x) tmp = sqrt(((exp((2.0 * x)) - 1.0) / (exp(x) - 1.0))); end
function tmp = code(x) tmp = hypot(1.0, sqrt(exp(x))); end
code[x_] := N[Sqrt[N[(N[(N[Exp[N[(2.0 * x), $MachinePrecision]], $MachinePrecision] - 1.0), $MachinePrecision] / N[(N[Exp[x], $MachinePrecision] - 1.0), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
code[x_] := N[Sqrt[1.0 ^ 2 + N[Sqrt[N[Exp[x], $MachinePrecision]], $MachinePrecision] ^ 2], $MachinePrecision]
\sqrt{\frac{e^{2 \cdot x} - 1}{e^{x} - 1}}
\mathsf{hypot}\left(1, \sqrt{e^{x}}\right)
Results
Initial program 41.1
Simplified0.0
Applied egg-rr0.0
Final simplification0.0
| Alternative 1 | |
|---|---|
| Error | 0.0 |
| Cost | 12992 |
| Alternative 2 | |
|---|---|
| Error | 17.8 |
| Cost | 6464 |
| Alternative 3 | |
|---|---|
| Error | 54.9 |
| Cost | 320 |
| Alternative 4 | |
|---|---|
| Error | 62.1 |
| Cost | 192 |
| Alternative 5 | |
|---|---|
| Error | 61.2 |
| Cost | 192 |

herbie shell --seed 2022300
(FPCore (x)
:name "sqrtexp (problem 3.4.4)"
:precision binary64
(sqrt (/ (- (exp (* 2.0 x)) 1.0) (- (exp x) 1.0))))