
(FPCore (a b) :precision binary64 (- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (+ 1.0 a)) (* (* b b) (- 1.0 (* 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) * (1.0 - (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) * (1.0d0 - (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) * (1.0 - (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) * (1.0 - (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(1.0 - 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) * (1.0 - (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[(1.0 - N[(3.0 * a), $MachinePrecision]), $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(1 - 3 \cdot 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) (- 1.0 (* 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) * (1.0 - (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) * (1.0d0 - (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) * (1.0 - (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) * (1.0 - (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(1.0 - 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) * (1.0 - (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[(1.0 - N[(3.0 * a), $MachinePrecision]), $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(1 - 3 \cdot a\right)\right)\right) - 1
\end{array}
(FPCore (a b)
:precision binary64
(if (<=
(+
(pow (+ (* a a) (* b b)) 2.0)
(* 4.0 (+ (* (* a a) (+ a 1.0)) (* (* b b) (- 1.0 (* a 3.0))))))
INFINITY)
(+
(fma
4.0
(fma a (fma a a a) (* b (* b (fma a -3.0 1.0))))
(pow (hypot a b) 4.0))
-1.0)
(+ (pow a 4.0) (+ -1.0 (* (* a a) 4.0)))))
double code(double a, double b) {
double tmp;
if ((pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (a + 1.0)) + ((b * b) * (1.0 - (a * 3.0)))))) <= ((double) INFINITY)) {
tmp = fma(4.0, fma(a, fma(a, a, a), (b * (b * fma(a, -3.0, 1.0)))), pow(hypot(a, b), 4.0)) + -1.0;
} else {
tmp = pow(a, 4.0) + (-1.0 + ((a * a) * 4.0));
}
return tmp;
}
function code(a, b) tmp = 0.0 if (Float64((Float64(Float64(a * a) + Float64(b * b)) ^ 2.0) + Float64(4.0 * Float64(Float64(Float64(a * a) * Float64(a + 1.0)) + Float64(Float64(b * b) * Float64(1.0 - Float64(a * 3.0)))))) <= Inf) tmp = Float64(fma(4.0, fma(a, fma(a, a, a), Float64(b * Float64(b * fma(a, -3.0, 1.0)))), (hypot(a, b) ^ 4.0)) + -1.0); else tmp = Float64((a ^ 4.0) + Float64(-1.0 + Float64(Float64(a * a) * 4.0))); end return tmp end
code[a_, b_] := If[LessEqual[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[(a + 1.0), $MachinePrecision]), $MachinePrecision] + N[(N[(b * b), $MachinePrecision] * N[(1.0 - N[(a * 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], Infinity], N[(N[(4.0 * N[(a * N[(a * a + a), $MachinePrecision] + N[(b * N[(b * N[(a * -3.0 + 1.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] + N[Power[N[Sqrt[a ^ 2 + b ^ 2], $MachinePrecision], 4.0], $MachinePrecision]), $MachinePrecision] + -1.0), $MachinePrecision], N[(N[Power[a, 4.0], $MachinePrecision] + N[(-1.0 + N[(N[(a * a), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;{\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(\left(a \cdot a\right) \cdot \left(a + 1\right) + \left(b \cdot b\right) \cdot \left(1 - a \cdot 3\right)\right) \leq \infty:\\
\;\;\;\;\mathsf{fma}\left(4, \mathsf{fma}\left(a, \mathsf{fma}\left(a, a, a\right), b \cdot \left(b \cdot \mathsf{fma}\left(a, -3, 1\right)\right)\right), {\left(\mathsf{hypot}\left(a, b\right)\right)}^{4}\right) + -1\\
\mathbf{else}:\\
\;\;\;\;{a}^{4} + \left(-1 + \left(a \cdot a\right) \cdot 4\right)\\
\end{array}
\end{array}
if (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (+.f64 (*.f64 (*.f64 a a) (+.f64 1 a)) (*.f64 (*.f64 b b) (-.f64 1 (*.f64 3 a)))))) < +inf.0Initial program 99.9%
sub-neg99.9%
Simplified100.0%
if +inf.0 < (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (+.f64 (*.f64 (*.f64 a a) (+.f64 1 a)) (*.f64 (*.f64 b b) (-.f64 1 (*.f64 3 a)))))) Initial program 0.0%
associate--l+0.0%
fma-def0.0%
Simplified5.2%
Taylor expanded in b around 0 31.3%
associate--l+31.3%
associate-*r*31.3%
unpow231.3%
Simplified31.3%
Taylor expanded in a around 0 95.1%
unpow295.1%
Simplified95.1%
Final simplification98.9%
(FPCore (a b)
:precision binary64
(let* ((t_0
(+
(pow (+ (* a a) (* b b)) 2.0)
(* 4.0 (+ (* (* a a) (+ a 1.0)) (* (* b b) (- 1.0 (* a 3.0))))))))
(if (<= t_0 INFINITY)
(+ t_0 -1.0)
(+ (pow a 4.0) (+ -1.0 (* (* a a) 4.0))))))
double code(double a, double b) {
double t_0 = pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (a + 1.0)) + ((b * b) * (1.0 - (a * 3.0)))));
double tmp;
if (t_0 <= ((double) INFINITY)) {
tmp = t_0 + -1.0;
} else {
tmp = pow(a, 4.0) + (-1.0 + ((a * a) * 4.0));
}
return tmp;
}
public static double code(double a, double b) {
double t_0 = Math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (a + 1.0)) + ((b * b) * (1.0 - (a * 3.0)))));
double tmp;
if (t_0 <= Double.POSITIVE_INFINITY) {
tmp = t_0 + -1.0;
} else {
tmp = Math.pow(a, 4.0) + (-1.0 + ((a * a) * 4.0));
}
return tmp;
}
def code(a, b): t_0 = math.pow(((a * a) + (b * b)), 2.0) + (4.0 * (((a * a) * (a + 1.0)) + ((b * b) * (1.0 - (a * 3.0))))) tmp = 0 if t_0 <= math.inf: tmp = t_0 + -1.0 else: tmp = math.pow(a, 4.0) + (-1.0 + ((a * a) * 4.0)) return tmp
function code(a, b) t_0 = Float64((Float64(Float64(a * a) + Float64(b * b)) ^ 2.0) + Float64(4.0 * Float64(Float64(Float64(a * a) * Float64(a + 1.0)) + Float64(Float64(b * b) * Float64(1.0 - Float64(a * 3.0)))))) tmp = 0.0 if (t_0 <= Inf) tmp = Float64(t_0 + -1.0); else tmp = Float64((a ^ 4.0) + Float64(-1.0 + Float64(Float64(a * a) * 4.0))); end return tmp end
function tmp_2 = code(a, b) t_0 = (((a * a) + (b * b)) ^ 2.0) + (4.0 * (((a * a) * (a + 1.0)) + ((b * b) * (1.0 - (a * 3.0))))); tmp = 0.0; if (t_0 <= Inf) tmp = t_0 + -1.0; else tmp = (a ^ 4.0) + (-1.0 + ((a * a) * 4.0)); end tmp_2 = tmp; end
code[a_, b_] := Block[{t$95$0 = 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[(a + 1.0), $MachinePrecision]), $MachinePrecision] + N[(N[(b * b), $MachinePrecision] * N[(1.0 - N[(a * 3.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[t$95$0, Infinity], N[(t$95$0 + -1.0), $MachinePrecision], N[(N[Power[a, 4.0], $MachinePrecision] + N[(-1.0 + N[(N[(a * a), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := {\left(a \cdot a + b \cdot b\right)}^{2} + 4 \cdot \left(\left(a \cdot a\right) \cdot \left(a + 1\right) + \left(b \cdot b\right) \cdot \left(1 - a \cdot 3\right)\right)\\
\mathbf{if}\;t_0 \leq \infty:\\
\;\;\;\;t_0 + -1\\
\mathbf{else}:\\
\;\;\;\;{a}^{4} + \left(-1 + \left(a \cdot a\right) \cdot 4\right)\\
\end{array}
\end{array}
if (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (+.f64 (*.f64 (*.f64 a a) (+.f64 1 a)) (*.f64 (*.f64 b b) (-.f64 1 (*.f64 3 a)))))) < +inf.0Initial program 99.9%
if +inf.0 < (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (+.f64 (*.f64 (*.f64 a a) (+.f64 1 a)) (*.f64 (*.f64 b b) (-.f64 1 (*.f64 3 a)))))) Initial program 0.0%
associate--l+0.0%
fma-def0.0%
Simplified5.2%
Taylor expanded in b around 0 31.3%
associate--l+31.3%
associate-*r*31.3%
unpow231.3%
Simplified31.3%
Taylor expanded in a around 0 95.1%
unpow295.1%
Simplified95.1%
Final simplification98.8%
(FPCore (a b)
:precision binary64
(if (<= b -58000000000000.0)
(pow b 4.0)
(if (<= b -5.5e-34)
(pow a 4.0)
(if (<= b -1e-129)
-1.0
(if (<= b -2.3e-194)
(pow a 4.0)
(if (<= b -4e-224)
-1.0
(if (<= b -1.25e-278)
(pow a 4.0)
(if (<= b 7e-123)
-1.0
(if (<= b 2.6e+16) (pow a 4.0) (pow b 4.0))))))))))
double code(double a, double b) {
double tmp;
if (b <= -58000000000000.0) {
tmp = pow(b, 4.0);
} else if (b <= -5.5e-34) {
tmp = pow(a, 4.0);
} else if (b <= -1e-129) {
tmp = -1.0;
} else if (b <= -2.3e-194) {
tmp = pow(a, 4.0);
} else if (b <= -4e-224) {
tmp = -1.0;
} else if (b <= -1.25e-278) {
tmp = pow(a, 4.0);
} else if (b <= 7e-123) {
tmp = -1.0;
} else if (b <= 2.6e+16) {
tmp = pow(a, 4.0);
} else {
tmp = pow(b, 4.0);
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if (b <= (-58000000000000.0d0)) then
tmp = b ** 4.0d0
else if (b <= (-5.5d-34)) then
tmp = a ** 4.0d0
else if (b <= (-1d-129)) then
tmp = -1.0d0
else if (b <= (-2.3d-194)) then
tmp = a ** 4.0d0
else if (b <= (-4d-224)) then
tmp = -1.0d0
else if (b <= (-1.25d-278)) then
tmp = a ** 4.0d0
else if (b <= 7d-123) then
tmp = -1.0d0
else if (b <= 2.6d+16) then
tmp = a ** 4.0d0
else
tmp = b ** 4.0d0
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if (b <= -58000000000000.0) {
tmp = Math.pow(b, 4.0);
} else if (b <= -5.5e-34) {
tmp = Math.pow(a, 4.0);
} else if (b <= -1e-129) {
tmp = -1.0;
} else if (b <= -2.3e-194) {
tmp = Math.pow(a, 4.0);
} else if (b <= -4e-224) {
tmp = -1.0;
} else if (b <= -1.25e-278) {
tmp = Math.pow(a, 4.0);
} else if (b <= 7e-123) {
tmp = -1.0;
} else if (b <= 2.6e+16) {
tmp = Math.pow(a, 4.0);
} else {
tmp = Math.pow(b, 4.0);
}
return tmp;
}
def code(a, b): tmp = 0 if b <= -58000000000000.0: tmp = math.pow(b, 4.0) elif b <= -5.5e-34: tmp = math.pow(a, 4.0) elif b <= -1e-129: tmp = -1.0 elif b <= -2.3e-194: tmp = math.pow(a, 4.0) elif b <= -4e-224: tmp = -1.0 elif b <= -1.25e-278: tmp = math.pow(a, 4.0) elif b <= 7e-123: tmp = -1.0 elif b <= 2.6e+16: tmp = math.pow(a, 4.0) else: tmp = math.pow(b, 4.0) return tmp
function code(a, b) tmp = 0.0 if (b <= -58000000000000.0) tmp = b ^ 4.0; elseif (b <= -5.5e-34) tmp = a ^ 4.0; elseif (b <= -1e-129) tmp = -1.0; elseif (b <= -2.3e-194) tmp = a ^ 4.0; elseif (b <= -4e-224) tmp = -1.0; elseif (b <= -1.25e-278) tmp = a ^ 4.0; elseif (b <= 7e-123) tmp = -1.0; elseif (b <= 2.6e+16) tmp = a ^ 4.0; else tmp = b ^ 4.0; end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (b <= -58000000000000.0) tmp = b ^ 4.0; elseif (b <= -5.5e-34) tmp = a ^ 4.0; elseif (b <= -1e-129) tmp = -1.0; elseif (b <= -2.3e-194) tmp = a ^ 4.0; elseif (b <= -4e-224) tmp = -1.0; elseif (b <= -1.25e-278) tmp = a ^ 4.0; elseif (b <= 7e-123) tmp = -1.0; elseif (b <= 2.6e+16) tmp = a ^ 4.0; else tmp = b ^ 4.0; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[b, -58000000000000.0], N[Power[b, 4.0], $MachinePrecision], If[LessEqual[b, -5.5e-34], N[Power[a, 4.0], $MachinePrecision], If[LessEqual[b, -1e-129], -1.0, If[LessEqual[b, -2.3e-194], N[Power[a, 4.0], $MachinePrecision], If[LessEqual[b, -4e-224], -1.0, If[LessEqual[b, -1.25e-278], N[Power[a, 4.0], $MachinePrecision], If[LessEqual[b, 7e-123], -1.0, If[LessEqual[b, 2.6e+16], N[Power[a, 4.0], $MachinePrecision], N[Power[b, 4.0], $MachinePrecision]]]]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;b \leq -58000000000000:\\
\;\;\;\;{b}^{4}\\
\mathbf{elif}\;b \leq -5.5 \cdot 10^{-34}:\\
\;\;\;\;{a}^{4}\\
\mathbf{elif}\;b \leq -1 \cdot 10^{-129}:\\
\;\;\;\;-1\\
\mathbf{elif}\;b \leq -2.3 \cdot 10^{-194}:\\
\;\;\;\;{a}^{4}\\
\mathbf{elif}\;b \leq -4 \cdot 10^{-224}:\\
\;\;\;\;-1\\
\mathbf{elif}\;b \leq -1.25 \cdot 10^{-278}:\\
\;\;\;\;{a}^{4}\\
\mathbf{elif}\;b \leq 7 \cdot 10^{-123}:\\
\;\;\;\;-1\\
\mathbf{elif}\;b \leq 2.6 \cdot 10^{+16}:\\
\;\;\;\;{a}^{4}\\
\mathbf{else}:\\
\;\;\;\;{b}^{4}\\
\end{array}
\end{array}
if b < -5.8e13 or 2.6e16 < b Initial program 69.8%
associate--l+69.8%
fma-def69.8%
Simplified72.5%
Taylor expanded in b around inf 96.6%
if -5.8e13 < b < -5.50000000000000014e-34 or -9.9999999999999993e-130 < b < -2.30000000000000003e-194 or -4.0000000000000001e-224 < b < -1.24999999999999996e-278 or 6.9999999999999997e-123 < b < 2.6e16Initial program 73.4%
associate--l+73.4%
fma-def73.4%
Simplified73.4%
Taylor expanded in a around inf 74.8%
if -5.50000000000000014e-34 < b < -9.9999999999999993e-130 or -2.30000000000000003e-194 < b < -4.0000000000000001e-224 or -1.24999999999999996e-278 < b < 6.9999999999999997e-123Initial program 91.9%
associate--l+91.9%
fma-def91.9%
Simplified91.9%
Taylor expanded in b around 0 92.0%
associate--l+92.0%
associate-*r*92.0%
unpow292.0%
Simplified92.0%
Taylor expanded in a around 0 74.1%
Final simplification84.2%
(FPCore (a b)
:precision binary64
(if (<= b -53000000.0)
(pow b 4.0)
(if (<= b 64000000000000.0)
(+ (pow a 4.0) (+ -1.0 (* (* a a) 4.0)))
(pow b 4.0))))
double code(double a, double b) {
double tmp;
if (b <= -53000000.0) {
tmp = pow(b, 4.0);
} else if (b <= 64000000000000.0) {
tmp = pow(a, 4.0) + (-1.0 + ((a * a) * 4.0));
} else {
tmp = pow(b, 4.0);
}
return tmp;
}
real(8) function code(a, b)
real(8), intent (in) :: a
real(8), intent (in) :: b
real(8) :: tmp
if (b <= (-53000000.0d0)) then
tmp = b ** 4.0d0
else if (b <= 64000000000000.0d0) then
tmp = (a ** 4.0d0) + ((-1.0d0) + ((a * a) * 4.0d0))
else
tmp = b ** 4.0d0
end if
code = tmp
end function
public static double code(double a, double b) {
double tmp;
if (b <= -53000000.0) {
tmp = Math.pow(b, 4.0);
} else if (b <= 64000000000000.0) {
tmp = Math.pow(a, 4.0) + (-1.0 + ((a * a) * 4.0));
} else {
tmp = Math.pow(b, 4.0);
}
return tmp;
}
def code(a, b): tmp = 0 if b <= -53000000.0: tmp = math.pow(b, 4.0) elif b <= 64000000000000.0: tmp = math.pow(a, 4.0) + (-1.0 + ((a * a) * 4.0)) else: tmp = math.pow(b, 4.0) return tmp
function code(a, b) tmp = 0.0 if (b <= -53000000.0) tmp = b ^ 4.0; elseif (b <= 64000000000000.0) tmp = Float64((a ^ 4.0) + Float64(-1.0 + Float64(Float64(a * a) * 4.0))); else tmp = b ^ 4.0; end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (b <= -53000000.0) tmp = b ^ 4.0; elseif (b <= 64000000000000.0) tmp = (a ^ 4.0) + (-1.0 + ((a * a) * 4.0)); else tmp = b ^ 4.0; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[b, -53000000.0], N[Power[b, 4.0], $MachinePrecision], If[LessEqual[b, 64000000000000.0], N[(N[Power[a, 4.0], $MachinePrecision] + N[(-1.0 + N[(N[(a * a), $MachinePrecision] * 4.0), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[Power[b, 4.0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;b \leq -53000000:\\
\;\;\;\;{b}^{4}\\
\mathbf{elif}\;b \leq 64000000000000:\\
\;\;\;\;{a}^{4} + \left(-1 + \left(a \cdot a\right) \cdot 4\right)\\
\mathbf{else}:\\
\;\;\;\;{b}^{4}\\
\end{array}
\end{array}
if b < -5.3e7 or 6.4e13 < b Initial program 69.8%
associate--l+69.8%
fma-def69.8%
Simplified72.5%
Taylor expanded in b around inf 96.6%
if -5.3e7 < b < 6.4e13Initial program 83.1%
associate--l+83.1%
fma-def83.1%
Simplified83.1%
Taylor expanded in b around 0 82.2%
associate--l+82.2%
associate-*r*82.2%
unpow282.2%
Simplified82.2%
Taylor expanded in a around 0 97.8%
unpow297.8%
Simplified97.8%
Final simplification97.3%
(FPCore (a b)
:precision binary64
(let* ((t_0 (fma 4.0 (* a a) -1.0)))
(if (<= b -350000000.0)
(pow b 4.0)
(if (<= b 2.2e-122)
t_0
(if (<= b 6.8e-41)
(pow a 4.0)
(if (<= b 16500000000000.0) t_0 (pow b 4.0)))))))
double code(double a, double b) {
double t_0 = fma(4.0, (a * a), -1.0);
double tmp;
if (b <= -350000000.0) {
tmp = pow(b, 4.0);
} else if (b <= 2.2e-122) {
tmp = t_0;
} else if (b <= 6.8e-41) {
tmp = pow(a, 4.0);
} else if (b <= 16500000000000.0) {
tmp = t_0;
} else {
tmp = pow(b, 4.0);
}
return tmp;
}
function code(a, b) t_0 = fma(4.0, Float64(a * a), -1.0) tmp = 0.0 if (b <= -350000000.0) tmp = b ^ 4.0; elseif (b <= 2.2e-122) tmp = t_0; elseif (b <= 6.8e-41) tmp = a ^ 4.0; elseif (b <= 16500000000000.0) tmp = t_0; else tmp = b ^ 4.0; end return tmp end
code[a_, b_] := Block[{t$95$0 = N[(4.0 * N[(a * a), $MachinePrecision] + -1.0), $MachinePrecision]}, If[LessEqual[b, -350000000.0], N[Power[b, 4.0], $MachinePrecision], If[LessEqual[b, 2.2e-122], t$95$0, If[LessEqual[b, 6.8e-41], N[Power[a, 4.0], $MachinePrecision], If[LessEqual[b, 16500000000000.0], t$95$0, N[Power[b, 4.0], $MachinePrecision]]]]]]
\begin{array}{l}
\\
\begin{array}{l}
t_0 := \mathsf{fma}\left(4, a \cdot a, -1\right)\\
\mathbf{if}\;b \leq -350000000:\\
\;\;\;\;{b}^{4}\\
\mathbf{elif}\;b \leq 2.2 \cdot 10^{-122}:\\
\;\;\;\;t_0\\
\mathbf{elif}\;b \leq 6.8 \cdot 10^{-41}:\\
\;\;\;\;{a}^{4}\\
\mathbf{elif}\;b \leq 16500000000000:\\
\;\;\;\;t_0\\
\mathbf{else}:\\
\;\;\;\;{b}^{4}\\
\end{array}
\end{array}
if b < -3.5e8 or 1.65e13 < b Initial program 69.8%
associate--l+69.8%
fma-def69.8%
Simplified72.5%
Taylor expanded in b around inf 96.6%
if -3.5e8 < b < 2.2e-122 or 6.7999999999999997e-41 < b < 1.65e13Initial program 82.9%
associate--l+82.9%
fma-def82.9%
Simplified82.9%
Taylor expanded in b around 0 81.8%
associate--l+81.8%
associate-*r*81.8%
unpow281.8%
Simplified81.8%
Taylor expanded in a around 0 84.2%
fma-neg84.2%
unpow284.2%
metadata-eval84.2%
Simplified84.2%
if 2.2e-122 < b < 6.7999999999999997e-41Initial program 85.0%
associate--l+85.0%
fma-def85.0%
Simplified85.0%
Taylor expanded in a around inf 88.2%
Final simplification89.9%
(FPCore (a b)
:precision binary64
(if (<= b -32000000.0)
(pow b 4.0)
(if (<= b 3.8e-122)
(fma 4.0 (* a a) -1.0)
(if (<= b 1.7e+14) (* (pow a 3.0) (+ a 4.0)) (pow b 4.0)))))
double code(double a, double b) {
double tmp;
if (b <= -32000000.0) {
tmp = pow(b, 4.0);
} else if (b <= 3.8e-122) {
tmp = fma(4.0, (a * a), -1.0);
} else if (b <= 1.7e+14) {
tmp = pow(a, 3.0) * (a + 4.0);
} else {
tmp = pow(b, 4.0);
}
return tmp;
}
function code(a, b) tmp = 0.0 if (b <= -32000000.0) tmp = b ^ 4.0; elseif (b <= 3.8e-122) tmp = fma(4.0, Float64(a * a), -1.0); elseif (b <= 1.7e+14) tmp = Float64((a ^ 3.0) * Float64(a + 4.0)); else tmp = b ^ 4.0; end return tmp end
code[a_, b_] := If[LessEqual[b, -32000000.0], N[Power[b, 4.0], $MachinePrecision], If[LessEqual[b, 3.8e-122], N[(4.0 * N[(a * a), $MachinePrecision] + -1.0), $MachinePrecision], If[LessEqual[b, 1.7e+14], N[(N[Power[a, 3.0], $MachinePrecision] * N[(a + 4.0), $MachinePrecision]), $MachinePrecision], N[Power[b, 4.0], $MachinePrecision]]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;b \leq -32000000:\\
\;\;\;\;{b}^{4}\\
\mathbf{elif}\;b \leq 3.8 \cdot 10^{-122}:\\
\;\;\;\;\mathsf{fma}\left(4, a \cdot a, -1\right)\\
\mathbf{elif}\;b \leq 1.7 \cdot 10^{+14}:\\
\;\;\;\;{a}^{3} \cdot \left(a + 4\right)\\
\mathbf{else}:\\
\;\;\;\;{b}^{4}\\
\end{array}
\end{array}
if b < -3.2e7 or 1.7e14 < b Initial program 69.8%
associate--l+69.8%
fma-def69.8%
Simplified72.5%
Taylor expanded in b around inf 96.6%
if -3.2e7 < b < 3.8000000000000001e-122Initial program 84.9%
associate--l+84.9%
fma-def84.9%
Simplified84.9%
Taylor expanded in b around 0 84.0%
associate--l+83.9%
associate-*r*83.9%
unpow283.9%
Simplified83.9%
Taylor expanded in a around 0 84.7%
fma-neg84.7%
unpow284.7%
metadata-eval84.7%
Simplified84.7%
if 3.8000000000000001e-122 < b < 1.7e14Initial program 73.5%
associate--l+73.5%
fma-def73.5%
Simplified73.5%
Taylor expanded in b around 0 72.9%
associate--l+72.9%
associate-*r*72.9%
unpow272.9%
Simplified72.9%
Taylor expanded in a around inf 51.2%
*-commutative51.2%
metadata-eval51.2%
pow-plus51.2%
distribute-lft-out77.3%
Simplified77.3%
Final simplification89.3%
(FPCore (a b) :precision binary64 (if (<= a -6e-18) (pow a 4.0) (if (<= a 0.41) -1.0 (pow a 4.0))))
double code(double a, double b) {
double tmp;
if (a <= -6e-18) {
tmp = pow(a, 4.0);
} else if (a <= 0.41) {
tmp = -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 <= (-6d-18)) then
tmp = a ** 4.0d0
else if (a <= 0.41d0) then
tmp = -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 <= -6e-18) {
tmp = Math.pow(a, 4.0);
} else if (a <= 0.41) {
tmp = -1.0;
} else {
tmp = Math.pow(a, 4.0);
}
return tmp;
}
def code(a, b): tmp = 0 if a <= -6e-18: tmp = math.pow(a, 4.0) elif a <= 0.41: tmp = -1.0 else: tmp = math.pow(a, 4.0) return tmp
function code(a, b) tmp = 0.0 if (a <= -6e-18) tmp = a ^ 4.0; elseif (a <= 0.41) tmp = -1.0; else tmp = a ^ 4.0; end return tmp end
function tmp_2 = code(a, b) tmp = 0.0; if (a <= -6e-18) tmp = a ^ 4.0; elseif (a <= 0.41) tmp = -1.0; else tmp = a ^ 4.0; end tmp_2 = tmp; end
code[a_, b_] := If[LessEqual[a, -6e-18], N[Power[a, 4.0], $MachinePrecision], If[LessEqual[a, 0.41], -1.0, N[Power[a, 4.0], $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -6 \cdot 10^{-18}:\\
\;\;\;\;{a}^{4}\\
\mathbf{elif}\;a \leq 0.41:\\
\;\;\;\;-1\\
\mathbf{else}:\\
\;\;\;\;{a}^{4}\\
\end{array}
\end{array}
if a < -5.99999999999999966e-18 or 0.409999999999999976 < a Initial program 51.5%
associate--l+51.5%
fma-def51.5%
Simplified54.0%
Taylor expanded in a around inf 87.9%
if -5.99999999999999966e-18 < a < 0.409999999999999976Initial program 99.9%
associate--l+99.9%
fma-def99.9%
Simplified99.9%
Taylor expanded in b around 0 52.9%
associate--l+52.9%
associate-*r*52.9%
unpow252.9%
Simplified52.9%
Taylor expanded in a around 0 52.5%
Final simplification69.1%
(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 77.2%
associate--l+77.2%
fma-def77.2%
Simplified78.4%
Taylor expanded in b around 0 55.3%
associate--l+55.3%
associate-*r*55.3%
unpow255.3%
Simplified55.3%
Taylor expanded in a around 0 28.2%
Final simplification28.2%
herbie shell --seed 2023182
(FPCore (a b)
:name "Bouland and Aaronson, Equation (25)"
:precision binary64
(- (+ (pow (+ (* a a) (* b b)) 2.0) (* 4.0 (+ (* (* a a) (+ 1.0 a)) (* (* b b) (- 1.0 (* 3.0 a)))))) 1.0))