
(FPCore (a b) :precision binary64 (- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (- 1.0 a)) (* (* b b) (+ 3.0 a))))) 1.0))
double code(double a, double b) {
return (pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = ((((a * a) + (b * b)) ** 2.0d0) + (4.0d0 * (((a * a) * (1.0d0 - a)) + ((b * b) * (3.0d0 + a))))) - 1.0d0
end function
public static double code(double a, double b) {
return (Math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0;
}
def code(a, b): return (math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0
function code(a, b) return Float64(Float64((Float64(Float64(a * a) + Float64(b * b)) ^ 2.0) + Float64(4.0 * Float64(Float64(Float64(a * a) * Float64(1.0 - a)) + Float64(Float64(b * b) * Float64(3.0 + a))))) - 1.0) end
function tmp = code(a, b) tmp = ((((a * a) + (b * b)) ^ 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0; end
code[a_, b_] := N[(N[(N[Power[N[(N[(a * a), $MachinePrecision] + N[(b * b), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision] + N[(4.0 * N[(N[(N[(a * a), $MachinePrecision] * N[(1.0 - a), $MachinePrecision]), $MachinePrecision] + N[(N[(b * b), $MachinePrecision] * N[(3.0 + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - 1.0), $MachinePrecision]
\begin{array}{l}
\\
\left({\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 - a\right) + \left(b \cdot b\right) \cdot \left(3 + a\right)\right)\right) - 1
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 8 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (a b) :precision binary64 (- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (- 1.0 a)) (* (* b b) (+ 3.0 a))))) 1.0))
double code(double a, double b) {
return (pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = ((((a * a) + (b * b)) ** 2.0d0) + (4.0d0 * (((a * a) * (1.0d0 - a)) + ((b * b) * (3.0d0 + a))))) - 1.0d0
end function
public static double code(double a, double b) {
return (Math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0;
}
def code(a, b): return (math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0
function code(a, b) return Float64(Float64((Float64(Float64(a * a) + Float64(b * b)) ^ 2.0) + Float64(4.0 * Float64(Float64(Float64(a * a) * Float64(1.0 - a)) + Float64(Float64(b * b) * Float64(3.0 + a))))) - 1.0) end
function tmp = code(a, b) tmp = ((((a * a) + (b * b)) ^ 2.0) + (4.0 * (((a * a) * (1.0 - a)) + ((b * b) * (3.0 + a))))) - 1.0; end
code[a_, b_] := N[(N[(N[Power[N[(N[(a * a), $MachinePrecision] + N[(b * b), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision] + N[(4.0 * N[(N[(N[(a * a), $MachinePrecision] * N[(1.0 - a), $MachinePrecision]), $MachinePrecision] + N[(N[(b * b), $MachinePrecision] * N[(3.0 + a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] - 1.0), $MachinePrecision]
\begin{array}{l}
\\
\left({\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 - a\right) + \left(b \cdot b\right) \cdot \left(3 + a\right)\right)\right) - 1
\end{array}
(FPCore (a b) :precision binary64 (+ (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* a a) (* (* b b) 3.0)))) -1.0))
double code(double a, double b) {
return (pow(((a * a) + (b * b)), 2.0) + (4.0 * ((a * a) + ((b * b) * 3.0)))) + -1.0;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = ((((a * a) + (b * b)) ** 2.0d0) + (4.0d0 * ((a * a) + ((b * b) * 3.0d0)))) + (-1.0d0)
end function
public static double code(double a, double b) {
return (Math.pow(((a * a) + (b * b)), 2.0) + (4.0 * ((a * a) + ((b * b) * 3.0)))) + -1.0;
}
def code(a, b): return (math.pow(((a * a) + (b * b)), 2.0) + (4.0 * ((a * a) + ((b * b) * 3.0)))) + -1.0
function code(a, b) return Float64(Float64((Float64(Float64(a * a) + Float64(b * b)) ^ 2.0) + Float64(4.0 * Float64(Float64(a * a) + Float64(Float64(b * b) * 3.0)))) + -1.0) end
function tmp = code(a, b) tmp = ((((a * a) + (b * b)) ^ 2.0) + (4.0 * ((a * a) + ((b * b) * 3.0)))) + -1.0; end
code[a_, b_] := N[(N[(N[Power[N[(N[(a * a), $MachinePrecision] + N[(b * b), $MachinePrecision]), $MachinePrecision], 2.0], $MachinePrecision] + N[(4.0 * N[(N[(a * a), $MachinePrecision] + N[(N[(b * b), $MachinePrecision] * 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision]
\begin{array}{l}
\\
\left({\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(a \cdot a + \left(b \cdot b\right) \cdot 3\right)\right) + -1
\end{array}
Initial program 76.4%
Taylor expanded in a around 0 91.3%
Taylor expanded in a around 0 99.1%
Final simplification99.1%
(FPCore (a b) :precision binary64 (if (<= a -10500.0) (* (pow a 4.0) (- 1.0 (/ 4.0 a))) (if (<= a 4.5e+17) (+ (+ (* (* b b) 12.0) (pow b 4.0)) -1.0) (pow a 4.0))))
double code(double a, double b) {
double tmp;
if (a <= -10500.0) {
tmp = pow(a, 4.0) * (1.0 - (4.0 / a));
} else if (a <= 4.5e+17) {
tmp = (((b * b) * 12.0) + pow(b, 4.0)) + -1.0;
} else {
tmp = pow(a, 4.0);
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if (a <= (-10500.0d0)) then
tmp = (a ** 4.0d0) * (1.0d0 - (4.0d0 / a))
else if (a <= 4.5d+17) then
tmp = (((b * b) * 12.0d0) + (b ** 4.0d0)) + (-1.0d0)
else
tmp = a ** 4.0d0
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if (a <= -10500.0) {
tmp = Math.pow(a, 4.0) * (1.0 - (4.0 / a));
} else if (a <= 4.5e+17) {
tmp = (((b * b) * 12.0) + Math.pow(b, 4.0)) + -1.0;
} else {
tmp = Math.pow(a, 4.0);
}
return tmp;
}
def code(a, b): tmp = 0 if a <= -10500.0: tmp = math.pow(a, 4.0) * (1.0 - (4.0 / a)) elif a <= 4.5e+17: tmp = (((b * b) * 12.0) + math.pow(b, 4.0)) + -1.0 else: tmp = math.pow(a, 4.0) return tmp
function code(a, b) tmp = 0.0 if (a <= -10500.0) tmp = Float64((a ^ 4.0) * Float64(1.0 - Float64(4.0 / a))); elseif (a <= 4.5e+17) tmp = Float64(Float64(Float64(Float64(b * b) * 12.0) + (b ^ 4.0)) + -1.0); else tmp = a ^ 4.0; end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (a <= -10500.0) tmp = (a ^ 4.0) * (1.0 - (4.0 / a)); elseif (a <= 4.5e+17) tmp = (((b * b) * 12.0) + (b ^ 4.0)) + -1.0; else tmp = a ^ 4.0; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[a, -10500.0], N[(N[Power[a, 4.0], $MachinePrecision] * N[(1.0 - N[(4.0 / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 4.5e+17], N[(N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + N[Power[b, 4.0], $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision], N[Power[a, 4.0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -10500:\\
\;\;\;\;{a}^{4} \cdot \left(1 - \frac{4}{a}\right)\\
\mathbf{elif}\;a \leq 4.5 \cdot 10^{+17}:\\
\;\;\;\;\left(\left(b \cdot b\right) \cdot 12 + {b}^{4}\right) + -1\\
\mathbf{else}:\\
\;\;\;\;{a}^{4}\\
\end{array}
\end{array}
if a < -10500Initial program 67.0%
associate--l+67.0%
fma-define67.0%
distribute-rgt-in67.0%
sqr-neg67.0%
distribute-rgt-in67.0%
Simplified67.0%
Taylor expanded in a around inf 94.9%
associate-*r/94.9%
metadata-eval94.9%
Simplified94.9%
if -10500 < a < 4.5e17Initial program 99.9%
associate--l+99.9%
fma-define99.9%
distribute-rgt-in99.9%
sqr-neg99.9%
distribute-rgt-in99.9%
Simplified99.9%
Taylor expanded in a around 0 98.7%
pow298.7%
Applied egg-rr98.7%
if 4.5e17 < a Initial program 21.4%
associate--l+21.4%
fma-define21.4%
distribute-rgt-in21.4%
sqr-neg21.4%
distribute-rgt-in21.4%
Simplified27.3%
Taylor expanded in a around inf 96.4%
associate-*r/96.4%
metadata-eval96.4%
Simplified96.4%
Taylor expanded in a around inf 96.4%
Final simplification97.4%
(FPCore (a b) :precision binary64 (if (or (<= a -490.0) (not (<= a 215.0))) (* (pow a 4.0) (- 1.0 (/ 4.0 a))) (+ (* (* b b) 12.0) -1.0)))
double code(double a, double b) {
double tmp;
if ((a <= -490.0) || !(a <= 215.0)) {
tmp = pow(a, 4.0) * (1.0 - (4.0 / a));
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if ((a <= (-490.0d0)) .or. (.not. (a <= 215.0d0))) then
tmp = (a ** 4.0d0) * (1.0d0 - (4.0d0 / a))
else
tmp = ((b * b) * 12.0d0) + (-1.0d0)
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if ((a <= -490.0) || !(a <= 215.0)) {
tmp = Math.pow(a, 4.0) * (1.0 - (4.0 / a));
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -490.0) or not (a <= 215.0): tmp = math.pow(a, 4.0) * (1.0 - (4.0 / a)) else: tmp = ((b * b) * 12.0) + -1.0 return tmp
function code(a, b) tmp = 0.0 if ((a <= -490.0) || !(a <= 215.0)) tmp = Float64((a ^ 4.0) * Float64(1.0 - Float64(4.0 / a))); else tmp = Float64(Float64(Float64(b * b) * 12.0) + -1.0); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -490.0) || ~((a <= 215.0))) tmp = (a ^ 4.0) * (1.0 - (4.0 / a)); else tmp = ((b * b) * 12.0) + -1.0; end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -490.0], N[Not[LessEqual[a, 215.0]], $MachinePrecision]], N[(N[Power[a, 4.0], $MachinePrecision] * N[(1.0 - N[(4.0 / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + -1.0), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -490 \lor \neg \left(a \leq 215\right):\\
\;\;\;\;{a}^{4} \cdot \left(1 - \frac{4}{a}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(b \cdot b\right) \cdot 12 + -1\\
\end{array}
\end{array}
if a < -490 or 215 < a Initial program 47.7%
associate--l+47.7%
fma-define47.7%
distribute-rgt-in47.7%
sqr-neg47.7%
distribute-rgt-in47.7%
Simplified50.3%
Taylor expanded in a around inf 93.7%
associate-*r/93.7%
metadata-eval93.7%
Simplified93.7%
if -490 < a < 215Initial program 99.9%
associate--l+99.9%
fma-define99.9%
distribute-rgt-in99.9%
sqr-neg99.9%
distribute-rgt-in99.9%
Simplified99.9%
Taylor expanded in a around 0 99.4%
Taylor expanded in b around 0 72.5%
*-commutative72.5%
Simplified72.5%
pow299.4%
Applied egg-rr72.5%
Final simplification82.1%
(FPCore (a b) :precision binary64 (if (or (<= a -380.0) (not (<= a 1720.0))) (* (pow a 3.0) (- a 4.0)) (+ (* (* b b) 12.0) -1.0)))
double code(double a, double b) {
double tmp;
if ((a <= -380.0) || !(a <= 1720.0)) {
tmp = pow(a, 3.0) * (a - 4.0);
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if ((a <= (-380.0d0)) .or. (.not. (a <= 1720.0d0))) then
tmp = (a ** 3.0d0) * (a - 4.0d0)
else
tmp = ((b * b) * 12.0d0) + (-1.0d0)
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if ((a <= -380.0) || !(a <= 1720.0)) {
tmp = Math.pow(a, 3.0) * (a - 4.0);
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -380.0) or not (a <= 1720.0): tmp = math.pow(a, 3.0) * (a - 4.0) else: tmp = ((b * b) * 12.0) + -1.0 return tmp
function code(a, b) tmp = 0.0 if ((a <= -380.0) || !(a <= 1720.0)) tmp = Float64((a ^ 3.0) * Float64(a - 4.0)); else tmp = Float64(Float64(Float64(b * b) * 12.0) + -1.0); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -380.0) || ~((a <= 1720.0))) tmp = (a ^ 3.0) * (a - 4.0); else tmp = ((b * b) * 12.0) + -1.0; end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -380.0], N[Not[LessEqual[a, 1720.0]], $MachinePrecision]], N[(N[Power[a, 3.0], $MachinePrecision] * N[(a - 4.0), $MachinePrecision]), $MachinePrecision], N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + -1.0), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -380 \lor \neg \left(a \leq 1720\right):\\
\;\;\;\;{a}^{3} \cdot \left(a - 4\right)\\
\mathbf{else}:\\
\;\;\;\;\left(b \cdot b\right) \cdot 12 + -1\\
\end{array}
\end{array}
if a < -380 or 1720 < a Initial program 47.7%
associate--l+47.7%
fma-define47.7%
distribute-rgt-in47.7%
sqr-neg47.7%
distribute-rgt-in47.7%
Simplified50.3%
Taylor expanded in a around inf 93.7%
associate-*r/93.7%
metadata-eval93.7%
Simplified93.7%
Taylor expanded in a around 0 93.7%
if -380 < a < 1720Initial program 99.9%
associate--l+99.9%
fma-define99.9%
distribute-rgt-in99.9%
sqr-neg99.9%
distribute-rgt-in99.9%
Simplified99.9%
Taylor expanded in a around 0 99.4%
Taylor expanded in b around 0 72.5%
*-commutative72.5%
Simplified72.5%
pow299.4%
Applied egg-rr72.5%
Final simplification82.0%
(FPCore (a b) :precision binary64 (if (or (<= a -50000.0) (not (<= a 54000.0))) (pow a 4.0) (+ (* (* b b) 12.0) -1.0)))
double code(double a, double b) {
double tmp;
if ((a <= -50000.0) || !(a <= 54000.0)) {
tmp = pow(a, 4.0);
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if ((a <= (-50000.0d0)) .or. (.not. (a <= 54000.0d0))) then
tmp = a ** 4.0d0
else
tmp = ((b * b) * 12.0d0) + (-1.0d0)
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if ((a <= -50000.0) || !(a <= 54000.0)) {
tmp = Math.pow(a, 4.0);
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
def code(a, b): tmp = 0 if (a <= -50000.0) or not (a <= 54000.0): tmp = math.pow(a, 4.0) else: tmp = ((b * b) * 12.0) + -1.0 return tmp
function code(a, b) tmp = 0.0 if ((a <= -50000.0) || !(a <= 54000.0)) tmp = a ^ 4.0; else tmp = Float64(Float64(Float64(b * b) * 12.0) + -1.0); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if ((a <= -50000.0) || ~((a <= 54000.0))) tmp = a ^ 4.0; else tmp = ((b * b) * 12.0) + -1.0; end tmp_2 = tmp; end
code[a_, b_] := If[Or[LessEqual[a, -50000.0], N[Not[LessEqual[a, 54000.0]], $MachinePrecision]], N[Power[a, 4.0], $MachinePrecision], N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + -1.0), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -50000 \lor \neg \left(a \leq 54000\right):\\
\;\;\;\;{a}^{4}\\
\mathbf{else}:\\
\;\;\;\;\left(b \cdot b\right) \cdot 12 + -1\\
\end{array}
\end{array}
if a < -5e4 or 54000 < a Initial program 47.7%
associate--l+47.7%
fma-define47.7%
distribute-rgt-in47.7%
sqr-neg47.7%
distribute-rgt-in47.7%
Simplified50.3%
Taylor expanded in a around inf 93.7%
associate-*r/93.7%
metadata-eval93.7%
Simplified93.7%
Taylor expanded in a around inf 92.9%
if -5e4 < a < 54000Initial program 99.9%
associate--l+99.9%
fma-define99.9%
distribute-rgt-in99.9%
sqr-neg99.9%
distribute-rgt-in99.9%
Simplified99.9%
Taylor expanded in a around 0 99.4%
Taylor expanded in b around 0 72.5%
*-commutative72.5%
Simplified72.5%
pow299.4%
Applied egg-rr72.5%
Final simplification81.7%
(FPCore (a b) :precision binary64 (if (<= a -4.2e+99) (+ (* 4.0 (* (* a a) (- 1.0 a))) -1.0) (+ (* (* b b) 12.0) -1.0)))
double code(double a, double b) {
double tmp;
if (a <= -4.2e+99) {
tmp = (4.0 * ((a * a) * (1.0 - a))) + -1.0;
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if (a <= (-4.2d+99)) then
tmp = (4.0d0 * ((a * a) * (1.0d0 - a))) + (-1.0d0)
else
tmp = ((b * b) * 12.0d0) + (-1.0d0)
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if (a <= -4.2e+99) {
tmp = (4.0 * ((a * a) * (1.0 - a))) + -1.0;
} else {
tmp = ((b * b) * 12.0) + -1.0;
}
return tmp;
}
def code(a, b): tmp = 0 if a <= -4.2e+99: tmp = (4.0 * ((a * a) * (1.0 - a))) + -1.0 else: tmp = ((b * b) * 12.0) + -1.0 return tmp
function code(a, b) tmp = 0.0 if (a <= -4.2e+99) tmp = Float64(Float64(4.0 * Float64(Float64(a * a) * Float64(1.0 - a))) + -1.0); else tmp = Float64(Float64(Float64(b * b) * 12.0) + -1.0); end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (a <= -4.2e+99) tmp = (4.0 * ((a * a) * (1.0 - a))) + -1.0; else tmp = ((b * b) * 12.0) + -1.0; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[a, -4.2e+99], N[(N[(4.0 * N[(N[(a * a), $MachinePrecision] * N[(1.0 - a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision], N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + -1.0), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -4.2 \cdot 10^{+99}:\\
\;\;\;\;4 \cdot \left(\left(a \cdot a\right) \cdot \left(1 - a\right)\right) + -1\\
\mathbf{else}:\\
\;\;\;\;\left(b \cdot b\right) \cdot 12 + -1\\
\end{array}
\end{array}
if a < -4.2000000000000002e99Initial program 53.8%
associate--l+53.8%
fma-define53.8%
distribute-rgt-in53.8%
sqr-neg53.8%
distribute-rgt-in53.8%
Simplified53.8%
fma-define53.8%
unpow253.8%
flip-+5.1%
associate-*r/5.1%
Applied egg-rr5.1%
Taylor expanded in a around 0 48.7%
mul-1-neg48.7%
Simplified48.7%
Taylor expanded in b around 0 97.7%
unpow297.7%
Applied egg-rr97.7%
if -4.2000000000000002e99 < a Initial program 80.5%
associate--l+80.5%
fma-define80.5%
distribute-rgt-in80.5%
sqr-neg80.5%
distribute-rgt-in80.5%
Simplified81.9%
Taylor expanded in a around 0 74.1%
Taylor expanded in b around 0 51.9%
*-commutative51.9%
Simplified51.9%
pow274.1%
Applied egg-rr51.9%
Final simplification58.9%
(FPCore (a b) :precision binary64 (+ (* (* b b) 12.0) -1.0))
double code(double a, double b) {
return ((b * b) * 12.0) + -1.0;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = ((b * b) * 12.0d0) + (-1.0d0)
end function
public static double code(double a, double b) {
return ((b * b) * 12.0) + -1.0;
}
def code(a, b): return ((b * b) * 12.0) + -1.0
function code(a, b) return Float64(Float64(Float64(b * b) * 12.0) + -1.0) end
function tmp = code(a, b) tmp = ((b * b) * 12.0) + -1.0; end
code[a_, b_] := N[(N[(N[(b * b), $MachinePrecision] * 12.0), $MachinePrecision] + -1.0), $MachinePrecision]
\begin{array}{l}
\\
\left(b \cdot b\right) \cdot 12 + -1
\end{array}
Initial program 76.4%
associate--l+76.4%
fma-define76.4%
distribute-rgt-in76.4%
sqr-neg76.4%
distribute-rgt-in76.4%
Simplified77.6%
Taylor expanded in a around 0 69.6%
Taylor expanded in b around 0 48.5%
*-commutative48.5%
Simplified48.5%
pow269.6%
Applied egg-rr48.5%
Final simplification48.5%
(FPCore (a b) :precision binary64 -1.0)
double code(double a, double b) {
return -1.0;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
code = -1.0d0
end function
public static double code(double a, double b) {
return -1.0;
}
def code(a, b): return -1.0
function code(a, b) return -1.0 end
function tmp = code(a, b) tmp = -1.0; end
code[a_, b_] := -1.0
\begin{array}{l}
\\
-1
\end{array}
Initial program 76.4%
associate--l+76.4%
fma-define76.4%
distribute-rgt-in76.4%
sqr-neg76.4%
distribute-rgt-in76.4%
Simplified77.6%
Taylor expanded in a around 0 69.6%
Taylor expanded in b around 0 27.3%
herbie shell --seed 2024180
(FPCore (a b)
:name "Bouland and Aaronson, Equation (24)"
:precision binary64
(- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (- 1.0 a)) (* (* b b) (+ 3.0 a))))) 1.0))