
(FPCore (x) :precision binary64 (acosh x))
double code(double x) {
return acosh(x);
}
def code(x): return math.acosh(x)
function code(x) return acosh(x) end
function tmp = code(x) tmp = acosh(x); end
code[x_] := N[ArcCosh[x], $MachinePrecision]
\begin{array}{l}
\\
\cosh^{-1} x
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 6 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x) :precision binary64 (log (+ x (sqrt (- (* x x) 1.0)))))
double code(double x) {
return log((x + sqrt(((x * x) - 1.0))));
}
real(8) function code(x)
real(8), intent (in) :: x
code = log((x + sqrt(((x * x) - 1.0d0))))
end function
public static double code(double x) {
return Math.log((x + Math.sqrt(((x * x) - 1.0))));
}
def code(x): return math.log((x + math.sqrt(((x * x) - 1.0))))
function code(x) return log(Float64(x + sqrt(Float64(Float64(x * x) - 1.0)))) end
function tmp = code(x) tmp = log((x + sqrt(((x * x) - 1.0)))); end
code[x_] := N[Log[N[(x + N[Sqrt[N[(N[(x * x), $MachinePrecision] - 1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\log \left(x + \sqrt{x \cdot x - 1}\right)
\end{array}
(FPCore (x) :precision binary64 (if (<= (+ x (sqrt (+ (* x x) -1.0))) 5000.0) (log (+ x (cbrt (pow (fma x x -1.0) 1.5)))) (- (log (/ 0.5 x)))))
double code(double x) {
double tmp;
if ((x + sqrt(((x * x) + -1.0))) <= 5000.0) {
tmp = log((x + cbrt(pow(fma(x, x, -1.0), 1.5))));
} else {
tmp = -log((0.5 / x));
}
return tmp;
}
function code(x) tmp = 0.0 if (Float64(x + sqrt(Float64(Float64(x * x) + -1.0))) <= 5000.0) tmp = log(Float64(x + cbrt((fma(x, x, -1.0) ^ 1.5)))); else tmp = Float64(-log(Float64(0.5 / x))); end return tmp end
code[x_] := If[LessEqual[N[(x + N[Sqrt[N[(N[(x * x), $MachinePrecision] + -1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 5000.0], N[Log[N[(x + N[Power[N[Power[N[(x * x + -1.0), $MachinePrecision], 1.5], $MachinePrecision], 1/3], $MachinePrecision]), $MachinePrecision]], $MachinePrecision], (-N[Log[N[(0.5 / x), $MachinePrecision]], $MachinePrecision])]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x + \sqrt{x \cdot x + -1} \leq 5000:\\
\;\;\;\;\log \left(x + \sqrt[3]{{\left(\mathsf{fma}\left(x, x, -1\right)\right)}^{1.5}}\right)\\
\mathbf{else}:\\
\;\;\;\;-\log \left(\frac{0.5}{x}\right)\\
\end{array}
\end{array}
if (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) < 5e3Initial program 99.2%
add-cbrt-cube99.5%
pow399.2%
sqrt-pow299.7%
fma-neg99.7%
metadata-eval99.7%
metadata-eval99.7%
Applied egg-rr99.7%
if 5e3 < (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) Initial program 49.2%
flip-+0.0%
div-inv0.0%
log-prod0.0%
add-sqr-sqrt0.0%
fma-neg0.0%
metadata-eval0.0%
fma-neg0.0%
metadata-eval0.0%
Applied egg-rr0.0%
fma-udef0.0%
associate--r+1.5%
sub-neg1.5%
+-inverses1.8%
metadata-eval1.8%
metadata-eval1.8%
metadata-eval1.8%
+-lft-identity1.8%
log-rec1.5%
Simplified1.5%
Taylor expanded in x around inf 100.0%
Final simplification100.0%
(FPCore (x) :precision binary64 (if (<= (+ x (sqrt (+ (* x x) -1.0))) 2e+21) (log1p (+ (+ x (sqrt (fma x x -1.0))) -1.0)) (- (log (/ 0.5 x)))))
double code(double x) {
double tmp;
if ((x + sqrt(((x * x) + -1.0))) <= 2e+21) {
tmp = log1p(((x + sqrt(fma(x, x, -1.0))) + -1.0));
} else {
tmp = -log((0.5 / x));
}
return tmp;
}
function code(x) tmp = 0.0 if (Float64(x + sqrt(Float64(Float64(x * x) + -1.0))) <= 2e+21) tmp = log1p(Float64(Float64(x + sqrt(fma(x, x, -1.0))) + -1.0)); else tmp = Float64(-log(Float64(0.5 / x))); end return tmp end
code[x_] := If[LessEqual[N[(x + N[Sqrt[N[(N[(x * x), $MachinePrecision] + -1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], 2e+21], N[Log[1 + N[(N[(x + N[Sqrt[N[(x * x + -1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision]], $MachinePrecision], (-N[Log[N[(0.5 / x), $MachinePrecision]], $MachinePrecision])]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x + \sqrt{x \cdot x + -1} \leq 2 \cdot 10^{+21}:\\
\;\;\;\;\mathsf{log1p}\left(\left(x + \sqrt{\mathsf{fma}\left(x, x, -1\right)}\right) + -1\right)\\
\mathbf{else}:\\
\;\;\;\;-\log \left(\frac{0.5}{x}\right)\\
\end{array}
\end{array}
if (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) < 2e21Initial program 99.7%
log1p-expm1-u99.7%
expm1-udef99.7%
add-exp-log99.8%
fma-neg99.8%
metadata-eval99.8%
Applied egg-rr99.8%
if 2e21 < (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) Initial program 46.9%
flip-+0.0%
div-inv0.0%
log-prod0.0%
add-sqr-sqrt0.0%
fma-neg0.0%
metadata-eval0.0%
fma-neg0.0%
metadata-eval0.0%
Applied egg-rr0.0%
fma-udef0.0%
associate--r+1.4%
sub-neg1.4%
+-inverses1.8%
metadata-eval1.8%
metadata-eval1.8%
metadata-eval1.8%
+-lft-identity1.8%
log-rec1.4%
Simplified1.4%
Taylor expanded in x around inf 100.0%
Final simplification100.0%
(FPCore (x) :precision binary64 (let* ((t_0 (+ x (sqrt (+ (* x x) -1.0))))) (if (<= t_0 2e+21) (log t_0) (- (log (/ 0.5 x))))))
double code(double x) {
double t_0 = x + sqrt(((x * x) + -1.0));
double tmp;
if (t_0 <= 2e+21) {
tmp = log(t_0);
} else {
tmp = -log((0.5 / x));
}
return tmp;
}
real(8) function code(x)
real(8), intent (in) :: x
real(8) :: t_0
real(8) :: tmp
t_0 = x + sqrt(((x * x) + (-1.0d0)))
if (t_0 <= 2d+21) then
tmp = log(t_0)
else
tmp = -log((0.5d0 / x))
end if
code = tmp
end function
public static double code(double x) {
double t_0 = x + Math.sqrt(((x * x) + -1.0));
double tmp;
if (t_0 <= 2e+21) {
tmp = Math.log(t_0);
} else {
tmp = -Math.log((0.5 / x));
}
return tmp;
}
def code(x): t_0 = x + math.sqrt(((x * x) + -1.0)) tmp = 0 if t_0 <= 2e+21: tmp = math.log(t_0) else: tmp = -math.log((0.5 / x)) return tmp
function code(x) t_0 = Float64(x + sqrt(Float64(Float64(x * x) + -1.0))) tmp = 0.0 if (t_0 <= 2e+21) tmp = log(t_0); else tmp = Float64(-log(Float64(0.5 / x))); end return tmp end
function tmp_2 = code(x) t_0 = x + sqrt(((x * x) + -1.0)); tmp = 0.0; if (t_0 <= 2e+21) tmp = log(t_0); else tmp = -log((0.5 / x)); end tmp_2 = tmp; end
code[x_] := Block[{t$95$0 = N[(x + N[Sqrt[N[(N[(x * x), $MachinePrecision] + -1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$0, 2e+21], N[Log[t$95$0], $MachinePrecision], (-N[Log[N[(0.5 / x), $MachinePrecision]], $MachinePrecision])]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := x + \sqrt{x \cdot x + -1}\\
\mathbf{if}\;t_0 \leq 2 \cdot 10^{+21}:\\
\;\;\;\;\log t_0\\
\mathbf{else}:\\
\;\;\;\;-\log \left(\frac{0.5}{x}\right)\\
\end{array}
\end{array}
if (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) < 2e21Initial program 99.7%
if 2e21 < (+.f64 x (sqrt.f64 (-.f64 (*.f64 x x) 1))) Initial program 46.9%
flip-+0.0%
div-inv0.0%
log-prod0.0%
add-sqr-sqrt0.0%
fma-neg0.0%
metadata-eval0.0%
fma-neg0.0%
metadata-eval0.0%
Applied egg-rr0.0%
fma-udef0.0%
associate--r+1.4%
sub-neg1.4%
+-inverses1.8%
metadata-eval1.8%
metadata-eval1.8%
metadata-eval1.8%
+-lft-identity1.8%
log-rec1.4%
Simplified1.4%
Taylor expanded in x around inf 100.0%
Final simplification100.0%
(FPCore (x) :precision binary64 (- (log (/ 0.5 x))))
double code(double x) {
return -log((0.5 / x));
}
real(8) function code(x)
real(8), intent (in) :: x
code = -log((0.5d0 / x))
end function
public static double code(double x) {
return -Math.log((0.5 / x));
}
def code(x): return -math.log((0.5 / x))
function code(x) return Float64(-log(Float64(0.5 / x))) end
function tmp = code(x) tmp = -log((0.5 / x)); end
code[x_] := (-N[Log[N[(0.5 / x), $MachinePrecision]], $MachinePrecision])
\begin{array}{l}
\\
-\log \left(\frac{0.5}{x}\right)
\end{array}
Initial program 50.4%
flip-+2.2%
div-inv2.2%
log-prod2.2%
add-sqr-sqrt2.2%
fma-neg2.2%
metadata-eval2.2%
fma-neg2.2%
metadata-eval2.2%
Applied egg-rr2.2%
fma-udef2.2%
associate--r+3.6%
sub-neg3.6%
+-inverses3.9%
metadata-eval3.9%
metadata-eval3.9%
metadata-eval3.9%
+-lft-identity3.9%
log-rec3.6%
Simplified3.6%
Taylor expanded in x around inf 98.4%
Final simplification98.4%
(FPCore (x) :precision binary64 (log (+ x x)))
double code(double x) {
return log((x + x));
}
real(8) function code(x)
real(8), intent (in) :: x
code = log((x + x))
end function
public static double code(double x) {
return Math.log((x + x));
}
def code(x): return math.log((x + x))
function code(x) return log(Float64(x + x)) end
function tmp = code(x) tmp = log((x + x)); end
code[x_] := N[Log[N[(x + x), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\log \left(x + x\right)
\end{array}
Initial program 50.4%
Taylor expanded in x around inf 98.0%
Final simplification98.0%
(FPCore (x) :precision binary64 0.0)
double code(double x) {
return 0.0;
}
real(8) function code(x)
real(8), intent (in) :: x
code = 0.0d0
end function
public static double code(double x) {
return 0.0;
}
def code(x): return 0.0
function code(x) return 0.0 end
function tmp = code(x) tmp = 0.0; end
code[x_] := 0.0
\begin{array}{l}
\\
0
\end{array}
Initial program 50.4%
Taylor expanded in x around inf 98.0%
flip-+0.0%
log-div0.0%
+-inverses0.0%
+-inverses0.0%
Applied egg-rr0.0%
+-inverses3.1%
Simplified3.1%
Final simplification3.1%
(FPCore (x) :precision binary64 (log (+ x (* (sqrt (- x 1.0)) (sqrt (+ x 1.0))))))
double code(double x) {
return log((x + (sqrt((x - 1.0)) * sqrt((x + 1.0)))));
}
real(8) function code(x)
real(8), intent (in) :: x
code = log((x + (sqrt((x - 1.0d0)) * sqrt((x + 1.0d0)))))
end function
public static double code(double x) {
return Math.log((x + (Math.sqrt((x - 1.0)) * Math.sqrt((x + 1.0)))));
}
def code(x): return math.log((x + (math.sqrt((x - 1.0)) * math.sqrt((x + 1.0)))))
function code(x) return log(Float64(x + Float64(sqrt(Float64(x - 1.0)) * sqrt(Float64(x + 1.0))))) end
function tmp = code(x) tmp = log((x + (sqrt((x - 1.0)) * sqrt((x + 1.0))))); end
code[x_] := N[Log[N[(x + N[(N[Sqrt[N[(x - 1.0), $MachinePrecision]], $MachinePrecision] * N[Sqrt[N[(x + 1.0), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\log \left(x + \sqrt{x - 1} \cdot \sqrt{x + 1}\right)
\end{array}
herbie shell --seed 2023201
(FPCore (x)
:name "Rust f64::acosh"
:precision binary64
:pre (>= x 1.0)
:herbie-target
(log (+ x (* (sqrt (- x 1.0)) (sqrt (+ x 1.0)))))
(log (+ x (sqrt (- (* x x) 1.0)))))