
(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 14 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 (/ (* z_m (* y_m x_m)) (sqrt (- (* z_m z_m) (* t a))))))
(*
z_s
(*
y_s
(*
x_s
(if (<= t_1 0.0)
(/ (* y_m x_m) (/ (+ z_m (/ -0.5 (/ (/ z_m t) a))) z_m))
(if (<= t_1 5e+207) t_1 (* y_m 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 t_1 = (z_m * (y_m * x_m)) / sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (t_1 <= 0.0) {
tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / z_m);
} else if (t_1 <= 5e+207) {
tmp = t_1;
} else {
tmp = y_m * 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) :: t_1
real(8) :: tmp
t_1 = (z_m * (y_m * x_m)) / sqrt(((z_m * z_m) - (t * a)))
if (t_1 <= 0.0d0) then
tmp = (y_m * x_m) / ((z_m + ((-0.5d0) / ((z_m / t) / a))) / z_m)
else if (t_1 <= 5d+207) then
tmp = t_1
else
tmp = y_m * 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 t_1 = (z_m * (y_m * x_m)) / Math.sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (t_1 <= 0.0) {
tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / z_m);
} else if (t_1 <= 5e+207) {
tmp = t_1;
} else {
tmp = y_m * 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): t_1 = (z_m * (y_m * x_m)) / math.sqrt(((z_m * z_m) - (t * a))) tmp = 0 if t_1 <= 0.0: tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / z_m) elif t_1 <= 5e+207: tmp = t_1 else: tmp = y_m * 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) t_1 = Float64(Float64(z_m * Float64(y_m * x_m)) / sqrt(Float64(Float64(z_m * z_m) - Float64(t * a)))) tmp = 0.0 if (t_1 <= 0.0) tmp = Float64(Float64(y_m * x_m) / Float64(Float64(z_m + Float64(-0.5 / Float64(Float64(z_m / t) / a))) / z_m)); elseif (t_1 <= 5e+207) tmp = t_1; else tmp = Float64(y_m * 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) t_1 = (z_m * (y_m * x_m)) / sqrt(((z_m * z_m) - (t * a))); tmp = 0.0; if (t_1 <= 0.0) tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / z_m); elseif (t_1 <= 5e+207) tmp = t_1; else tmp = y_m * 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_] := Block[{t$95$1 = N[(N[(z$95$m * N[(y$95$m * x$95$m), $MachinePrecision]), $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[(N[(y$95$m * x$95$m), $MachinePrecision] / N[(N[(z$95$m + N[(-0.5 / N[(N[(z$95$m / t), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision], If[LessEqual[t$95$1, 5e+207], t$95$1, N[(y$95$m * x$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{z_m \cdot \left(y_m \cdot x_m\right)}{\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 \cdot x_m}{\frac{z_m + \frac{-0.5}{\frac{\frac{z_m}{t}}{a}}}{z_m}}\\
\mathbf{elif}\;t_1 \leq 5 \cdot 10^{+207}:\\
\;\;\;\;t_1\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_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 70.5%
Taylor expanded in z around inf 56.4%
associate-*r/56.4%
Simplified56.4%
*-un-lft-identity56.4%
associate-/l*57.6%
associate-/l*57.6%
Applied egg-rr57.6%
expm1-log1p-u36.1%
expm1-udef34.1%
Applied egg-rr34.1%
expm1-def36.1%
expm1-log1p57.6%
*-lft-identity57.6%
associate-/l*57.6%
associate-/l*57.6%
associate-/l*57.6%
*-lft-identity57.6%
Simplified57.6%
if 0.0 < (/.f64 (*.f64 (*.f64 x y) z) (sqrt.f64 (-.f64 (*.f64 z z) (*.f64 t a)))) < 4.9999999999999999e207Initial program 99.7%
if 4.9999999999999999e207 < (/.f64 (*.f64 (*.f64 x y) z) (sqrt.f64 (-.f64 (*.f64 z z) (*.f64 t a)))) Initial program 25.3%
associate-*l/29.4%
*-commutative29.4%
associate-/l*29.7%
associate-/r/32.8%
associate-/r*32.1%
Simplified32.1%
Taylor expanded in z around inf 49.4%
Final simplification62.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
(if (<= z_m 1.2e+80)
(* (* z_m (/ y_m (sqrt (- (pow z_m 2.0) (* t a))))) x_m)
(* y_m 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 (z_m <= 1.2e+80) {
tmp = (z_m * (y_m / sqrt((pow(z_m, 2.0) - (t * a))))) * x_m;
} else {
tmp = y_m * 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 (z_m <= 1.2d+80) then
tmp = (z_m * (y_m / sqrt(((z_m ** 2.0d0) - (t * a))))) * x_m
else
tmp = y_m * 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 (z_m <= 1.2e+80) {
tmp = (z_m * (y_m / Math.sqrt((Math.pow(z_m, 2.0) - (t * a))))) * x_m;
} else {
tmp = y_m * 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 z_m <= 1.2e+80: tmp = (z_m * (y_m / math.sqrt((math.pow(z_m, 2.0) - (t * a))))) * x_m else: tmp = y_m * 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 (z_m <= 1.2e+80) tmp = Float64(Float64(z_m * Float64(y_m / sqrt(Float64((z_m ^ 2.0) - Float64(t * a))))) * x_m); else tmp = Float64(y_m * 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 (z_m <= 1.2e+80) tmp = (z_m * (y_m / sqrt(((z_m ^ 2.0) - (t * a))))) * x_m; else tmp = y_m * 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[z$95$m, 1.2e+80], N[(N[(z$95$m * N[(y$95$m / N[Sqrt[N[(N[Power[z$95$m, 2.0], $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * x$95$m), $MachinePrecision], N[(y$95$m * x$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 1.2 \cdot 10^{+80}:\\
\;\;\;\;\left(z_m \cdot \frac{y_m}{\sqrt{{z_m}^{2} - t \cdot a}}\right) \cdot x_m\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 1.1999999999999999e80Initial program 75.0%
associate-*l/75.7%
*-commutative75.7%
associate-/l*74.6%
associate-/r/76.0%
associate-/r*74.9%
Simplified74.9%
associate-/r/73.1%
*-commutative73.1%
associate-*r*73.4%
pow273.4%
Applied egg-rr73.4%
if 1.1999999999999999e80 < z Initial program 30.7%
associate-*l/32.4%
*-commutative32.4%
associate-/l*29.6%
associate-/r/31.1%
associate-/r*30.4%
Simplified30.4%
Taylor expanded in z around inf 98.3%
Final simplification78.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
(if (<= z_m 4.6e-71)
(* x_m (* z_m (/ y_m (sqrt (* a (- t))))))
(if (<= z_m 1.16e+80)
(/ y_m (/ (sqrt (- (* z_m z_m) (* t a))) (* z_m x_m)))
(* y_m 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 (z_m <= 4.6e-71) {
tmp = x_m * (z_m * (y_m / sqrt((a * -t))));
} else if (z_m <= 1.16e+80) {
tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (z_m * x_m));
} else {
tmp = y_m * 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 (z_m <= 4.6d-71) then
tmp = x_m * (z_m * (y_m / sqrt((a * -t))))
else if (z_m <= 1.16d+80) then
tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (z_m * x_m))
else
tmp = y_m * 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 (z_m <= 4.6e-71) {
tmp = x_m * (z_m * (y_m / Math.sqrt((a * -t))));
} else if (z_m <= 1.16e+80) {
tmp = y_m / (Math.sqrt(((z_m * z_m) - (t * a))) / (z_m * x_m));
} else {
tmp = y_m * 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 z_m <= 4.6e-71: tmp = x_m * (z_m * (y_m / math.sqrt((a * -t)))) elif z_m <= 1.16e+80: tmp = y_m / (math.sqrt(((z_m * z_m) - (t * a))) / (z_m * x_m)) else: tmp = y_m * 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 (z_m <= 4.6e-71) tmp = Float64(x_m * Float64(z_m * Float64(y_m / sqrt(Float64(a * Float64(-t)))))); elseif (z_m <= 1.16e+80) tmp = Float64(y_m / Float64(sqrt(Float64(Float64(z_m * z_m) - Float64(t * a))) / Float64(z_m * x_m))); else tmp = Float64(y_m * 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 (z_m <= 4.6e-71) tmp = x_m * (z_m * (y_m / sqrt((a * -t)))); elseif (z_m <= 1.16e+80) tmp = y_m / (sqrt(((z_m * z_m) - (t * a))) / (z_m * x_m)); else tmp = y_m * 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[z$95$m, 4.6e-71], N[(x$95$m * N[(z$95$m * N[(y$95$m / N[Sqrt[N[(a * (-t)), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], If[LessEqual[z$95$m, 1.16e+80], N[(y$95$m / N[(N[Sqrt[N[(N[(z$95$m * z$95$m), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision] / N[(z$95$m * x$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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 4.6 \cdot 10^{-71}:\\
\;\;\;\;x_m \cdot \left(z_m \cdot \frac{y_m}{\sqrt{a \cdot \left(-t\right)}}\right)\\
\mathbf{elif}\;z_m \leq 1.16 \cdot 10^{+80}:\\
\;\;\;\;\frac{y_m}{\frac{\sqrt{z_m \cdot z_m - t \cdot a}}{z_m \cdot x_m}}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 4.5999999999999997e-71Initial program 70.8%
associate-*l/71.7%
*-commutative71.7%
associate-/l*71.1%
associate-/r/72.8%
associate-/r*70.1%
Simplified70.1%
associate-/r/68.2%
*-commutative68.2%
associate-*r*68.8%
pow268.8%
Applied egg-rr68.8%
Taylor expanded in z around 0 41.3%
neg-mul-141.3%
distribute-rgt-neg-in41.3%
Simplified41.3%
if 4.5999999999999997e-71 < z < 1.15999999999999997e80Initial program 90.9%
associate-*l/91.0%
*-commutative91.0%
associate-/l*87.9%
associate-/r/88.0%
associate-/r*92.8%
Simplified92.8%
if 1.15999999999999997e80 < z Initial program 30.7%
associate-*l/32.4%
*-commutative32.4%
associate-/l*29.6%
associate-/r/31.1%
associate-/r*30.4%
Simplified30.4%
Taylor expanded in z around inf 98.3%
Final simplification62.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
(let* ((t_1 (sqrt (- (* z_m z_m) (* t a)))))
(*
z_s
(*
y_s
(*
x_s
(if (<= z_m 8.8e+29)
(/ (* x_m (* z_m y_m)) t_1)
(if (<= z_m 1.25e+80) (/ y_m (/ t_1 (* z_m x_m))) (* y_m 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 t_1 = sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (z_m <= 8.8e+29) {
tmp = (x_m * (z_m * y_m)) / t_1;
} else if (z_m <= 1.25e+80) {
tmp = y_m / (t_1 / (z_m * x_m));
} else {
tmp = y_m * 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) :: t_1
real(8) :: tmp
t_1 = sqrt(((z_m * z_m) - (t * a)))
if (z_m <= 8.8d+29) then
tmp = (x_m * (z_m * y_m)) / t_1
else if (z_m <= 1.25d+80) then
tmp = y_m / (t_1 / (z_m * x_m))
else
tmp = y_m * 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 t_1 = Math.sqrt(((z_m * z_m) - (t * a)));
double tmp;
if (z_m <= 8.8e+29) {
tmp = (x_m * (z_m * y_m)) / t_1;
} else if (z_m <= 1.25e+80) {
tmp = y_m / (t_1 / (z_m * x_m));
} else {
tmp = y_m * 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): t_1 = math.sqrt(((z_m * z_m) - (t * a))) tmp = 0 if z_m <= 8.8e+29: tmp = (x_m * (z_m * y_m)) / t_1 elif z_m <= 1.25e+80: tmp = y_m / (t_1 / (z_m * x_m)) else: tmp = y_m * 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) t_1 = sqrt(Float64(Float64(z_m * z_m) - Float64(t * a))) tmp = 0.0 if (z_m <= 8.8e+29) tmp = Float64(Float64(x_m * Float64(z_m * y_m)) / t_1); elseif (z_m <= 1.25e+80) tmp = Float64(y_m / Float64(t_1 / Float64(z_m * x_m))); else tmp = Float64(y_m * 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) t_1 = sqrt(((z_m * z_m) - (t * a))); tmp = 0.0; if (z_m <= 8.8e+29) tmp = (x_m * (z_m * y_m)) / t_1; elseif (z_m <= 1.25e+80) tmp = y_m / (t_1 / (z_m * x_m)); else tmp = y_m * 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_] := Block[{t$95$1 = N[Sqrt[N[(N[(z$95$m * z$95$m), $MachinePrecision] - N[(t * a), $MachinePrecision]), $MachinePrecision]], $MachinePrecision]}, N[(z$95$s * N[(y$95$s * N[(x$95$s * If[LessEqual[z$95$m, 8.8e+29], N[(N[(x$95$m * N[(z$95$m * y$95$m), $MachinePrecision]), $MachinePrecision] / t$95$1), $MachinePrecision], If[LessEqual[z$95$m, 1.25e+80], N[(y$95$m / N[(t$95$1 / N[(z$95$m * x$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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 := \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}\;z_m \leq 8.8 \cdot 10^{+29}:\\
\;\;\;\;\frac{x_m \cdot \left(z_m \cdot y_m\right)}{t_1}\\
\mathbf{elif}\;z_m \leq 1.25 \cdot 10^{+80}:\\
\;\;\;\;\frac{y_m}{\frac{t_1}{z_m \cdot x_m}}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
\end{array}
if z < 8.8000000000000005e29Initial program 73.9%
associate-*l*68.8%
Simplified68.8%
if 8.8000000000000005e29 < z < 1.2499999999999999e80Initial program 88.1%
associate-*l/82.9%
*-commutative82.9%
associate-/l*82.6%
associate-/r/82.5%
associate-/r*87.4%
Simplified87.4%
if 1.2499999999999999e80 < z Initial program 30.7%
associate-*l/32.4%
*-commutative32.4%
associate-/l*29.6%
associate-/r/31.1%
associate-/r*30.4%
Simplified30.4%
Taylor expanded in z around inf 98.3%
Final simplification76.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 (<= z_m 2.7e-80)
(* x_m (* z_m (/ y_m (sqrt (* a (- t))))))
(* x_m (* y_m (/ z_m (fma (* a (/ -0.5 z_m)) t 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 <= 2.7e-80) {
tmp = x_m * (z_m * (y_m / sqrt((a * -t))));
} else {
tmp = x_m * (y_m * (z_m / fma((a * (-0.5 / z_m)), t, 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 <= 2.7e-80) tmp = Float64(x_m * Float64(z_m * Float64(y_m / sqrt(Float64(a * Float64(-t)))))); else tmp = Float64(x_m * Float64(y_m * Float64(z_m / fma(Float64(a * Float64(-0.5 / z_m)), t, z_m)))); end return Float64(z_s * Float64(y_s * Float64(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, 2.7e-80], N[(x$95$m * N[(z$95$m * N[(y$95$m / N[Sqrt[N[(a * (-t)), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(x$95$m * N[(y$95$m * N[(z$95$m / N[(N[(a * N[(-0.5 / z$95$m), $MachinePrecision]), $MachinePrecision] * t + 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}\;z_m \leq 2.7 \cdot 10^{-80}:\\
\;\;\;\;x_m \cdot \left(z_m \cdot \frac{y_m}{\sqrt{a \cdot \left(-t\right)}}\right)\\
\mathbf{else}:\\
\;\;\;\;x_m \cdot \left(y_m \cdot \frac{z_m}{\mathsf{fma}\left(a \cdot \frac{-0.5}{z_m}, t, z_m\right)}\right)\\
\end{array}\right)\right)
\end{array}
if z < 2.7000000000000002e-80Initial program 70.8%
associate-*l/71.7%
*-commutative71.7%
associate-/l*71.1%
associate-/r/72.8%
associate-/r*70.1%
Simplified70.1%
associate-/r/68.2%
*-commutative68.2%
associate-*r*68.8%
pow268.8%
Applied egg-rr68.8%
Taylor expanded in z around 0 41.3%
neg-mul-141.3%
distribute-rgt-neg-in41.3%
Simplified41.3%
if 2.7000000000000002e-80 < z Initial program 56.5%
associate-*l/57.5%
*-commutative57.5%
associate-/l*54.6%
associate-/r/55.5%
associate-/r*57.1%
Simplified57.1%
Taylor expanded in z around inf 74.6%
associate-*r/74.2%
Simplified74.6%
Taylor expanded in a around 0 74.6%
associate-/l*75.9%
Simplified75.9%
div-inv76.1%
+-commutative76.1%
fma-def76.1%
associate-/r/76.1%
*-commutative76.1%
Applied egg-rr76.1%
Taylor expanded in y around 0 69.3%
associate-*r*74.2%
associate-*r/74.2%
associate-*l/74.2%
+-commutative74.2%
fma-udef74.2%
associate-/l*86.8%
associate-*r/86.9%
*-rgt-identity86.9%
associate-*r/86.9%
associate-/r/86.6%
associate-*l/86.9%
*-lft-identity86.9%
fma-udef86.9%
associate-*r*90.9%
fma-def90.9%
*-commutative90.9%
Simplified90.9%
Final simplification60.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 3.3e-80)
(* x_m (* z_m (/ y_m (sqrt (* a (- t))))))
(/ (* y_m x_m) (/ (+ z_m (/ -0.5 (/ (/ z_m t) a))) 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 <= 3.3e-80) {
tmp = x_m * (z_m * (y_m / sqrt((a * -t))));
} else {
tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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 <= 3.3d-80) then
tmp = x_m * (z_m * (y_m / sqrt((a * -t))))
else
tmp = (y_m * x_m) / ((z_m + ((-0.5d0) / ((z_m / t) / a))) / 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 <= 3.3e-80) {
tmp = x_m * (z_m * (y_m / Math.sqrt((a * -t))));
} else {
tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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 <= 3.3e-80: tmp = x_m * (z_m * (y_m / math.sqrt((a * -t)))) else: tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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 <= 3.3e-80) tmp = Float64(x_m * Float64(z_m * Float64(y_m / sqrt(Float64(a * Float64(-t)))))); else tmp = Float64(Float64(y_m * x_m) / Float64(Float64(z_m + Float64(-0.5 / Float64(Float64(z_m / t) / a))) / 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 <= 3.3e-80) tmp = x_m * (z_m * (y_m / sqrt((a * -t)))); else tmp = (y_m * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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, 3.3e-80], N[(x$95$m * N[(z$95$m * N[(y$95$m / N[Sqrt[N[(a * (-t)), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(y$95$m * x$95$m), $MachinePrecision] / N[(N[(z$95$m + N[(-0.5 / N[(N[(z$95$m / t), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 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}\;z_m \leq 3.3 \cdot 10^{-80}:\\
\;\;\;\;x_m \cdot \left(z_m \cdot \frac{y_m}{\sqrt{a \cdot \left(-t\right)}}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{y_m \cdot x_m}{\frac{z_m + \frac{-0.5}{\frac{\frac{z_m}{t}}{a}}}{z_m}}\\
\end{array}\right)\right)
\end{array}
if z < 3.3e-80Initial program 70.8%
associate-*l/71.7%
*-commutative71.7%
associate-/l*71.1%
associate-/r/72.8%
associate-/r*70.1%
Simplified70.1%
associate-/r/68.2%
*-commutative68.2%
associate-*r*68.8%
pow268.8%
Applied egg-rr68.8%
Taylor expanded in z around 0 41.3%
neg-mul-141.3%
distribute-rgt-neg-in41.3%
Simplified41.3%
if 3.3e-80 < z Initial program 56.5%
Taylor expanded in z around inf 74.2%
associate-*r/74.2%
Simplified74.2%
*-un-lft-identity74.2%
associate-/l*86.8%
associate-/l*86.8%
Applied egg-rr86.8%
expm1-log1p-u46.9%
expm1-udef39.2%
Applied egg-rr39.2%
expm1-def46.9%
expm1-log1p86.8%
*-lft-identity86.8%
associate-/l*86.8%
associate-/l*90.9%
associate-/l*90.9%
*-lft-identity90.9%
Simplified90.9%
Final simplification60.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 8.4e-175)
(* -2.0 (/ x_m (* (/ a y_m) (* (/ 1.0 z_m) (/ t z_m)))))
(* y_m 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 (z_m <= 8.4e-175) {
tmp = -2.0 * (x_m / ((a / y_m) * ((1.0 / z_m) * (t / z_m))));
} else {
tmp = y_m * 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 (z_m <= 8.4d-175) then
tmp = (-2.0d0) * (x_m / ((a / y_m) * ((1.0d0 / z_m) * (t / z_m))))
else
tmp = y_m * 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 (z_m <= 8.4e-175) {
tmp = -2.0 * (x_m / ((a / y_m) * ((1.0 / z_m) * (t / z_m))));
} else {
tmp = y_m * 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 z_m <= 8.4e-175: tmp = -2.0 * (x_m / ((a / y_m) * ((1.0 / z_m) * (t / z_m)))) else: tmp = y_m * 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 (z_m <= 8.4e-175) tmp = Float64(-2.0 * Float64(x_m / Float64(Float64(a / y_m) * Float64(Float64(1.0 / z_m) * Float64(t / z_m))))); else tmp = Float64(y_m * 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 (z_m <= 8.4e-175) tmp = -2.0 * (x_m / ((a / y_m) * ((1.0 / z_m) * (t / z_m)))); else tmp = y_m * 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[z$95$m, 8.4e-175], N[(-2.0 * N[(x$95$m / N[(N[(a / y$95$m), $MachinePrecision] * N[(N[(1.0 / z$95$m), $MachinePrecision] * N[(t / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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 8.4 \cdot 10^{-175}:\\
\;\;\;\;-2 \cdot \frac{x_m}{\frac{a}{y_m} \cdot \left(\frac{1}{z_m} \cdot \frac{t}{z_m}\right)}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 8.4e-175Initial program 68.7%
associate-*l/69.6%
*-commutative69.6%
associate-/l*68.9%
associate-/r/70.8%
associate-/r*67.9%
Simplified67.9%
Taylor expanded in z around inf 27.4%
associate-*r/27.4%
Simplified27.4%
Taylor expanded in z around 0 22.6%
associate-/l*22.0%
times-frac22.0%
Simplified22.0%
*-un-lft-identity22.0%
unpow222.0%
times-frac22.1%
Applied egg-rr22.1%
if 8.4e-175 < z Initial program 60.9%
associate-*l/61.7%
*-commutative61.7%
associate-/l*59.1%
associate-/r/59.9%
associate-/r*61.4%
Simplified61.4%
Taylor expanded in z around inf 84.0%
Final simplification48.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 (<= z_m 5.2e+50)
(* z_m (* x_m (/ y_m (+ z_m (/ (* t (* a -0.5)) z_m)))))
(* y_m 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 (z_m <= 5.2e+50) {
tmp = z_m * (x_m * (y_m / (z_m + ((t * (a * -0.5)) / z_m))));
} else {
tmp = y_m * 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 (z_m <= 5.2d+50) then
tmp = z_m * (x_m * (y_m / (z_m + ((t * (a * (-0.5d0))) / z_m))))
else
tmp = y_m * 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 (z_m <= 5.2e+50) {
tmp = z_m * (x_m * (y_m / (z_m + ((t * (a * -0.5)) / z_m))));
} else {
tmp = y_m * 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 z_m <= 5.2e+50: tmp = z_m * (x_m * (y_m / (z_m + ((t * (a * -0.5)) / z_m)))) else: tmp = y_m * 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 (z_m <= 5.2e+50) tmp = Float64(z_m * Float64(x_m * Float64(y_m / Float64(z_m + Float64(Float64(t * Float64(a * -0.5)) / z_m))))); else tmp = Float64(y_m * 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 (z_m <= 5.2e+50) tmp = z_m * (x_m * (y_m / (z_m + ((t * (a * -0.5)) / z_m)))); else tmp = y_m * 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[z$95$m, 5.2e+50], N[(z$95$m * N[(x$95$m * N[(y$95$m / N[(z$95$m + N[(N[(t * N[(a * -0.5), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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 5.2 \cdot 10^{+50}:\\
\;\;\;\;z_m \cdot \left(x_m \cdot \frac{y_m}{z_m + \frac{t \cdot \left(a \cdot -0.5\right)}{z_m}}\right)\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 5.2000000000000004e50Initial program 74.0%
associate-*l/75.7%
*-commutative75.7%
associate-/l*74.5%
associate-/r/75.9%
associate-/r*74.4%
Simplified74.4%
Taylor expanded in z around inf 37.8%
associate-*r/36.9%
Simplified37.8%
associate-/r/37.9%
associate-*r*38.1%
associate-*r*38.1%
Applied egg-rr38.1%
if 5.2000000000000004e50 < z Initial program 39.3%
associate-*l/38.1%
*-commutative38.1%
associate-/l*35.6%
associate-/r/36.9%
associate-/r*37.5%
Simplified37.5%
Taylor expanded in z around inf 97.1%
Final simplification52.8%
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 1.6e+39)
(/ x_m (/ (+ z_m (/ (* t (* a -0.5)) z_m)) (* z_m y_m)))
(* y_m 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 (z_m <= 1.6e+39) {
tmp = x_m / ((z_m + ((t * (a * -0.5)) / z_m)) / (z_m * y_m));
} else {
tmp = y_m * 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 (z_m <= 1.6d+39) then
tmp = x_m / ((z_m + ((t * (a * (-0.5d0))) / z_m)) / (z_m * y_m))
else
tmp = y_m * 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 (z_m <= 1.6e+39) {
tmp = x_m / ((z_m + ((t * (a * -0.5)) / z_m)) / (z_m * y_m));
} else {
tmp = y_m * 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 z_m <= 1.6e+39: tmp = x_m / ((z_m + ((t * (a * -0.5)) / z_m)) / (z_m * y_m)) else: tmp = y_m * 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 (z_m <= 1.6e+39) tmp = Float64(x_m / Float64(Float64(z_m + Float64(Float64(t * Float64(a * -0.5)) / z_m)) / Float64(z_m * y_m))); else tmp = Float64(y_m * 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 (z_m <= 1.6e+39) tmp = x_m / ((z_m + ((t * (a * -0.5)) / z_m)) / (z_m * y_m)); else tmp = y_m * 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[z$95$m, 1.6e+39], N[(x$95$m / N[(N[(z$95$m + N[(N[(t * N[(a * -0.5), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision] / N[(z$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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 1.6 \cdot 10^{+39}:\\
\;\;\;\;\frac{x_m}{\frac{z_m + \frac{t \cdot \left(a \cdot -0.5\right)}{z_m}}{z_m \cdot y_m}}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 1.59999999999999996e39Initial program 73.9%
associate-*l/75.1%
*-commutative75.1%
associate-/l*73.9%
associate-/r/75.4%
associate-/r*73.8%
Simplified73.8%
associate-/r/71.9%
associate-*l/71.3%
*-commutative71.3%
associate-*l*68.9%
*-commutative68.9%
associate-/l*70.9%
div-inv71.0%
pow271.0%
*-commutative71.0%
Applied egg-rr71.0%
associate-*r/70.9%
*-rgt-identity70.9%
*-commutative70.9%
Simplified70.9%
Taylor expanded in z around inf 35.2%
associate-*r/35.2%
associate-*l*35.2%
*-commutative35.2%
Simplified35.2%
if 1.59999999999999996e39 < z Initial program 41.5%
associate-*l/41.7%
*-commutative41.7%
associate-/l*39.3%
associate-/r/40.6%
associate-/r*41.1%
Simplified41.1%
Taylor expanded in z around inf 95.9%
Final simplification51.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.8e+79)
(/ (* y_m x_m) (/ (+ z_m (/ -0.5 (/ z_m (* t a)))) z_m))
(* y_m 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 (z_m <= 6.8e+79) {
tmp = (y_m * x_m) / ((z_m + (-0.5 / (z_m / (t * a)))) / z_m);
} else {
tmp = y_m * 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 (z_m <= 6.8d+79) then
tmp = (y_m * x_m) / ((z_m + ((-0.5d0) / (z_m / (t * a)))) / z_m)
else
tmp = y_m * 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 (z_m <= 6.8e+79) {
tmp = (y_m * x_m) / ((z_m + (-0.5 / (z_m / (t * a)))) / z_m);
} else {
tmp = y_m * 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 z_m <= 6.8e+79: tmp = (y_m * x_m) / ((z_m + (-0.5 / (z_m / (t * a)))) / z_m) else: tmp = y_m * 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 (z_m <= 6.8e+79) tmp = Float64(Float64(y_m * x_m) / Float64(Float64(z_m + Float64(-0.5 / Float64(z_m / Float64(t * a)))) / z_m)); else tmp = Float64(y_m * 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 (z_m <= 6.8e+79) tmp = (y_m * x_m) / ((z_m + (-0.5 / (z_m / (t * a)))) / z_m); else tmp = y_m * 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[z$95$m, 6.8e+79], N[(N[(y$95$m * x$95$m), $MachinePrecision] / N[(N[(z$95$m + N[(-0.5 / N[(z$95$m / N[(t * a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision]), $MachinePrecision], N[(y$95$m * x$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.8 \cdot 10^{+79}:\\
\;\;\;\;\frac{y_m \cdot x_m}{\frac{z_m + \frac{-0.5}{\frac{z_m}{t \cdot a}}}{z_m}}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 6.80000000000000063e79Initial program 75.0%
Taylor expanded in z around inf 39.5%
associate-*r/39.5%
Simplified39.5%
*-un-lft-identity39.5%
associate-/l*40.4%
associate-/l*40.4%
Applied egg-rr40.4%
if 6.80000000000000063e79 < z Initial program 30.7%
associate-*l/32.4%
*-commutative32.4%
associate-/l*29.6%
associate-/r/31.1%
associate-/r*30.4%
Simplified30.4%
Taylor expanded in z around inf 98.3%
Final simplification53.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 (/ (* y_m x_m) (/ (+ z_m (/ -0.5 (/ (/ z_m t) a))) 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 * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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 * x_m) / ((z_m + ((-0.5d0) / ((z_m / t) / a))) / 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 * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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 * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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(Float64(y_m * x_m) / Float64(Float64(z_m + Float64(-0.5 / Float64(Float64(z_m / t) / a))) / 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 * x_m) / ((z_m + (-0.5 / ((z_m / t) / a))) / 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[(N[(y$95$m * x$95$m), $MachinePrecision] / N[(N[(z$95$m + N[(-0.5 / N[(N[(z$95$m / t), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] / 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 \frac{y_m \cdot x_m}{\frac{z_m + \frac{-0.5}{\frac{\frac{z_m}{t}}{a}}}{z_m}}\right)\right)
\end{array}
Initial program 65.3%
Taylor expanded in z around inf 45.9%
associate-*r/45.9%
Simplified45.9%
*-un-lft-identity45.9%
associate-/l*50.7%
associate-/l*50.7%
Applied egg-rr50.7%
expm1-log1p-u31.7%
expm1-udef28.7%
Applied egg-rr28.7%
expm1-def31.7%
expm1-log1p50.7%
*-lft-identity50.7%
associate-/l*50.7%
associate-/l*52.3%
associate-/l*52.3%
*-lft-identity52.3%
Simplified52.3%
Final simplification52.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 1.4e-135) (/ (* x_m (* z_m y_m)) z_m) (* y_m 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 (z_m <= 1.4e-135) {
tmp = (x_m * (z_m * y_m)) / z_m;
} else {
tmp = y_m * 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 (z_m <= 1.4d-135) then
tmp = (x_m * (z_m * y_m)) / z_m
else
tmp = y_m * 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 (z_m <= 1.4e-135) {
tmp = (x_m * (z_m * y_m)) / z_m;
} else {
tmp = y_m * 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 z_m <= 1.4e-135: tmp = (x_m * (z_m * y_m)) / z_m else: tmp = y_m * 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 (z_m <= 1.4e-135) tmp = Float64(Float64(x_m * Float64(z_m * y_m)) / z_m); else tmp = Float64(y_m * 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 (z_m <= 1.4e-135) tmp = (x_m * (z_m * y_m)) / z_m; else tmp = y_m * 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[z$95$m, 1.4e-135], N[(N[(x$95$m * N[(z$95$m * y$95$m), $MachinePrecision]), $MachinePrecision] / z$95$m), $MachinePrecision], N[(y$95$m * x$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 1.4 \cdot 10^{-135}:\\
\;\;\;\;\frac{x_m \cdot \left(z_m \cdot y_m\right)}{z_m}\\
\mathbf{else}:\\
\;\;\;\;y_m \cdot x_m\\
\end{array}\right)\right)
\end{array}
if z < 1.40000000000000012e-135Initial program 69.3%
associate-*l*64.1%
Simplified64.1%
Taylor expanded in z around inf 22.7%
if 1.40000000000000012e-135 < z Initial program 59.8%
associate-*l/60.7%
*-commutative60.7%
associate-/l*58.0%
associate-/r/58.8%
associate-/r*60.3%
Simplified60.3%
Taylor expanded in z around inf 86.2%
Final simplification49.0%
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 (/ z_m (* z_m 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) {
return z_s * (y_s * (x_s * (y_m / (z_m / (z_m * x_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 / (z_m / (z_m * x_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 / (z_m / (z_m * x_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 / (z_m / (z_m * x_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(z_m / Float64(z_m * x_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 / (z_m / (z_m * x_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[(z$95$m / N[(z$95$m * x$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{z_m}{z_m \cdot x_m}}\right)\right)
\end{array}
Initial program 65.3%
associate-*l/66.3%
*-commutative66.3%
associate-/l*64.8%
associate-/r/66.1%
associate-/r*65.1%
Simplified65.1%
Taylor expanded in z around inf 41.4%
Final simplification41.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 (* y_m 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) {
return z_s * (y_s * (x_s * (y_m * x_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 * x_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 * x_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 * x_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 * x_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 * x_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 * x$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(y_m \cdot x_m\right)\right)\right)
\end{array}
Initial program 65.3%
associate-*l/66.3%
*-commutative66.3%
associate-/l*64.8%
associate-/r/66.1%
associate-/r*65.1%
Simplified65.1%
Taylor expanded in z around inf 44.9%
Final simplification44.9%
(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 2023322
(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)))))