
(FPCore (x y z t a) :precision binary64 (/ (* (* x y) z) (sqrt (- (* z z) (* t a)))))
double code(double x, double y, double z, double t, double a) {
return ((x * y) * z) / sqrt(((z * z) - (t * a)));
}
real(8) function code(x, y, z, t, a)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
real(8), intent (in) :: a
code = ((x * y) * z) / sqrt(((z * z) - (t * a)))
end function
public static double code(double x, double y, double z, double t, double a) {
return ((x * y) * z) / Math.sqrt(((z * z) - (t * a)));
}
def code(x, y, z, t, a): return ((x * y) * z) / math.sqrt(((z * z) - (t * a)))
function code(x, y, z, t, a) return Float64(Float64(Float64(x * y) * z) / sqrt(Float64(Float64(z * z) - Float64(t * a)))) end
function tmp = code(x, y, z, t, a) tmp = ((x * y) * z) / sqrt(((z * z) - (t * a))); end
code[x_, y_, z_, t_, a_] := N[(N[(N[(x * y), $MachinePrecision] * z), $MachinePrecision] / N[Sqrt[N[(N[(z * z), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 11 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x y z t a) :precision binary64 (/ (* (* x y) z) (sqrt (- (* z z) (* t a)))))
double code(double x, double y, double z, double t, double a) {
return ((x * y) * z) / sqrt(((z * z) - (t * a)));
}
real(8) function code(x, y, z, t, a)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
real(8), intent (in) :: a
code = ((x * y) * z) / sqrt(((z * z) - (t * a)))
end function
public static double code(double x, double y, double z, double t, double a) {
return ((x * y) * z) / Math.sqrt(((z * z) - (t * a)));
}
def code(x, y, z, t, a): return ((x * y) * z) / math.sqrt(((z * z) - (t * a)))
function code(x, y, z, t, a) return Float64(Float64(Float64(x * y) * z) / sqrt(Float64(Float64(z * z) - Float64(t * a)))) end
function tmp = code(x, y, z, t, a) tmp = ((x * y) * z) / sqrt(((z * z) - (t * a))); end
code[x_, y_, z_, t_, a_] := N[(N[(N[(x * y), $MachinePrecision] * z), $MachinePrecision] / N[Sqrt[N[(N[(z * z), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
\frac{\left(x \cdot y\right) \cdot z}{\sqrt{z \cdot z - t \cdot a}}
\end{array}
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(let* ((t_1 (/ (* (* x_m y_m) z_m) (sqrt (- (* z_m z_m) (* t a))))))
(*
z_s
(*
y_s
(*
x_s
(if (<= t_1 0.0)
(/ y_m (* (/ 1.0 x_m) (/ (+ z_m (* -0.5 (* t (/ a z_m)))) z_m)))
(if (<= t_1 1e+265) t_1 (* x_m y_m))))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double t_1 = ((x_m * y_m) * z_m) / sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (t_1 <= 0.0) {
tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m));
} else if (t_1 <= 1e+265) {
tmp = t_1;
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: t_1
real(8) :: tmp
t_1 = ((x_m * y_m) * z_m) / sqrt(((z_m * z_m) - (t * a)))
if (t_1 <= 0.0d0) then
tmp = y_m / ((1.0d0 / x_m) * ((z_m + ((-0.5d0) * (t * (a / z_m)))) / z_m))
else if (t_1 <= 1d+265) then
tmp = t_1
else
tmp = x_m * y_m
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double t_1 = ((x_m * y_m) * z_m) / Math.sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (t_1 <= 0.0) {
tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m));
} else if (t_1 <= 1e+265) {
tmp = t_1;
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): t_1 = ((x_m * y_m) * z_m) / math.sqrt(((z_m * z_m) - (t * a))) tmp = 0 if t_1 <= 0.0: tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)) elif t_1 <= 1e+265: tmp = t_1 else: tmp = x_m * y_m return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) t_1 = Float64(Float64(Float64(x_m * y_m) * z_m) / sqrt(Float64(Float64(z_m * z_m) - Float64(t * a)))) tmp = 0.0 if (t_1 <= 0.0) tmp = Float64(y_m / Float64(Float64(1.0 / x_m) * Float64(Float64(z_m + Float64(-0.5 * Float64(t * Float64(a / z_m)))) / z_m))); elseif (t_1 <= 1e+265) tmp = t_1; else tmp = Float64(x_m * y_m); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) t_1 = ((x_m * y_m) * z_m) / sqrt(((z_m * z_m) - (t * a))); tmp = 0.0; if (t_1 <= 0.0) tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)); elseif (t_1 <= 1e+265) tmp = t_1; else tmp = x_m * y_m; end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := Block[{t$95$1 = N[(N[(N[(x$95$m * y$95$m), $MachinePrecision] * z$95$m), $MachinePrecision] / N[Sqrt[N[(N[(z$95$m * z$95$m), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]}, N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[t$95$1, 0.0], N[(y$95$m / N[(N[(1.0 / x$95$m), $MachinePrecision] * N[(N[(z$95$m + N[(-0.5 * N[(t * N[(a / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 1e+265], t$95$1, N[(x$95$m * y$95$m), $MachinePrecision]]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
\begin{array}{l}
t_1 := \frac{\left(x_m \cdot y_m\right) \cdot z_m}{\sqrt{z_m \cdot z_m - t \cdot a}}\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;t_1 \leq 0:\\
\;\;\;\;\frac{y_m}{\frac{1}{x_m} \cdot \frac{z_m + -0.5 \cdot \left(t \cdot \frac{a}{z_m}\right)}{z_m}}\\
\mathbf{elif}\;t_1 \leq 10^{+265}:\\
\;\;\;\;t_1\\
\mathbf{else}:\\
\;\;\;\;x_m \cdot y_m\\
\end{array}\right)\right)
\end{array}
\end{array}
if (/.f64 (*.f64 (*.f64 x y) z) (sqrt.f64 (-.f64 (*.f64 z z) (*.f64 t a)))) < 0.0Initial program 65.1%
associate-*l/69.1%
*-commutative69.1%
associate-/l*67.5%
associate-/r/68.2%
associate-/r*66.7%
Simplified66.7%
Taylor expanded in z around inf 52.8%
associate-*r/52.8%
Simplified52.8%
*-un-lft-identity52.8%
times-frac56.8%
*-commutative56.8%
*-un-lft-identity56.8%
times-frac56.8%
metadata-eval56.8%
*-commutative56.8%
Applied egg-rr56.8%
associate-/l*56.7%
associate-/r/56.7%
Applied egg-rr56.7%
if 0.0 < (/.f64 (*.f64 (*.f64 x y) z) (sqrt.f64 (-.f64 (*.f64 z z) (*.f64 t a)))) < 1.00000000000000007e265Initial program 99.8%
if 1.00000000000000007e265 < (/.f64 (*.f64 (*.f64 x y) z) (sqrt.f64 (-.f64 (*.f64 z z) (*.f64 t a)))) Initial program 27.7%
associate-*l/33.0%
*-commutative33.0%
associate-/l*33.4%
associate-/r/33.4%
associate-/r*32.8%
Simplified32.8%
Taylor expanded in z around inf 48.7%
Final simplification63.6%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= z_m 4.8e-164)
(/ (* x_m (* y_m z_m)) (sqrt (* a (- t))))
(if (<= z_m 2.5e+126)
(/ y_m (/ (sqrt (- (* z_m z_m) (* t a))) (* x_m z_m)))
(/ y_m (* (/ 1.0 x_m) (/ (+ z_m (* -0.5 (* t (/ a z_m)))) z_m)))))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 4.8e-164) {
tmp = (x_m * (y_m * z_m)) / sqrt((a * -t));
} else if (z_m <= 2.5e+126) {
tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (x_m * z_m));
} else {
tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (z_m <= 4.8d-164) then
tmp = (x_m * (y_m * z_m)) / sqrt((a * -t))
else if (z_m <= 2.5d+126) then
tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (x_m * z_m))
else
tmp = y_m / ((1.0d0 / x_m) * ((z_m + ((-0.5d0) * (t * (a / z_m)))) / z_m))
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 4.8e-164) {
tmp = (x_m * (y_m * z_m)) / Math.sqrt((a * -t));
} else if (z_m <= 2.5e+126) {
tmp = y_m / (Math.sqrt(((z_m * z_m) - (t * a))) / (x_m * z_m));
} else {
tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if z_m <= 4.8e-164: tmp = (x_m * (y_m * z_m)) / math.sqrt((a * -t)) elif z_m <= 2.5e+126: tmp = y_m / (math.sqrt(((z_m * z_m) - (t * a))) / (x_m * z_m)) else: tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (z_m <= 4.8e-164) tmp = Float64(Float64(x_m * Float64(y_m * z_m)) / sqrt(Float64(a * Float64(-t)))); elseif (z_m <= 2.5e+126) tmp = Float64(y_m / Float64(sqrt(Float64(Float64(z_m * z_m) - Float64(t * a))) / Float64(x_m * z_m))); else tmp = Float64(y_m / Float64(Float64(1.0 / x_m) * Float64(Float64(z_m + Float64(-0.5 * Float64(t * Float64(a / z_m)))) / z_m))); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (z_m <= 4.8e-164) tmp = (x_m * (y_m * z_m)) / sqrt((a * -t)); elseif (z_m <= 2.5e+126) tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (x_m * z_m)); else tmp = y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[z$95$m, 4.8e-164], N[(N[(x$95$m * N[(y$95$m * z$95$m), $MachinePrecision]), $MachinePrecision] / N[Sqrt[N[(a * (-t)), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], If[LessEqual[z$95$m, 2.5e+126], N[(y$95$m / N[(N[Sqrt[N[(N[(z$95$m * z$95$m), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / N[(x$95$m * z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m / N[(N[(1.0 / x$95$m), $MachinePrecision] * N[(N[(z$95$m + N[(-0.5 * N[(t * N[(a / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;z_m \leq 4.8 \cdot 10^{-164}:\\
\;\;\;\;\frac{x_m \cdot \left(y_m \cdot z_m\right)}{\sqrt{a \cdot \left(-t\right)}}\\
\mathbf{elif}\;z_m \leq 2.5 \cdot 10^{+126}:\\
\;\;\;\;\frac{y_m}{\frac{\sqrt{z_m \cdot z_m - t \cdot a}}{x_m \cdot z_m}}\\
\mathbf{else}:\\
\;\;\;\;\frac{y_m}{\frac{1}{x_m} \cdot \frac{z_m + -0.5 \cdot \left(t \cdot \frac{a}{z_m}\right)}{z_m}}\\
\end{array}\right)\right)
\end{array}
if z < 4.79999999999999966e-164Initial program 64.9%
associate-*l*62.2%
Simplified62.2%
Taylor expanded in z around 0 39.6%
mul-1-neg39.6%
distribute-rgt-neg-out39.6%
Simplified39.6%
if 4.79999999999999966e-164 < z < 2.49999999999999989e126Initial program 91.7%
associate-*l/94.4%
*-commutative94.4%
associate-/l*91.8%
associate-/r/91.9%
associate-/r*90.6%
Simplified90.6%
if 2.49999999999999989e126 < z Initial program 32.0%
associate-*l/35.7%
*-commutative35.7%
associate-/l*34.1%
associate-/r/37.6%
associate-/r*35.3%
Simplified35.3%
Taylor expanded in z around inf 78.7%
associate-*r/78.7%
Simplified78.7%
*-un-lft-identity78.7%
times-frac92.8%
*-commutative92.8%
*-un-lft-identity92.8%
times-frac92.8%
metadata-eval92.8%
*-commutative92.8%
Applied egg-rr92.8%
associate-/l*99.0%
associate-/r/99.0%
Applied egg-rr99.0%
Final simplification62.7%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= z_m 3.5e+35)
(/ (* x_m (* y_m z_m)) (sqrt (- (* z_m z_m) (* t a))))
(* x_m y_m))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 3.5e+35) {
tmp = (x_m * (y_m * z_m)) / sqrt(((z_m * z_m) - (t * a)));
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (z_m <= 3.5d+35) then
tmp = (x_m * (y_m * z_m)) / sqrt(((z_m * z_m) - (t * a)))
else
tmp = x_m * y_m
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 3.5e+35) {
tmp = (x_m * (y_m * z_m)) / Math.sqrt(((z_m * z_m) - (t * a)));
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if z_m <= 3.5e+35: tmp = (x_m * (y_m * z_m)) / math.sqrt(((z_m * z_m) - (t * a))) else: tmp = x_m * y_m return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (z_m <= 3.5e+35) tmp = Float64(Float64(x_m * Float64(y_m * z_m)) / sqrt(Float64(Float64(z_m * z_m) - Float64(t * a)))); else tmp = Float64(x_m * y_m); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (z_m <= 3.5e+35) tmp = (x_m * (y_m * z_m)) / sqrt(((z_m * z_m) - (t * a))); else tmp = x_m * y_m; end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[z$95$m, 3.5e+35], N[(N[(x$95$m * N[(y$95$m * z$95$m), $MachinePrecision]), $MachinePrecision] / N[Sqrt[N[(N[(z$95$m * z$95$m), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(x$95$m * y$95$m), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;z_m \leq 3.5 \cdot 10^{+35}:\\
\;\;\;\;\frac{x_m \cdot \left(y_m \cdot z_m\right)}{\sqrt{z_m \cdot z_m - t \cdot a}}\\
\mathbf{else}:\\
\;\;\;\;x_m \cdot y_m\\
\end{array}\right)\right)
\end{array}
if z < 3.5000000000000001e35Initial program 69.4%
associate-*l*66.6%
Simplified66.6%
if 3.5000000000000001e35 < z Initial program 50.5%
associate-*l/54.1%
*-commutative54.1%
associate-/l*51.7%
associate-/r/54.1%
associate-/r*51.4%
Simplified51.4%
Taylor expanded in z around inf 94.6%
Final simplification75.3%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= z_m 6.5e-113)
(/ (* x_m (* y_m z_m)) (sqrt (* a (- t))))
(* x_m y_m))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 6.5e-113) {
tmp = (x_m * (y_m * z_m)) / sqrt((a * -t));
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (z_m <= 6.5d-113) then
tmp = (x_m * (y_m * z_m)) / sqrt((a * -t))
else
tmp = x_m * y_m
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (z_m <= 6.5e-113) {
tmp = (x_m * (y_m * z_m)) / Math.sqrt((a * -t));
} else {
tmp = x_m * y_m;
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if z_m <= 6.5e-113: tmp = (x_m * (y_m * z_m)) / math.sqrt((a * -t)) else: tmp = x_m * y_m return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (z_m <= 6.5e-113) tmp = Float64(Float64(x_m * Float64(y_m * z_m)) / sqrt(Float64(a * Float64(-t)))); else tmp = Float64(x_m * y_m); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (z_m <= 6.5e-113) tmp = (x_m * (y_m * z_m)) / sqrt((a * -t)); else tmp = x_m * y_m; end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[z$95$m, 6.5e-113], N[(N[(x$95$m * N[(y$95$m * z$95$m), $MachinePrecision]), $MachinePrecision] / N[Sqrt[N[(a * (-t)), $MachinePrecision]], $MachinePrecision]), $MachinePrecision], N[(x$95$m * y$95$m), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;z_m \leq 6.5 \cdot 10^{-113}:\\
\;\;\;\;\frac{x_m \cdot \left(y_m \cdot z_m\right)}{\sqrt{a \cdot \left(-t\right)}}\\
\mathbf{else}:\\
\;\;\;\;x_m \cdot y_m\\
\end{array}\right)\right)
\end{array}
if z < 6.49999999999999979e-113Initial program 66.1%
associate-*l*63.6%
Simplified63.6%
Taylor expanded in z around 0 41.1%
mul-1-neg41.1%
distribute-rgt-neg-out41.1%
Simplified41.1%
if 6.49999999999999979e-113 < z Initial program 59.4%
associate-*l/62.3%
*-commutative62.3%
associate-/l*60.1%
associate-/r/62.0%
associate-/r*60.1%
Simplified60.1%
Taylor expanded in z around inf 88.1%
Final simplification59.4%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= a 5.7e-129)
(* x_m y_m)
(/ y_m (/ (+ z_m (* -0.5 (/ a (/ z_m t)))) (* x_m z_m))))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 5.7e-129) {
tmp = x_m * y_m;
} else {
tmp = y_m / ((z_m + (-0.5 * (a / (z_m / t)))) / (x_m * z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (a <= 5.7d-129) then
tmp = x_m * y_m
else
tmp = y_m / ((z_m + ((-0.5d0) * (a / (z_m / t)))) / (x_m * z_m))
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 5.7e-129) {
tmp = x_m * y_m;
} else {
tmp = y_m / ((z_m + (-0.5 * (a / (z_m / t)))) / (x_m * z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if a <= 5.7e-129: tmp = x_m * y_m else: tmp = y_m / ((z_m + (-0.5 * (a / (z_m / t)))) / (x_m * z_m)) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (a <= 5.7e-129) tmp = Float64(x_m * y_m); else tmp = Float64(y_m / Float64(Float64(z_m + Float64(-0.5 * Float64(a / Float64(z_m / t)))) / Float64(x_m * z_m))); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (a <= 5.7e-129) tmp = x_m * y_m; else tmp = y_m / ((z_m + (-0.5 * (a / (z_m / t)))) / (x_m * z_m)); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[a, 5.7e-129], N[(x$95$m * y$95$m), $MachinePrecision], N[(y$95$m / N[(N[(z$95$m + N[(-0.5 * N[(a / N[(z$95$m / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / N[(x$95$m * z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;a \leq 5.7 \cdot 10^{-129}:\\
\;\;\;\;x_m \cdot y_m\\
\mathbf{else}:\\
\;\;\;\;\frac{y_m}{\frac{z_m + -0.5 \cdot \frac{a}{\frac{z_m}{t}}}{x_m \cdot z_m}}\\
\end{array}\right)\right)
\end{array}
if a < 5.7000000000000001e-129Initial program 60.0%
associate-*l/61.9%
*-commutative61.9%
associate-/l*60.1%
associate-/r/61.2%
associate-/r*58.7%
Simplified58.7%
Taylor expanded in z around inf 43.9%
if 5.7000000000000001e-129 < a Initial program 70.3%
associate-*l/71.5%
*-commutative71.5%
associate-/l*71.4%
associate-/r/72.5%
associate-/r*70.0%
Simplified70.0%
Taylor expanded in z around inf 45.0%
associate-*r/45.0%
Simplified45.0%
Taylor expanded in a around 0 45.0%
associate-/l*46.7%
Simplified46.7%
Final simplification44.9%
x_m = (fabs.f64 x) x_s = (copysign.f64 1 x) y_m = (fabs.f64 y) y_s = (copysign.f64 1 y) z_m = (fabs.f64 z) z_s = (copysign.f64 1 z) (FPCore (z_s y_s x_s x_m y_m z_m t a) :precision binary64 (* z_s (* y_s (* x_s (/ y_m (* (/ 1.0 x_m) (/ (+ z_m (* -0.5 (* t (/ a z_m)))) z_m)))))))
x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
return z_s * (y_s * (x_s * (y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)))));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
code = z_s * (y_s * (x_s * (y_m / ((1.0d0 / x_m) * ((z_m + ((-0.5d0) * (t * (a / z_m)))) / z_m)))))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
return z_s * (y_s * (x_s * (y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)))));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): return z_s * (y_s * (x_s * (y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m)))))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) return Float64(z_s * Float64(y_s * Float64(x_s * Float64(y_m / Float64(Float64(1.0 / x_m) * Float64(Float64(z_m + Float64(-0.5 * Float64(t * Float64(a / z_m)))) / z_m)))))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = z_s * (y_s * (x_s * (y_m / ((1.0 / x_m) * ((z_m + (-0.5 * (t * (a / z_m)))) / z_m))))); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * N[(y$95$m / N[(N[(1.0 / x$95$m), $MachinePrecision] * N[(N[(z$95$m + N[(-0.5 * N[(t * N[(a / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \frac{y_m}{\frac{1}{x_m} \cdot \frac{z_m + -0.5 \cdot \left(t \cdot \frac{a}{z_m}\right)}{z_m}}\right)\right)
\end{array}
Initial program 63.5%
associate-*l/65.2%
*-commutative65.2%
associate-/l*63.9%
associate-/r/65.0%
associate-/r*62.6%
Simplified62.6%
Taylor expanded in z around inf 44.8%
associate-*r/44.8%
Simplified44.8%
*-un-lft-identity44.8%
times-frac48.9%
*-commutative48.9%
*-un-lft-identity48.9%
times-frac48.9%
metadata-eval48.9%
*-commutative48.9%
Applied egg-rr48.9%
associate-/l*50.2%
associate-/r/50.2%
Applied egg-rr50.2%
Final simplification50.2%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= a 2.6e-141)
(* x_m y_m)
(* y_m (* (/ 1.0 z_m) (/ z_m (/ 1.0 x_m)))))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 2.6e-141) {
tmp = x_m * y_m;
} else {
tmp = y_m * ((1.0 / z_m) * (z_m / (1.0 / x_m)));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (a <= 2.6d-141) then
tmp = x_m * y_m
else
tmp = y_m * ((1.0d0 / z_m) * (z_m / (1.0d0 / x_m)))
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 2.6e-141) {
tmp = x_m * y_m;
} else {
tmp = y_m * ((1.0 / z_m) * (z_m / (1.0 / x_m)));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if a <= 2.6e-141: tmp = x_m * y_m else: tmp = y_m * ((1.0 / z_m) * (z_m / (1.0 / x_m))) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (a <= 2.6e-141) tmp = Float64(x_m * y_m); else tmp = Float64(y_m * Float64(Float64(1.0 / z_m) * Float64(z_m / Float64(1.0 / x_m)))); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (a <= 2.6e-141) tmp = x_m * y_m; else tmp = y_m * ((1.0 / z_m) * (z_m / (1.0 / x_m))); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[a, 2.6e-141], N[(x$95$m * y$95$m), $MachinePrecision], N[(y$95$m * N[(N[(1.0 / z$95$m), $MachinePrecision] * N[(z$95$m / N[(1.0 / x$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;a \leq 2.6 \cdot 10^{-141}:\\
\;\;\;\;x_m \cdot y_m\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot \left(\frac{1}{z_m} \cdot \frac{z_m}{\frac{1}{x_m}}\right)\\
\end{array}\right)\right)
\end{array}
if a < 2.60000000000000011e-141Initial program 60.4%
associate-*l/62.3%
*-commutative62.3%
associate-/l*60.4%
associate-/r/61.5%
associate-/r*59.1%
Simplified59.1%
Taylor expanded in z around inf 43.6%
if 2.60000000000000011e-141 < a Initial program 69.5%
associate-*l/70.7%
*-commutative70.7%
associate-/l*70.7%
associate-/r/71.7%
associate-/r*69.2%
Simplified69.2%
Taylor expanded in z around inf 43.0%
expm1-log1p-u37.5%
expm1-udef33.5%
associate-/r/32.3%
*-commutative32.3%
Applied egg-rr32.3%
expm1-def33.9%
expm1-log1p39.4%
associate-*l/41.6%
associate-*r/43.0%
associate-/l*38.9%
Simplified38.9%
*-un-lft-identity38.9%
div-inv38.8%
times-frac43.0%
Applied egg-rr43.0%
Final simplification43.4%
x_m = (fabs.f64 x)
x_s = (copysign.f64 1 x)
y_m = (fabs.f64 y)
y_s = (copysign.f64 1 y)
z_m = (fabs.f64 z)
z_s = (copysign.f64 1 z)
(FPCore (z_s y_s x_s x_m y_m z_m t a)
:precision binary64
(*
z_s
(*
y_s
(*
x_s
(if (<= a 9.5e-126) (* x_m y_m) (/ y_m (* z_m (/ 1.0 (* x_m z_m)))))))))x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 9.5e-126) {
tmp = x_m * y_m;
} else {
tmp = y_m / (z_m * (1.0 / (x_m * z_m)));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (a <= 9.5d-126) then
tmp = x_m * y_m
else
tmp = y_m / (z_m * (1.0d0 / (x_m * z_m)))
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 9.5e-126) {
tmp = x_m * y_m;
} else {
tmp = y_m / (z_m * (1.0 / (x_m * z_m)));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if a <= 9.5e-126: tmp = x_m * y_m else: tmp = y_m / (z_m * (1.0 / (x_m * z_m))) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (a <= 9.5e-126) tmp = Float64(x_m * y_m); else tmp = Float64(y_m / Float64(z_m * Float64(1.0 / Float64(x_m * z_m)))); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (a <= 9.5e-126) tmp = x_m * y_m; else tmp = y_m / (z_m * (1.0 / (x_m * z_m))); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[a, 9.5e-126], N[(x$95$m * y$95$m), $MachinePrecision], N[(y$95$m / N[(z$95$m * N[(1.0 / N[(x$95$m * z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;a \leq 9.5 \cdot 10^{-126}:\\
\;\;\;\;x_m \cdot y_m\\
\mathbf{else}:\\
\;\;\;\;\frac{y_m}{z_m \cdot \frac{1}{x_m \cdot z_m}}\\
\end{array}\right)\right)
\end{array}
if a < 9.5000000000000003e-126Initial program 60.2%
associate-*l/62.1%
*-commutative62.1%
associate-/l*60.3%
associate-/r/61.4%
associate-/r*59.0%
Simplified59.0%
Taylor expanded in z around inf 44.1%
if 9.5000000000000003e-126 < a Initial program 70.0%
associate-*l/71.2%
*-commutative71.2%
associate-/l*71.1%
associate-/r/72.2%
associate-/r*69.6%
Simplified69.6%
Taylor expanded in z around inf 42.0%
div-inv42.0%
*-commutative42.0%
Applied egg-rr42.0%
Final simplification43.4%
x_m = (fabs.f64 x) x_s = (copysign.f64 1 x) y_m = (fabs.f64 y) y_s = (copysign.f64 1 y) z_m = (fabs.f64 z) z_s = (copysign.f64 1 z) (FPCore (z_s y_s x_s x_m y_m z_m t a) :precision binary64 (* z_s (* y_s (* x_s (if (<= a 5.5e-90) (* x_m y_m) (* (* x_m z_m) (/ y_m z_m)))))))
x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 5.5e-90) {
tmp = x_m * y_m;
} else {
tmp = (x_m * z_m) * (y_m / z_m);
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (a <= 5.5d-90) then
tmp = x_m * y_m
else
tmp = (x_m * z_m) * (y_m / z_m)
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 5.5e-90) {
tmp = x_m * y_m;
} else {
tmp = (x_m * z_m) * (y_m / z_m);
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if a <= 5.5e-90: tmp = x_m * y_m else: tmp = (x_m * z_m) * (y_m / z_m) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (a <= 5.5e-90) tmp = Float64(x_m * y_m); else tmp = Float64(Float64(x_m * z_m) * Float64(y_m / z_m)); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (a <= 5.5e-90) tmp = x_m * y_m; else tmp = (x_m * z_m) * (y_m / z_m); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[a, 5.5e-90], N[(x$95$m * y$95$m), $MachinePrecision], N[(N[(x$95$m * z$95$m), $MachinePrecision] * N[(y$95$m / z$95$m), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;a \leq 5.5 \cdot 10^{-90}:\\
\;\;\;\;x_m \cdot y_m\\
\mathbf{else}:\\
\;\;\;\;\left(x_m \cdot z_m\right) \cdot \frac{y_m}{z_m}\\
\end{array}\right)\right)
\end{array}
if a < 5.5000000000000003e-90Initial program 61.1%
associate-*l/63.0%
*-commutative63.0%
associate-/l*61.2%
associate-/r/62.2%
associate-/r*59.9%
Simplified59.9%
Taylor expanded in z around inf 43.6%
if 5.5000000000000003e-90 < a Initial program 69.1%
associate-*l/70.4%
*-commutative70.4%
associate-/l*70.3%
associate-/r/71.6%
associate-/r*68.6%
Simplified68.6%
Taylor expanded in z around inf 42.9%
associate-/r/38.8%
*-commutative38.8%
Applied egg-rr38.8%
Final simplification42.1%
x_m = (fabs.f64 x) x_s = (copysign.f64 1 x) y_m = (fabs.f64 y) y_s = (copysign.f64 1 y) z_m = (fabs.f64 z) z_s = (copysign.f64 1 z) (FPCore (z_s y_s x_s x_m y_m z_m t a) :precision binary64 (* z_s (* y_s (* x_s (if (<= a 7.2e-128) (* x_m y_m) (/ y_m (/ z_m (* x_m z_m))))))))
x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 7.2e-128) {
tmp = x_m * y_m;
} else {
tmp = y_m / (z_m / (x_m * z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (a <= 7.2d-128) then
tmp = x_m * y_m
else
tmp = y_m / (z_m / (x_m * z_m))
end if
code = z_s * (y_s * (x_s * tmp))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
double tmp;
if (a <= 7.2e-128) {
tmp = x_m * y_m;
} else {
tmp = y_m / (z_m / (x_m * z_m));
}
return z_s * (y_s * (x_s * tmp));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): tmp = 0 if a <= 7.2e-128: tmp = x_m * y_m else: tmp = y_m / (z_m / (x_m * z_m)) return z_s * (y_s * (x_s * tmp))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0 if (a <= 7.2e-128) tmp = Float64(x_m * y_m); else tmp = Float64(y_m / Float64(z_m / Float64(x_m * z_m))); end return Float64(z_s * Float64(y_s * Float64(x_s * tmp))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp_2 = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = 0.0; if (a <= 7.2e-128) tmp = x_m * y_m; else tmp = y_m / (z_m / (x_m * z_m)); end tmp_2 = z_s * (y_s * (x_s * tmp)); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[a, 7.2e-128], N[(x$95$m * y$95$m), $MachinePrecision], N[(y$95$m / N[(z$95$m / N[(x$95$m * z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \begin{array}{l}
\mathbf{if}\;a \leq 7.2 \cdot 10^{-128}:\\
\;\;\;\;x_m \cdot y_m\\
\mathbf{else}:\\
\;\;\;\;\frac{y_m}{\frac{z_m}{x_m \cdot z_m}}\\
\end{array}\right)\right)
\end{array}
if a < 7.20000000000000049e-128Initial program 60.2%
associate-*l/62.1%
*-commutative62.1%
associate-/l*60.3%
associate-/r/61.4%
associate-/r*59.0%
Simplified59.0%
Taylor expanded in z around inf 44.1%
if 7.20000000000000049e-128 < a Initial program 70.0%
associate-*l/71.2%
*-commutative71.2%
associate-/l*71.1%
associate-/r/72.2%
associate-/r*69.6%
Simplified69.6%
Taylor expanded in z around inf 42.0%
Final simplification43.4%
x_m = (fabs.f64 x) x_s = (copysign.f64 1 x) y_m = (fabs.f64 y) y_s = (copysign.f64 1 y) z_m = (fabs.f64 z) z_s = (copysign.f64 1 z) (FPCore (z_s y_s x_s x_m y_m z_m t a) :precision binary64 (* z_s (* y_s (* x_s (* x_m y_m)))))
x_m = fabs(x);
x_s = copysign(1.0, x);
y_m = fabs(y);
y_s = copysign(1.0, y);
z_m = fabs(z);
z_s = copysign(1.0, z);
double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
return z_s * (y_s * (x_s * (x_m * y_m)));
}
x_m = abs(x)
x_s = copysign(1.0d0, x)
y_m = abs(y)
y_s = copysign(1.0d0, y)
z_m = abs(z)
z_s = copysign(1.0d0, z)
real(8) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a)
real(8), intent (in) :: z_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x_s
real(8), intent (in) :: x_m
real(8), intent (in) :: y_m
real(8), intent (in) :: z_m
real(8), intent (in) :: t
real(8), intent (in) :: a
code = z_s * (y_s * (x_s * (x_m * y_m)))
end function
x_m = Math.abs(x);
x_s = Math.copySign(1.0, x);
y_m = Math.abs(y);
y_s = Math.copySign(1.0, y);
z_m = Math.abs(z);
z_s = Math.copySign(1.0, z);
public static double code(double z_s, double y_s, double x_s, double x_m, double y_m, double z_m, double t, double a) {
return z_s * (y_s * (x_s * (x_m * y_m)));
}
x_m = math.fabs(x) x_s = math.copysign(1.0, x) y_m = math.fabs(y) y_s = math.copysign(1.0, y) z_m = math.fabs(z) z_s = math.copysign(1.0, z) def code(z_s, y_s, x_s, x_m, y_m, z_m, t, a): return z_s * (y_s * (x_s * (x_m * y_m)))
x_m = abs(x) x_s = copysign(1.0, x) y_m = abs(y) y_s = copysign(1.0, y) z_m = abs(z) z_s = copysign(1.0, z) function code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) return Float64(z_s * Float64(y_s * Float64(x_s * Float64(x_m * y_m)))) end
x_m = abs(x); x_s = sign(x) * abs(1.0); y_m = abs(y); y_s = sign(y) * abs(1.0); z_m = abs(z); z_s = sign(z) * abs(1.0); function tmp = code(z_s, y_s, x_s, x_m, y_m, z_m, t, a) tmp = z_s * (y_s * (x_s * (x_m * y_m))); end
x_m = N[Abs[x], $MachinePrecision]
x_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[x]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
y_m = N[Abs[y], $MachinePrecision]
y_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
z_m = N[Abs[z], $MachinePrecision]
z_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[z]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
code[z$95$s_, y$95$s_, x$95$s_, x$95$m_, y$95$m_, z$95$m_, t_, a_] := N[(z$95$s * N[(y$95$s * N[(x$95$s * N[(x$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
x_m = \left|x\right|
\\
x_s = \mathsf{copysign}\left(1, x\right)
\\
y_m = \left|y\right|
\\
y_s = \mathsf{copysign}\left(1, y\right)
\\
z_m = \left|z\right|
\\
z_s = \mathsf{copysign}\left(1, z\right)
\\
z_s \cdot \left(y_s \cdot \left(x_s \cdot \left(x_m \cdot y_m\right)\right)\right)
\end{array}
Initial program 63.5%
associate-*l/65.2%
*-commutative65.2%
associate-/l*63.9%
associate-/r/65.0%
associate-/r*62.6%
Simplified62.6%
Taylor expanded in z around inf 43.5%
Final simplification43.5%
(FPCore (x y z t a)
:precision binary64
(if (< z -3.1921305903852764e+46)
(- (* y x))
(if (< z 5.976268120920894e+90)
(/ (* x z) (/ (sqrt (- (* z z) (* a t))) y))
(* y x))))
double code(double x, double y, double z, double t, double a) {
double tmp;
if (z < -3.1921305903852764e+46) {
tmp = -(y * x);
} else if (z < 5.976268120920894e+90) {
tmp = (x * z) / (sqrt(((z * z) - (a * t))) / y);
} else {
tmp = y * x;
}
return tmp;
}
real(8) function code(x, y, z, t, a)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
real(8), intent (in) :: a
real(8) :: tmp
if (z < (-3.1921305903852764d+46)) then
tmp = -(y * x)
else if (z < 5.976268120920894d+90) then
tmp = (x * z) / (sqrt(((z * z) - (a * t))) / y)
else
tmp = y * x
end if
code = tmp
end function
public static double code(double x, double y, double z, double t, double a) {
double tmp;
if (z < -3.1921305903852764e+46) {
tmp = -(y * x);
} else if (z < 5.976268120920894e+90) {
tmp = (x * z) / (Math.sqrt(((z * z) - (a * t))) / y);
} else {
tmp = y * x;
}
return tmp;
}
def code(x, y, z, t, a): tmp = 0 if z < -3.1921305903852764e+46: tmp = -(y * x) elif z < 5.976268120920894e+90: tmp = (x * z) / (math.sqrt(((z * z) - (a * t))) / y) else: tmp = y * x return tmp
function code(x, y, z, t, a) tmp = 0.0 if (z < -3.1921305903852764e+46) tmp = Float64(-Float64(y * x)); elseif (z < 5.976268120920894e+90) tmp = Float64(Float64(x * z) / Float64(sqrt(Float64(Float64(z * z) - Float64(a * t))) / y)); else tmp = Float64(y * x); end return tmp end
function tmp_2 = code(x, y, z, t, a) tmp = 0.0; if (z < -3.1921305903852764e+46) tmp = -(y * x); elseif (z < 5.976268120920894e+90) tmp = (x * z) / (sqrt(((z * z) - (a * t))) / y); else tmp = y * x; end tmp_2 = tmp; end
code[x_, y_, z_, t_, a_] := If[Less[z, -3.1921305903852764e+46], (-N[(y * x), $MachinePrecision]), If[Less[z, 5.976268120920894e+90], N[(N[(x * z), $MachinePrecision] / N[(N[Sqrt[N[(N[(z * z), $MachinePrecision] - N[(a * t), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / y), $MachinePrecision]), $MachinePrecision], N[(y * x), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z < -3.1921305903852764 \cdot 10^{+46}:\\
\;\;\;\;-y \cdot x\\
\mathbf{elif}\;z < 5.976268120920894 \cdot 10^{+90}:\\
\;\;\;\;\frac{x \cdot z}{\frac{\sqrt{z \cdot z - a \cdot t}}{y}}\\
\mathbf{else}:\\
\;\;\;\;y \cdot x\\
\end{array}
\end{array}
herbie shell --seed 2023321
(FPCore (x y z t a)
:name "Statistics.Math.RootFinding:ridders from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(if (< z -3.1921305903852764e+46) (- (* y x)) (if (< z 5.976268120920894e+90) (/ (* x z) (/ (sqrt (- (* z z) (* a t))) y)) (* y x)))
(/ (* (* x y) z) (sqrt (- (* z z) (* t a)))))