
(FPCore (x y z) :precision binary64 (sqrt (/ (+ (+ (* x x) (* y y)) (* z z)) 3.0)))
double code(double x, double y, double z) {
return sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0));
}
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
code = sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0d0))
end function
public static double code(double x, double y, double z) {
return Math.sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0));
}
def code(x, y, z): return math.sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0))
function code(x, y, z) return sqrt(Float64(Float64(Float64(Float64(x * x) + Float64(y * y)) + Float64(z * z)) / 3.0)) end
function tmp = code(x, y, z) tmp = sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0)); end
code[x_, y_, z_] := N[Sqrt[N[(N[(N[(N[(x * x), $MachinePrecision] + N[(y * y), $MachinePrecision]), $MachinePrecision] + N[(z * z), $MachinePrecision]), $MachinePrecision] / 3.0), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\sqrt{\frac{\left(x \cdot x + y \cdot y\right) + z \cdot z}{3}}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 5 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x y z) :precision binary64 (sqrt (/ (+ (+ (* x x) (* y y)) (* z z)) 3.0)))
double code(double x, double y, double z) {
return sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0));
}
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
code = sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0d0))
end function
public static double code(double x, double y, double z) {
return Math.sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0));
}
def code(x, y, z): return math.sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0))
function code(x, y, z) return sqrt(Float64(Float64(Float64(Float64(x * x) + Float64(y * y)) + Float64(z * z)) / 3.0)) end
function tmp = code(x, y, z) tmp = sqrt(((((x * x) + (y * y)) + (z * z)) / 3.0)); end
code[x_, y_, z_] := N[Sqrt[N[(N[(N[(N[(x * x), $MachinePrecision] + N[(y * y), $MachinePrecision]), $MachinePrecision] + N[(z * z), $MachinePrecision]), $MachinePrecision] / 3.0), $MachinePrecision]], $MachinePrecision]
\begin{array}{l}
\\
\sqrt{\frac{\left(x \cdot x + y \cdot y\right) + z \cdot z}{3}}
\end{array}
x_m = (fabs.f64 x) y_m = (fabs.f64 y) z_m = (fabs.f64 z) NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. (FPCore (x_m y_m z_m) :precision binary64 (/ (hypot z_m y_m) (sqrt 3.0)))
x_m = fabs(x);
y_m = fabs(y);
z_m = fabs(z);
assert(x_m < y_m && y_m < z_m);
double code(double x_m, double y_m, double z_m) {
return hypot(z_m, y_m) / sqrt(3.0);
}
x_m = Math.abs(x);
y_m = Math.abs(y);
z_m = Math.abs(z);
assert x_m < y_m && y_m < z_m;
public static double code(double x_m, double y_m, double z_m) {
return Math.hypot(z_m, y_m) / Math.sqrt(3.0);
}
x_m = math.fabs(x) y_m = math.fabs(y) z_m = math.fabs(z) [x_m, y_m, z_m] = sort([x_m, y_m, z_m]) def code(x_m, y_m, z_m): return math.hypot(z_m, y_m) / math.sqrt(3.0)
x_m = abs(x) y_m = abs(y) z_m = abs(z) x_m, y_m, z_m = sort([x_m, y_m, z_m]) function code(x_m, y_m, z_m) return Float64(hypot(z_m, y_m) / sqrt(3.0)) end
x_m = abs(x);
y_m = abs(y);
z_m = abs(z);
x_m, y_m, z_m = num2cell(sort([x_m, y_m, z_m])){:}
function tmp = code(x_m, y_m, z_m)
tmp = hypot(z_m, y_m) / sqrt(3.0);
end
x_m = N[Abs[x], $MachinePrecision] y_m = N[Abs[y], $MachinePrecision] z_m = N[Abs[z], $MachinePrecision] NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. code[x$95$m_, y$95$m_, z$95$m_] := N[(N[Sqrt[z$95$m ^ 2 + y$95$m ^ 2], $MachinePrecision] / N[Sqrt[3.0], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
y_m = \left|y\right|
\\
z_m = \left|z\right|
\\
[x_m, y_m, z_m] = \mathsf{sort}([x_m, y_m, z_m])\\
\\
\frac{\mathsf{hypot}\left(z_m, y_m\right)}{\sqrt{3}}
\end{array}
Initial program 43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
Simplified43.1%
fma-udef43.1%
fma-udef43.1%
associate-+l+43.1%
metadata-eval43.1%
div-inv43.1%
sqrt-div43.0%
div-inv42.7%
+-commutative42.7%
add-sqr-sqrt42.7%
hypot-def57.8%
hypot-def98.6%
Applied egg-rr98.6%
associate-*r/99.4%
*-rgt-identity99.4%
hypot-def58.2%
unpow258.2%
unpow258.2%
+-commutative58.2%
unpow258.2%
unpow258.2%
hypot-def99.4%
Simplified99.4%
Taylor expanded in x around 0 27.2%
associate-*l/27.4%
+-commutative27.4%
unpow227.4%
unpow227.4%
hypot-def63.8%
*-lft-identity63.8%
Simplified63.8%
Final simplification63.8%
x_m = (fabs.f64 x) y_m = (fabs.f64 y) z_m = (fabs.f64 z) NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. (FPCore (x_m y_m z_m) :precision binary64 (* (sqrt 0.3333333333333333) (hypot y_m z_m)))
x_m = fabs(x);
y_m = fabs(y);
z_m = fabs(z);
assert(x_m < y_m && y_m < z_m);
double code(double x_m, double y_m, double z_m) {
return sqrt(0.3333333333333333) * hypot(y_m, z_m);
}
x_m = Math.abs(x);
y_m = Math.abs(y);
z_m = Math.abs(z);
assert x_m < y_m && y_m < z_m;
public static double code(double x_m, double y_m, double z_m) {
return Math.sqrt(0.3333333333333333) * Math.hypot(y_m, z_m);
}
x_m = math.fabs(x) y_m = math.fabs(y) z_m = math.fabs(z) [x_m, y_m, z_m] = sort([x_m, y_m, z_m]) def code(x_m, y_m, z_m): return math.sqrt(0.3333333333333333) * math.hypot(y_m, z_m)
x_m = abs(x) y_m = abs(y) z_m = abs(z) x_m, y_m, z_m = sort([x_m, y_m, z_m]) function code(x_m, y_m, z_m) return Float64(sqrt(0.3333333333333333) * hypot(y_m, z_m)) end
x_m = abs(x);
y_m = abs(y);
z_m = abs(z);
x_m, y_m, z_m = num2cell(sort([x_m, y_m, z_m])){:}
function tmp = code(x_m, y_m, z_m)
tmp = sqrt(0.3333333333333333) * hypot(y_m, z_m);
end
x_m = N[Abs[x], $MachinePrecision] y_m = N[Abs[y], $MachinePrecision] z_m = N[Abs[z], $MachinePrecision] NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. code[x$95$m_, y$95$m_, z$95$m_] := N[(N[Sqrt[0.3333333333333333], $MachinePrecision] * N[Sqrt[y$95$m ^ 2 + z$95$m ^ 2], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
y_m = \left|y\right|
\\
z_m = \left|z\right|
\\
[x_m, y_m, z_m] = \mathsf{sort}([x_m, y_m, z_m])\\
\\
\sqrt{0.3333333333333333} \cdot \mathsf{hypot}\left(y_m, z_m\right)
\end{array}
Initial program 43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
Simplified43.1%
Taylor expanded in x around 0 27.4%
unpow227.4%
unpow227.4%
hypot-def63.8%
Simplified63.8%
Final simplification63.8%
x_m = (fabs.f64 x) y_m = (fabs.f64 y) z_m = (fabs.f64 z) NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. (FPCore (x_m y_m z_m) :precision binary64 (/ 1.0 (/ (sqrt 3.0) z_m)))
x_m = fabs(x);
y_m = fabs(y);
z_m = fabs(z);
assert(x_m < y_m && y_m < z_m);
double code(double x_m, double y_m, double z_m) {
return 1.0 / (sqrt(3.0) / z_m);
}
x_m = abs(x)
y_m = abs(y)
z_m = abs(z)
NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function.
real(8) function code(x_m, y_m, z_m)
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
code = 1.0d0 / (sqrt(3.0d0) / z_m)
end function
x_m = Math.abs(x);
y_m = Math.abs(y);
z_m = Math.abs(z);
assert x_m < y_m && y_m < z_m;
public static double code(double x_m, double y_m, double z_m) {
return 1.0 / (Math.sqrt(3.0) / z_m);
}
x_m = math.fabs(x) y_m = math.fabs(y) z_m = math.fabs(z) [x_m, y_m, z_m] = sort([x_m, y_m, z_m]) def code(x_m, y_m, z_m): return 1.0 / (math.sqrt(3.0) / z_m)
x_m = abs(x) y_m = abs(y) z_m = abs(z) x_m, y_m, z_m = sort([x_m, y_m, z_m]) function code(x_m, y_m, z_m) return Float64(1.0 / Float64(sqrt(3.0) / z_m)) end
x_m = abs(x);
y_m = abs(y);
z_m = abs(z);
x_m, y_m, z_m = num2cell(sort([x_m, y_m, z_m])){:}
function tmp = code(x_m, y_m, z_m)
tmp = 1.0 / (sqrt(3.0) / z_m);
end
x_m = N[Abs[x], $MachinePrecision] y_m = N[Abs[y], $MachinePrecision] z_m = N[Abs[z], $MachinePrecision] NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. code[x$95$m_, y$95$m_, z$95$m_] := N[(1.0 / N[(N[Sqrt[3.0], $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
y_m = \left|y\right|
\\
z_m = \left|z\right|
\\
[x_m, y_m, z_m] = \mathsf{sort}([x_m, y_m, z_m])\\
\\
\frac{1}{\frac{\sqrt{3}}{z_m}}
\end{array}
Initial program 43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
Simplified43.1%
fma-udef43.1%
fma-udef43.1%
associate-+l+43.1%
metadata-eval43.1%
div-inv43.1%
sqrt-div43.0%
div-inv42.7%
+-commutative42.7%
add-sqr-sqrt42.7%
hypot-def57.8%
hypot-def98.6%
Applied egg-rr98.6%
associate-*r/99.4%
*-rgt-identity99.4%
hypot-def58.2%
unpow258.2%
unpow258.2%
+-commutative58.2%
unpow258.2%
unpow258.2%
hypot-def99.4%
Simplified99.4%
Taylor expanded in z around inf 14.6%
frac-2neg14.6%
div-inv14.6%
Applied egg-rr14.6%
Applied egg-rr14.7%
Final simplification14.7%
x_m = (fabs.f64 x) y_m = (fabs.f64 y) z_m = (fabs.f64 z) NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. (FPCore (x_m y_m z_m) :precision binary64 (* z_m (sqrt 0.3333333333333333)))
x_m = fabs(x);
y_m = fabs(y);
z_m = fabs(z);
assert(x_m < y_m && y_m < z_m);
double code(double x_m, double y_m, double z_m) {
return z_m * sqrt(0.3333333333333333);
}
x_m = abs(x)
y_m = abs(y)
z_m = abs(z)
NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function.
real(8) function code(x_m, y_m, z_m)
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
code = z_m * sqrt(0.3333333333333333d0)
end function
x_m = Math.abs(x);
y_m = Math.abs(y);
z_m = Math.abs(z);
assert x_m < y_m && y_m < z_m;
public static double code(double x_m, double y_m, double z_m) {
return z_m * Math.sqrt(0.3333333333333333);
}
x_m = math.fabs(x) y_m = math.fabs(y) z_m = math.fabs(z) [x_m, y_m, z_m] = sort([x_m, y_m, z_m]) def code(x_m, y_m, z_m): return z_m * math.sqrt(0.3333333333333333)
x_m = abs(x) y_m = abs(y) z_m = abs(z) x_m, y_m, z_m = sort([x_m, y_m, z_m]) function code(x_m, y_m, z_m) return Float64(z_m * sqrt(0.3333333333333333)) end
x_m = abs(x);
y_m = abs(y);
z_m = abs(z);
x_m, y_m, z_m = num2cell(sort([x_m, y_m, z_m])){:}
function tmp = code(x_m, y_m, z_m)
tmp = z_m * sqrt(0.3333333333333333);
end
x_m = N[Abs[x], $MachinePrecision] y_m = N[Abs[y], $MachinePrecision] z_m = N[Abs[z], $MachinePrecision] NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. code[x$95$m_, y$95$m_, z$95$m_] := N[(z$95$m * N[Sqrt[0.3333333333333333], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
y_m = \left|y\right|
\\
z_m = \left|z\right|
\\
[x_m, y_m, z_m] = \mathsf{sort}([x_m, y_m, z_m])\\
\\
z_m \cdot \sqrt{0.3333333333333333}
\end{array}
Initial program 43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
Simplified43.1%
Taylor expanded in z around inf 14.6%
*-commutative14.6%
Simplified14.6%
Final simplification14.6%
x_m = (fabs.f64 x) y_m = (fabs.f64 y) z_m = (fabs.f64 z) NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. (FPCore (x_m y_m z_m) :precision binary64 (/ z_m (sqrt 3.0)))
x_m = fabs(x);
y_m = fabs(y);
z_m = fabs(z);
assert(x_m < y_m && y_m < z_m);
double code(double x_m, double y_m, double z_m) {
return z_m / sqrt(3.0);
}
x_m = abs(x)
y_m = abs(y)
z_m = abs(z)
NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function.
real(8) function code(x_m, y_m, z_m)
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
code = z_m / sqrt(3.0d0)
end function
x_m = Math.abs(x);
y_m = Math.abs(y);
z_m = Math.abs(z);
assert x_m < y_m && y_m < z_m;
public static double code(double x_m, double y_m, double z_m) {
return z_m / Math.sqrt(3.0);
}
x_m = math.fabs(x) y_m = math.fabs(y) z_m = math.fabs(z) [x_m, y_m, z_m] = sort([x_m, y_m, z_m]) def code(x_m, y_m, z_m): return z_m / math.sqrt(3.0)
x_m = abs(x) y_m = abs(y) z_m = abs(z) x_m, y_m, z_m = sort([x_m, y_m, z_m]) function code(x_m, y_m, z_m) return Float64(z_m / sqrt(3.0)) end
x_m = abs(x);
y_m = abs(y);
z_m = abs(z);
x_m, y_m, z_m = num2cell(sort([x_m, y_m, z_m])){:}
function tmp = code(x_m, y_m, z_m)
tmp = z_m / sqrt(3.0);
end
x_m = N[Abs[x], $MachinePrecision] y_m = N[Abs[y], $MachinePrecision] z_m = N[Abs[z], $MachinePrecision] NOTE: x_m, y_m, and z_m should be sorted in increasing order before calling this function. code[x$95$m_, y$95$m_, z$95$m_] := N[(z$95$m / N[Sqrt[3.0], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
y_m = \left|y\right|
\\
z_m = \left|z\right|
\\
[x_m, y_m, z_m] = \mathsf{sort}([x_m, y_m, z_m])\\
\\
\frac{z_m}{\sqrt{3}}
\end{array}
Initial program 43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
sqr-neg43.1%
Simplified43.1%
fma-udef43.1%
fma-udef43.1%
associate-+l+43.1%
metadata-eval43.1%
div-inv43.1%
sqrt-div43.0%
div-inv42.7%
+-commutative42.7%
add-sqr-sqrt42.7%
hypot-def57.8%
hypot-def98.6%
Applied egg-rr98.6%
associate-*r/99.4%
*-rgt-identity99.4%
hypot-def58.2%
unpow258.2%
unpow258.2%
+-commutative58.2%
unpow258.2%
unpow258.2%
hypot-def99.4%
Simplified99.4%
Taylor expanded in z around inf 14.6%
Final simplification14.6%
(FPCore (x y z)
:precision binary64
(if (< z -6.396479394109776e+136)
(/ (- z) (sqrt 3.0))
(if (< z 7.320293694404182e+117)
(/ (sqrt (+ (+ (* z z) (* x x)) (* y y))) (sqrt 3.0))
(* (sqrt 0.3333333333333333) z))))
double code(double x, double y, double z) {
double tmp;
if (z < -6.396479394109776e+136) {
tmp = -z / sqrt(3.0);
} else if (z < 7.320293694404182e+117) {
tmp = sqrt((((z * z) + (x * x)) + (y * y))) / sqrt(3.0);
} else {
tmp = sqrt(0.3333333333333333) * z;
}
return tmp;
}
real(8) function code(x, y, z)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8) :: tmp
if (z < (-6.396479394109776d+136)) then
tmp = -z / sqrt(3.0d0)
else if (z < 7.320293694404182d+117) then
tmp = sqrt((((z * z) + (x * x)) + (y * y))) / sqrt(3.0d0)
else
tmp = sqrt(0.3333333333333333d0) * z
end if
code = tmp
end function
public static double code(double x, double y, double z) {
double tmp;
if (z < -6.396479394109776e+136) {
tmp = -z / Math.sqrt(3.0);
} else if (z < 7.320293694404182e+117) {
tmp = Math.sqrt((((z * z) + (x * x)) + (y * y))) / Math.sqrt(3.0);
} else {
tmp = Math.sqrt(0.3333333333333333) * z;
}
return tmp;
}
def code(x, y, z): tmp = 0 if z < -6.396479394109776e+136: tmp = -z / math.sqrt(3.0) elif z < 7.320293694404182e+117: tmp = math.sqrt((((z * z) + (x * x)) + (y * y))) / math.sqrt(3.0) else: tmp = math.sqrt(0.3333333333333333) * z return tmp
function code(x, y, z) tmp = 0.0 if (z < -6.396479394109776e+136) tmp = Float64(Float64(-z) / sqrt(3.0)); elseif (z < 7.320293694404182e+117) tmp = Float64(sqrt(Float64(Float64(Float64(z * z) + Float64(x * x)) + Float64(y * y))) / sqrt(3.0)); else tmp = Float64(sqrt(0.3333333333333333) * z); end return tmp end
function tmp_2 = code(x, y, z) tmp = 0.0; if (z < -6.396479394109776e+136) tmp = -z / sqrt(3.0); elseif (z < 7.320293694404182e+117) tmp = sqrt((((z * z) + (x * x)) + (y * y))) / sqrt(3.0); else tmp = sqrt(0.3333333333333333) * z; end tmp_2 = tmp; end
code[x_, y_, z_] := If[Less[z, -6.396479394109776e+136], N[((-z) / N[Sqrt[3.0], $MachinePrecision]), $MachinePrecision], If[Less[z, 7.320293694404182e+117], N[(N[Sqrt[N[(N[(N[(z * z), $MachinePrecision] + N[(x * x), $MachinePrecision]), $MachinePrecision] + N[(y * y), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / N[Sqrt[3.0], $MachinePrecision]), $MachinePrecision], N[(N[Sqrt[0.3333333333333333], $MachinePrecision] * z), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z < -6.396479394109776 \cdot 10^{+136}:\\
\;\;\;\;\frac{-z}{\sqrt{3}}\\
\mathbf{elif}\;z < 7.320293694404182 \cdot 10^{+117}:\\
\;\;\;\;\frac{\sqrt{\left(z \cdot z + x \cdot x\right) + y \cdot y}}{\sqrt{3}}\\
\mathbf{else}:\\
\;\;\;\;\sqrt{0.3333333333333333} \cdot z\\
\end{array}
\end{array}
herbie shell --seed 2024017
(FPCore (x y z)
:name "Data.Array.Repa.Algorithms.Pixel:doubleRmsOfRGB8 from repa-algorithms-3.4.0.1"
:precision binary64
:herbie-target
(if (< z -6.396479394109776e+136) (/ (- z) (sqrt 3.0)) (if (< z 7.320293694404182e+117) (/ (sqrt (+ (+ (* z z) (* x x)) (* y y))) (sqrt 3.0)) (* (sqrt 0.3333333333333333) z)))
(sqrt (/ (+ (+ (* x x) (* y y)) (* z z)) 3.0)))