
(FPCore (d) :precision binary64 (+ (* d 10.0) (* d 20.0)))
double code(double d) {
return (d * 10.0) + (d * 20.0);
}
real(8) function code(d)
real(8), intent (in) :: d
code = (d * 10.0d0) + (d * 20.0d0)
end function
public static double code(double d) {
return (d * 10.0) + (d * 20.0);
}
def code(d): return (d * 10.0) + (d * 20.0)
function code(d) return Float64(Float64(d * 10.0) + Float64(d * 20.0)) end
function tmp = code(d) tmp = (d * 10.0) + (d * 20.0); end
code[d_] := N[(N[(d * 10.0), $MachinePrecision] + N[(d * 20.0), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
d \cdot 10 + d \cdot 20
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 1 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (d) :precision binary64 (+ (* d 10.0) (* d 20.0)))
double code(double d) {
return (d * 10.0) + (d * 20.0);
}
real(8) function code(d)
real(8), intent (in) :: d
code = (d * 10.0d0) + (d * 20.0d0)
end function
public static double code(double d) {
return (d * 10.0) + (d * 20.0);
}
def code(d): return (d * 10.0) + (d * 20.0)
function code(d) return Float64(Float64(d * 10.0) + Float64(d * 20.0)) end
function tmp = code(d) tmp = (d * 10.0) + (d * 20.0); end
code[d_] := N[(N[(d * 10.0), $MachinePrecision] + N[(d * 20.0), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
d \cdot 10 + d \cdot 20
\end{array}
(FPCore (d) :precision binary64 (* d 30.0))
double code(double d) {
return d * 30.0;
}
real(8) function code(d)
real(8), intent (in) :: d
code = d * 30.0d0
end function
public static double code(double d) {
return d * 30.0;
}
def code(d): return d * 30.0
function code(d) return Float64(d * 30.0) end
function tmp = code(d) tmp = d * 30.0; end
code[d_] := N[(d * 30.0), $MachinePrecision]
\begin{array}{l}
\\
d \cdot 30
\end{array}
Initial program 99.6%
distribute-lft-out100.0%
metadata-eval100.0%
Simplified100.0%
Final simplification100.0%
(FPCore (d) :precision binary64 (* d 30.0))
double code(double d) {
return d * 30.0;
}
real(8) function code(d)
real(8), intent (in) :: d
code = d * 30.0d0
end function
public static double code(double d) {
return d * 30.0;
}
def code(d): return d * 30.0
function code(d) return Float64(d * 30.0) end
function tmp = code(d) tmp = d * 30.0; end
code[d_] := N[(d * 30.0), $MachinePrecision]
\begin{array}{l}
\\
d \cdot 30
\end{array}
herbie shell --seed 2023182
(FPCore (d)
:name "FastMath test1"
:precision binary64
:herbie-target
(* d 30.0)
(+ (* d 10.0) (* d 20.0)))