
(FPCore (a b) :precision binary64 (exp (+ (log a) (log b))))
double code(double a, double b) {
return exp((log(a) + log(b)));
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = exp((log(a) + log(b)))
end function
public static double code(double a, double b) {
return Math.exp((Math.log(a) + Math.log(b)));
}
def code(a, b): return math.exp((math.log(a) + math.log(b)))
function code(a, b) return exp(Float64(log(a) + log(b))) end
function tmp = code(a, b) tmp = exp((log(a) + log(b))); end
code[a_, b_] := N[Exp[N[(N[Log[a], $MachinePrecision] + N[Log[b], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
e^{\log a + \log b}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 1 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (a b) :precision binary64 (exp (+ (log a) (log b))))
double code(double a, double b) {
return exp((log(a) + log(b)));
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = exp((log(a) + log(b)))
end function
public static double code(double a, double b) {
return Math.exp((Math.log(a) + Math.log(b)));
}
def code(a, b): return math.exp((math.log(a) + math.log(b)))
function code(a, b) return exp(Float64(log(a) + log(b))) end
function tmp = code(a, b) tmp = exp((log(a) + log(b))); end
code[a_, b_] := N[Exp[N[(N[Log[a], $MachinePrecision] + N[Log[b], $MachinePrecision]), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
e^{\log a + \log b}
\end{array}
(FPCore (a b) :precision binary64 (* a b))
double code(double a, double b) {
return a * b;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = a * b
end function
public static double code(double a, double b) {
return a * b;
}
def code(a, b): return a * b
function code(a, b) return Float64(a * b) end
function tmp = code(a, b) tmp = a * b; end
code[a_, b_] := N[(a * b), $MachinePrecision]
\begin{array}{l}
\\
a \cdot b
\end{array}
Initial program 92.3%
exp-sum92.8%
rem-exp-log93.9%
rem-exp-log100.0%
Simplified100.0%
Final simplification100.0%
(FPCore (a b) :precision binary64 (* a b))
double code(double a, double b) {
return a * b;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = a * b
end function
public static double code(double a, double b) {
return a * b;
}
def code(a, b): return a * b
function code(a, b) return Float64(a * b) end
function tmp = code(a, b) tmp = a * b; end
code[a_, b_] := N[(a * b), $MachinePrecision]
\begin{array}{l}
\\
a \cdot b
\end{array}
herbie shell --seed 2023175
(FPCore (a b)
:name "Exp of sum of logs"
:precision binary64
:herbie-target
(* a b)
(exp (+ (log a) (log b))))