
(FPCore (x y z t) :precision binary64 (* (- (* x y) (* z y)) t))
double code(double x, double y, double z, double t) {
return ((x * y) - (z * y)) * t;
}
real(8) function code(x, y, z, t)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
code = ((x * y) - (z * y)) * t
end function
public static double code(double x, double y, double z, double t) {
return ((x * y) - (z * y)) * t;
}
def code(x, y, z, t): return ((x * y) - (z * y)) * t
function code(x, y, z, t) return Float64(Float64(Float64(x * y) - Float64(z * y)) * t) end
function tmp = code(x, y, z, t) tmp = ((x * y) - (z * y)) * t; end
code[x_, y_, z_, t_] := N[(N[(N[(x * y), $MachinePrecision] - N[(z * y), $MachinePrecision]), $MachinePrecision] * t), $MachinePrecision]
\begin{array}{l}
\\
\left(x \cdot y - z \cdot y\right) \cdot t
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 9 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x y z t) :precision binary64 (* (- (* x y) (* z y)) t))
double code(double x, double y, double z, double t) {
return ((x * y) - (z * y)) * t;
}
real(8) function code(x, y, z, t)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
code = ((x * y) - (z * y)) * t
end function
public static double code(double x, double y, double z, double t) {
return ((x * y) - (z * y)) * t;
}
def code(x, y, z, t): return ((x * y) - (z * y)) * t
function code(x, y, z, t) return Float64(Float64(Float64(x * y) - Float64(z * y)) * t) end
function tmp = code(x, y, z, t) tmp = ((x * y) - (z * y)) * t; end
code[x_, y_, z_, t_] := N[(N[(N[(x * y), $MachinePrecision] - N[(z * y), $MachinePrecision]), $MachinePrecision] * t), $MachinePrecision]
\begin{array}{l}
\\
\left(x \cdot y - z \cdot y\right) \cdot t
\end{array}
y\_m = (fabs.f64 y) y\_s = (copysign.f64 #s(literal 1 binary64) y) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function. (FPCore (t_s y_s x y_m z t_m) :precision binary64 (* t_s (* y_s (if (<= t_m 2e-18) (* t_m (* y_m (- x z))) (* (- x z) (* t_m y_m))))))
y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 2e-18) {
tmp = t_m * (y_m * (x - z));
} else {
tmp = (x - z) * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if (t_m <= 2d-18) then
tmp = t_m * (y_m * (x - z))
else
tmp = (x - z) * (t_m * y_m)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 2e-18) {
tmp = t_m * (y_m * (x - z));
} else {
tmp = (x - z) * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if t_m <= 2e-18: tmp = t_m * (y_m * (x - z)) else: tmp = (x - z) * (t_m * y_m) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if (t_m <= 2e-18) tmp = Float64(t_m * Float64(y_m * Float64(x - z))); else tmp = Float64(Float64(x - z) * Float64(t_m * y_m)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if (t_m <= 2e-18)
tmp = t_m * (y_m * (x - z));
else
tmp = (x - z) * (t_m * y_m);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[LessEqual[t$95$m, 2e-18], N[(t$95$m * N[(y$95$m * N[(x - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(x - z), $MachinePrecision] * N[(t$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 2 \cdot 10^{-18}:\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot \left(x - z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x - z\right) \cdot \left(t\_m \cdot y\_m\right)\\
\end{array}\right)
\end{array}
if t < 2.0000000000000001e-18Initial program 88.1%
distribute-rgt-out--89.3%
Simplified89.3%
if 2.0000000000000001e-18 < t Initial program 95.5%
*-commutative95.5%
distribute-rgt-out--97.0%
associate-*r*98.5%
*-commutative98.5%
Simplified98.5%
Final simplification91.7%
y\_m = (fabs.f64 y)
y\_s = (copysign.f64 #s(literal 1 binary64) y)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
(FPCore (t_s y_s x y_m z t_m)
:precision binary64
(*
t_s
(*
y_s
(if (or (<= z -2.05e+188) (not (<= z 1.18e+153)))
(* t_m (* y_m (- z)))
(* y_m (* t_m (- x z)))))))y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -2.05e+188) || !(z <= 1.18e+153)) {
tmp = t_m * (y_m * -z);
} else {
tmp = y_m * (t_m * (x - z));
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if ((z <= (-2.05d+188)) .or. (.not. (z <= 1.18d+153))) then
tmp = t_m * (y_m * -z)
else
tmp = y_m * (t_m * (x - z))
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -2.05e+188) || !(z <= 1.18e+153)) {
tmp = t_m * (y_m * -z);
} else {
tmp = y_m * (t_m * (x - z));
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if (z <= -2.05e+188) or not (z <= 1.18e+153): tmp = t_m * (y_m * -z) else: tmp = y_m * (t_m * (x - z)) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if ((z <= -2.05e+188) || !(z <= 1.18e+153)) tmp = Float64(t_m * Float64(y_m * Float64(-z))); else tmp = Float64(y_m * Float64(t_m * Float64(x - z))); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if ((z <= -2.05e+188) || ~((z <= 1.18e+153)))
tmp = t_m * (y_m * -z);
else
tmp = y_m * (t_m * (x - z));
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[Or[LessEqual[z, -2.05e+188], N[Not[LessEqual[z, 1.18e+153]], $MachinePrecision]], N[(t$95$m * N[(y$95$m * (-z)), $MachinePrecision]), $MachinePrecision], N[(y$95$m * N[(t$95$m * N[(x - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;z \leq -2.05 \cdot 10^{+188} \lor \neg \left(z \leq 1.18 \cdot 10^{+153}\right):\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot \left(-z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;y\_m \cdot \left(t\_m \cdot \left(x - z\right)\right)\\
\end{array}\right)
\end{array}
if z < -2.05e188 or 1.18e153 < z Initial program 85.4%
distribute-rgt-out--87.1%
Simplified87.1%
Taylor expanded in x around 0 84.4%
neg-mul-184.4%
Simplified84.4%
if -2.05e188 < z < 1.18e153Initial program 91.4%
distribute-rgt-out--92.6%
associate-*l*90.9%
*-commutative90.9%
Simplified90.9%
Final simplification89.4%
y\_m = (fabs.f64 y)
y\_s = (copysign.f64 #s(literal 1 binary64) y)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
(FPCore (t_s y_s x y_m z t_m)
:precision binary64
(*
t_s
(*
y_s
(if (or (<= z -7.2e+95) (not (<= z 3.55e+134)))
(* t_m (* y_m (- z)))
(* t_m (* y_m x))))))y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -7.2e+95) || !(z <= 3.55e+134)) {
tmp = t_m * (y_m * -z);
} else {
tmp = t_m * (y_m * x);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if ((z <= (-7.2d+95)) .or. (.not. (z <= 3.55d+134))) then
tmp = t_m * (y_m * -z)
else
tmp = t_m * (y_m * x)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -7.2e+95) || !(z <= 3.55e+134)) {
tmp = t_m * (y_m * -z);
} else {
tmp = t_m * (y_m * x);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if (z <= -7.2e+95) or not (z <= 3.55e+134): tmp = t_m * (y_m * -z) else: tmp = t_m * (y_m * x) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if ((z <= -7.2e+95) || !(z <= 3.55e+134)) tmp = Float64(t_m * Float64(y_m * Float64(-z))); else tmp = Float64(t_m * Float64(y_m * x)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if ((z <= -7.2e+95) || ~((z <= 3.55e+134)))
tmp = t_m * (y_m * -z);
else
tmp = t_m * (y_m * x);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[Or[LessEqual[z, -7.2e+95], N[Not[LessEqual[z, 3.55e+134]], $MachinePrecision]], N[(t$95$m * N[(y$95$m * (-z)), $MachinePrecision]), $MachinePrecision], N[(t$95$m * N[(y$95$m * x), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;z \leq -7.2 \cdot 10^{+95} \lor \neg \left(z \leq 3.55 \cdot 10^{+134}\right):\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot \left(-z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot x\right)\\
\end{array}\right)
\end{array}
if z < -7.19999999999999955e95 or 3.54999999999999995e134 < z Initial program 88.2%
distribute-rgt-out--89.4%
Simplified89.4%
Taylor expanded in x around 0 83.8%
neg-mul-183.8%
Simplified83.8%
if -7.19999999999999955e95 < z < 3.54999999999999995e134Initial program 90.9%
distribute-rgt-out--92.2%
Simplified92.2%
Taylor expanded in x around inf 72.9%
Final simplification76.3%
y\_m = (fabs.f64 y)
y\_s = (copysign.f64 #s(literal 1 binary64) y)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
(FPCore (t_s y_s x y_m z t_m)
:precision binary64
(*
t_s
(*
y_s
(if (or (<= z -7.2e+95) (not (<= z 1e+134)))
(* z (* t_m (- y_m)))
(* t_m (* y_m x))))))y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -7.2e+95) || !(z <= 1e+134)) {
tmp = z * (t_m * -y_m);
} else {
tmp = t_m * (y_m * x);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if ((z <= (-7.2d+95)) .or. (.not. (z <= 1d+134))) then
tmp = z * (t_m * -y_m)
else
tmp = t_m * (y_m * x)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((z <= -7.2e+95) || !(z <= 1e+134)) {
tmp = z * (t_m * -y_m);
} else {
tmp = t_m * (y_m * x);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if (z <= -7.2e+95) or not (z <= 1e+134): tmp = z * (t_m * -y_m) else: tmp = t_m * (y_m * x) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if ((z <= -7.2e+95) || !(z <= 1e+134)) tmp = Float64(z * Float64(t_m * Float64(-y_m))); else tmp = Float64(t_m * Float64(y_m * x)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if ((z <= -7.2e+95) || ~((z <= 1e+134)))
tmp = z * (t_m * -y_m);
else
tmp = t_m * (y_m * x);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[Or[LessEqual[z, -7.2e+95], N[Not[LessEqual[z, 1e+134]], $MachinePrecision]], N[(z * N[(t$95$m * (-y$95$m)), $MachinePrecision]), $MachinePrecision], N[(t$95$m * N[(y$95$m * x), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;z \leq -7.2 \cdot 10^{+95} \lor \neg \left(z \leq 10^{+134}\right):\\
\;\;\;\;z \cdot \left(t\_m \cdot \left(-y\_m\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot x\right)\\
\end{array}\right)
\end{array}
if z < -7.19999999999999955e95 or 9.99999999999999921e133 < z Initial program 88.2%
*-commutative88.2%
distribute-rgt-out--89.4%
associate-*r*93.2%
*-commutative93.2%
Simplified93.2%
Taylor expanded in x around 0 85.2%
neg-mul-183.8%
Simplified85.2%
if -7.19999999999999955e95 < z < 9.99999999999999921e133Initial program 90.9%
distribute-rgt-out--92.2%
Simplified92.2%
Taylor expanded in x around inf 72.9%
Final simplification76.8%
y\_m = (fabs.f64 y)
y\_s = (copysign.f64 #s(literal 1 binary64) y)
t\_m = (fabs.f64 t)
t\_s = (copysign.f64 #s(literal 1 binary64) t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
(FPCore (t_s y_s x y_m z t_m)
:precision binary64
(*
t_s
(*
y_s
(if (or (<= x -6.2e-31) (not (<= x 2.5e+32)))
(* t_m (* y_m x))
(* y_m (* t_m (- z)))))))y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((x <= -6.2e-31) || !(x <= 2.5e+32)) {
tmp = t_m * (y_m * x);
} else {
tmp = y_m * (t_m * -z);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if ((x <= (-6.2d-31)) .or. (.not. (x <= 2.5d+32))) then
tmp = t_m * (y_m * x)
else
tmp = y_m * (t_m * -z)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if ((x <= -6.2e-31) || !(x <= 2.5e+32)) {
tmp = t_m * (y_m * x);
} else {
tmp = y_m * (t_m * -z);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if (x <= -6.2e-31) or not (x <= 2.5e+32): tmp = t_m * (y_m * x) else: tmp = y_m * (t_m * -z) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if ((x <= -6.2e-31) || !(x <= 2.5e+32)) tmp = Float64(t_m * Float64(y_m * x)); else tmp = Float64(y_m * Float64(t_m * Float64(-z))); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if ((x <= -6.2e-31) || ~((x <= 2.5e+32)))
tmp = t_m * (y_m * x);
else
tmp = y_m * (t_m * -z);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[Or[LessEqual[x, -6.2e-31], N[Not[LessEqual[x, 2.5e+32]], $MachinePrecision]], N[(t$95$m * N[(y$95$m * x), $MachinePrecision]), $MachinePrecision], N[(y$95$m * N[(t$95$m * (-z)), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;x \leq -6.2 \cdot 10^{-31} \lor \neg \left(x \leq 2.5 \cdot 10^{+32}\right):\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot x\right)\\
\mathbf{else}:\\
\;\;\;\;y\_m \cdot \left(t\_m \cdot \left(-z\right)\right)\\
\end{array}\right)
\end{array}
if x < -6.19999999999999999e-31 or 2.4999999999999999e32 < x Initial program 85.9%
distribute-rgt-out--88.2%
Simplified88.2%
Taylor expanded in x around inf 73.6%
if -6.19999999999999999e-31 < x < 2.4999999999999999e32Initial program 95.0%
distribute-rgt-out--95.0%
associate-*l*89.7%
*-commutative89.7%
Simplified89.7%
Taylor expanded in x around 0 74.4%
mul-1-neg74.4%
*-commutative74.4%
distribute-rgt-neg-in74.4%
Simplified74.4%
Final simplification74.0%
y\_m = (fabs.f64 y) y\_s = (copysign.f64 #s(literal 1 binary64) y) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function. (FPCore (t_s y_s x y_m z t_m) :precision binary64 (* t_s (* y_s (if (<= t_m 3.3e-15) (* y_m (* t_m (- x z))) (* (- x z) (* t_m y_m))))))
y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 3.3e-15) {
tmp = y_m * (t_m * (x - z));
} else {
tmp = (x - z) * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if (t_m <= 3.3d-15) then
tmp = y_m * (t_m * (x - z))
else
tmp = (x - z) * (t_m * y_m)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 3.3e-15) {
tmp = y_m * (t_m * (x - z));
} else {
tmp = (x - z) * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if t_m <= 3.3e-15: tmp = y_m * (t_m * (x - z)) else: tmp = (x - z) * (t_m * y_m) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if (t_m <= 3.3e-15) tmp = Float64(y_m * Float64(t_m * Float64(x - z))); else tmp = Float64(Float64(x - z) * Float64(t_m * y_m)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if (t_m <= 3.3e-15)
tmp = y_m * (t_m * (x - z));
else
tmp = (x - z) * (t_m * y_m);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[LessEqual[t$95$m, 3.3e-15], N[(y$95$m * N[(t$95$m * N[(x - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(x - z), $MachinePrecision] * N[(t$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 3.3 \cdot 10^{-15}:\\
\;\;\;\;y\_m \cdot \left(t\_m \cdot \left(x - z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x - z\right) \cdot \left(t\_m \cdot y\_m\right)\\
\end{array}\right)
\end{array}
if t < 3.3e-15Initial program 88.1%
distribute-rgt-out--89.3%
associate-*l*90.0%
*-commutative90.0%
Simplified90.0%
if 3.3e-15 < t Initial program 95.5%
*-commutative95.5%
distribute-rgt-out--97.0%
associate-*r*98.5%
*-commutative98.5%
Simplified98.5%
Final simplification92.2%
y\_m = (fabs.f64 y) y\_s = (copysign.f64 #s(literal 1 binary64) y) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function. (FPCore (t_s y_s x y_m z t_m) :precision binary64 (* t_s (* y_s (if (<= t_m 5e-8) (* t_m (* y_m x)) (* x (* t_m y_m))))))
y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 5e-8) {
tmp = t_m * (y_m * x);
} else {
tmp = x * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if (t_m <= 5d-8) then
tmp = t_m * (y_m * x)
else
tmp = x * (t_m * y_m)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 5e-8) {
tmp = t_m * (y_m * x);
} else {
tmp = x * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if t_m <= 5e-8: tmp = t_m * (y_m * x) else: tmp = x * (t_m * y_m) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if (t_m <= 5e-8) tmp = Float64(t_m * Float64(y_m * x)); else tmp = Float64(x * Float64(t_m * y_m)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if (t_m <= 5e-8)
tmp = t_m * (y_m * x);
else
tmp = x * (t_m * y_m);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[LessEqual[t$95$m, 5e-8], N[(t$95$m * N[(y$95$m * x), $MachinePrecision]), $MachinePrecision], N[(x * N[(t$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 5 \cdot 10^{-8}:\\
\;\;\;\;t\_m \cdot \left(y\_m \cdot x\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(t\_m \cdot y\_m\right)\\
\end{array}\right)
\end{array}
if t < 4.9999999999999998e-8Initial program 88.2%
distribute-rgt-out--89.4%
Simplified89.4%
Taylor expanded in x around inf 57.1%
if 4.9999999999999998e-8 < t Initial program 95.4%
*-commutative95.4%
distribute-rgt-out--97.0%
associate-*r*98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in x around inf 62.2%
Final simplification58.4%
y\_m = (fabs.f64 y) y\_s = (copysign.f64 #s(literal 1 binary64) y) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function. (FPCore (t_s y_s x y_m z t_m) :precision binary64 (* t_s (* y_s (if (<= t_m 2e-33) (* y_m (* t_m x)) (* x (* t_m y_m))))))
y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 2e-33) {
tmp = y_m * (t_m * x);
} else {
tmp = x * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
real(8) :: tmp
if (t_m <= 2d-33) then
tmp = y_m * (t_m * x)
else
tmp = x * (t_m * y_m)
end if
code = t_s * (y_s * tmp)
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
double tmp;
if (t_m <= 2e-33) {
tmp = y_m * (t_m * x);
} else {
tmp = x * (t_m * y_m);
}
return t_s * (y_s * tmp);
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): tmp = 0 if t_m <= 2e-33: tmp = y_m * (t_m * x) else: tmp = x * (t_m * y_m) return t_s * (y_s * tmp)
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) tmp = 0.0 if (t_m <= 2e-33) tmp = Float64(y_m * Float64(t_m * x)); else tmp = Float64(x * Float64(t_m * y_m)); end return Float64(t_s * Float64(y_s * tmp)) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp_2 = code(t_s, y_s, x, y_m, z, t_m)
tmp = 0.0;
if (t_m <= 2e-33)
tmp = y_m * (t_m * x);
else
tmp = x * (t_m * y_m);
end
tmp_2 = t_s * (y_s * tmp);
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * If[LessEqual[t$95$m, 2e-33], N[(y$95$m * N[(t$95$m * x), $MachinePrecision]), $MachinePrecision], N[(x * N[(t$95$m * y$95$m), $MachinePrecision]), $MachinePrecision]]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \begin{array}{l}
\mathbf{if}\;t\_m \leq 2 \cdot 10^{-33}:\\
\;\;\;\;y\_m \cdot \left(t\_m \cdot x\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(t\_m \cdot y\_m\right)\\
\end{array}\right)
\end{array}
if t < 2.0000000000000001e-33Initial program 88.1%
distribute-rgt-out--89.3%
associate-*l*90.0%
*-commutative90.0%
Simplified90.0%
Taylor expanded in x around inf 60.0%
if 2.0000000000000001e-33 < t Initial program 95.5%
*-commutative95.5%
distribute-rgt-out--97.0%
associate-*r*98.5%
*-commutative98.5%
Simplified98.5%
Taylor expanded in x around inf 61.3%
Final simplification60.3%
y\_m = (fabs.f64 y) y\_s = (copysign.f64 #s(literal 1 binary64) y) t\_m = (fabs.f64 t) t\_s = (copysign.f64 #s(literal 1 binary64) t) NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function. (FPCore (t_s y_s x y_m z t_m) :precision binary64 (* t_s (* y_s (* y_m (* t_m x)))))
y\_m = fabs(y);
y\_s = copysign(1.0, y);
t\_m = fabs(t);
t\_s = copysign(1.0, t);
assert(x < y_m && y_m < z && z < t_m);
double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
return t_s * (y_s * (y_m * (t_m * x)));
}
y\_m = abs(y)
y\_s = copysign(1.0d0, y)
t\_m = abs(t)
t\_s = copysign(1.0d0, t)
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
real(8) function code(t_s, y_s, x, y_m, z, t_m)
real(8), intent (in) :: t_s
real(8), intent (in) :: y_s
real(8), intent (in) :: x
real(8), intent (in) :: y_m
real(8), intent (in) :: z
real(8), intent (in) :: t_m
code = t_s * (y_s * (y_m * (t_m * x)))
end function
y\_m = Math.abs(y);
y\_s = Math.copySign(1.0, y);
t\_m = Math.abs(t);
t\_s = Math.copySign(1.0, t);
assert x < y_m && y_m < z && z < t_m;
public static double code(double t_s, double y_s, double x, double y_m, double z, double t_m) {
return t_s * (y_s * (y_m * (t_m * x)));
}
y\_m = math.fabs(y) y\_s = math.copysign(1.0, y) t\_m = math.fabs(t) t\_s = math.copysign(1.0, t) [x, y_m, z, t_m] = sort([x, y_m, z, t_m]) def code(t_s, y_s, x, y_m, z, t_m): return t_s * (y_s * (y_m * (t_m * x)))
y\_m = abs(y) y\_s = copysign(1.0, y) t\_m = abs(t) t\_s = copysign(1.0, t) x, y_m, z, t_m = sort([x, y_m, z, t_m]) function code(t_s, y_s, x, y_m, z, t_m) return Float64(t_s * Float64(y_s * Float64(y_m * Float64(t_m * x)))) end
y\_m = abs(y);
y\_s = sign(y) * abs(1.0);
t\_m = abs(t);
t\_s = sign(t) * abs(1.0);
x, y_m, z, t_m = num2cell(sort([x, y_m, z, t_m])){:}
function tmp = code(t_s, y_s, x, y_m, z, t_m)
tmp = t_s * (y_s * (y_m * (t_m * x)));
end
y\_m = N[Abs[y], $MachinePrecision]
y\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[y]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
t\_m = N[Abs[t], $MachinePrecision]
t\_s = N[With[{TMP1 = Abs[1.0], TMP2 = Sign[t]}, TMP1 * If[TMP2 == 0, 1, TMP2]], $MachinePrecision]
NOTE: x, y_m, z, and t_m should be sorted in increasing order before calling this function.
code[t$95$s_, y$95$s_, x_, y$95$m_, z_, t$95$m_] := N[(t$95$s * N[(y$95$s * N[(y$95$m * N[(t$95$m * x), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
y\_m = \left|y\right|
\\
y\_s = \mathsf{copysign}\left(1, y\right)
\\
t\_m = \left|t\right|
\\
t\_s = \mathsf{copysign}\left(1, t\right)
\\
[x, y_m, z, t_m] = \mathsf{sort}([x, y_m, z, t_m])\\
\\
t\_s \cdot \left(y\_s \cdot \left(y\_m \cdot \left(t\_m \cdot x\right)\right)\right)
\end{array}
Initial program 90.1%
distribute-rgt-out--91.3%
associate-*l*89.7%
*-commutative89.7%
Simplified89.7%
Taylor expanded in x around inf 57.7%
(FPCore (x y z t) :precision binary64 (if (< t -9.231879582886777e-80) (* (* y t) (- x z)) (if (< t 2.543067051564877e+83) (* y (* t (- x z))) (* (* y (- x z)) t))))
double code(double x, double y, double z, double t) {
double tmp;
if (t < -9.231879582886777e-80) {
tmp = (y * t) * (x - z);
} else if (t < 2.543067051564877e+83) {
tmp = y * (t * (x - z));
} else {
tmp = (y * (x - z)) * t;
}
return tmp;
}
real(8) function code(x, y, z, t)
real(8), intent (in) :: x
real(8), intent (in) :: y
real(8), intent (in) :: z
real(8), intent (in) :: t
real(8) :: tmp
if (t < (-9.231879582886777d-80)) then
tmp = (y * t) * (x - z)
else if (t < 2.543067051564877d+83) then
tmp = y * (t * (x - z))
else
tmp = (y * (x - z)) * t
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if (t < -9.231879582886777e-80) {
tmp = (y * t) * (x - z);
} else if (t < 2.543067051564877e+83) {
tmp = y * (t * (x - z));
} else {
tmp = (y * (x - z)) * t;
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if t < -9.231879582886777e-80: tmp = (y * t) * (x - z) elif t < 2.543067051564877e+83: tmp = y * (t * (x - z)) else: tmp = (y * (x - z)) * t return tmp
function code(x, y, z, t) tmp = 0.0 if (t < -9.231879582886777e-80) tmp = Float64(Float64(y * t) * Float64(x - z)); elseif (t < 2.543067051564877e+83) tmp = Float64(y * Float64(t * Float64(x - z))); else tmp = Float64(Float64(y * Float64(x - z)) * t); end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if (t < -9.231879582886777e-80) tmp = (y * t) * (x - z); elseif (t < 2.543067051564877e+83) tmp = y * (t * (x - z)); else tmp = (y * (x - z)) * t; end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[Less[t, -9.231879582886777e-80], N[(N[(y * t), $MachinePrecision] * N[(x - z), $MachinePrecision]), $MachinePrecision], If[Less[t, 2.543067051564877e+83], N[(y * N[(t * N[(x - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(N[(y * N[(x - z), $MachinePrecision]), $MachinePrecision] * t), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t < -9.231879582886777 \cdot 10^{-80}:\\
\;\;\;\;\left(y \cdot t\right) \cdot \left(x - z\right)\\
\mathbf{elif}\;t < 2.543067051564877 \cdot 10^{+83}:\\
\;\;\;\;y \cdot \left(t \cdot \left(x - z\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(y \cdot \left(x - z\right)\right) \cdot t\\
\end{array}
\end{array}
herbie shell --seed 2024110
(FPCore (x y z t)
:name "Linear.Projection:inverseInfinitePerspective from linear-1.19.1.3"
:precision binary64
:alt
(if (< t -9.231879582886777e-80) (* (* y t) (- x z)) (if (< t 2.543067051564877e+83) (* y (* t (- x z))) (* (* y (- x z)) t)))
(* (- (* x y) (* z y)) t))