
(FPCore (x y z t a) :precision binary64 (+ x (/ (* (- y z) t) (- a z))))
double code(double x, double y, double z, double t, double a) {
return x + (((y - z) * t) / (a - z));
}
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) * t) / (a - z))
end function
public static double code(double x, double y, double z, double t, double a) {
return x + (((y - z) * t) / (a - z));
}
def code(x, y, z, t, a): return x + (((y - z) * t) / (a - z))
function code(x, y, z, t, a) return Float64(x + Float64(Float64(Float64(y - z) * t) / Float64(a - z))) end
function tmp = code(x, y, z, t, a) tmp = x + (((y - z) * t) / (a - z)); end
code[x_, y_, z_, t_, a_] := N[(x + N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
x + \frac{\left(y - z\right) \cdot t}{a - z}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 10 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x y z t a) :precision binary64 (+ x (/ (* (- y z) t) (- a z))))
double code(double x, double y, double z, double t, double a) {
return x + (((y - z) * t) / (a - z));
}
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) * t) / (a - z))
end function
public static double code(double x, double y, double z, double t, double a) {
return x + (((y - z) * t) / (a - z));
}
def code(x, y, z, t, a): return x + (((y - z) * t) / (a - z))
function code(x, y, z, t, a) return Float64(x + Float64(Float64(Float64(y - z) * t) / Float64(a - z))) end
function tmp = code(x, y, z, t, a) tmp = x + (((y - z) * t) / (a - z)); end
code[x_, y_, z_, t_, a_] := N[(x + N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
x + \frac{\left(y - z\right) \cdot t}{a - z}
\end{array}
(FPCore (x y z t a) :precision binary64 (if (or (<= z -1.35e+187) (not (<= z 7e+29))) (fma (/ z (- a z)) (- t) x) (+ x (/ (* (- y z) t) (- a z)))))
double code(double x, double y, double z, double t, double a) {
double tmp;
if ((z <= -1.35e+187) || !(z <= 7e+29)) {
tmp = fma((z / (a - z)), -t, x);
} else {
tmp = x + (((y - z) * t) / (a - z));
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if ((z <= -1.35e+187) || !(z <= 7e+29)) tmp = fma(Float64(z / Float64(a - z)), Float64(-t), x); else tmp = Float64(x + Float64(Float64(Float64(y - z) * t) / Float64(a - z))); end return tmp end
code[x_, y_, z_, t_, a_] := If[Or[LessEqual[z, -1.35e+187], N[Not[LessEqual[z, 7e+29]], $MachinePrecision]], N[(N[(z / N[(a - z), $MachinePrecision]), $MachinePrecision] * (-t) + x), $MachinePrecision], N[(x + N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -1.35 \cdot 10^{+187} \lor \neg \left(z \leq 7 \cdot 10^{+29}\right):\\
\;\;\;\;\mathsf{fma}\left(\frac{z}{a - z}, -t, x\right)\\
\mathbf{else}:\\
\;\;\;\;x + \frac{\left(y - z\right) \cdot t}{a - z}\\
\end{array}
\end{array}
if z < -1.35000000000000004e187 or 6.99999999999999958e29 < z Initial program 67.4%
Taylor expanded in y around 0
+-commutativeN/A
mul-1-negN/A
associate-/l*N/A
*-commutativeN/A
distribute-rgt-neg-inN/A
mul-1-negN/A
lower-fma.f64N/A
lower-/.f64N/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f6496.7
Applied rewrites96.7%
if -1.35000000000000004e187 < z < 6.99999999999999958e29Initial program 92.7%
Final simplification94.1%
(FPCore (x y z t a) :precision binary64 (let* ((t_1 (/ (* (- y z) t) (- a z)))) (if (or (<= t_1 -1e-91) (not (<= t_1 1e-195))) (+ t x) (* 1.0 x))))
double code(double x, double y, double z, double t, double a) {
double t_1 = ((y - z) * t) / (a - z);
double tmp;
if ((t_1 <= -1e-91) || !(t_1 <= 1e-195)) {
tmp = t + x;
} else {
tmp = 1.0 * 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) :: t_1
real(8) :: tmp
t_1 = ((y - z) * t) / (a - z)
if ((t_1 <= (-1d-91)) .or. (.not. (t_1 <= 1d-195))) then
tmp = t + x
else
tmp = 1.0d0 * x
end if
code = tmp
end function
public static double code(double x, double y, double z, double t, double a) {
double t_1 = ((y - z) * t) / (a - z);
double tmp;
if ((t_1 <= -1e-91) || !(t_1 <= 1e-195)) {
tmp = t + x;
} else {
tmp = 1.0 * x;
}
return tmp;
}
def code(x, y, z, t, a): t_1 = ((y - z) * t) / (a - z) tmp = 0 if (t_1 <= -1e-91) or not (t_1 <= 1e-195): tmp = t + x else: tmp = 1.0 * x return tmp
function code(x, y, z, t, a) t_1 = Float64(Float64(Float64(y - z) * t) / Float64(a - z)) tmp = 0.0 if ((t_1 <= -1e-91) || !(t_1 <= 1e-195)) tmp = Float64(t + x); else tmp = Float64(1.0 * x); end return tmp end
function tmp_2 = code(x, y, z, t, a) t_1 = ((y - z) * t) / (a - z); tmp = 0.0; if ((t_1 <= -1e-91) || ~((t_1 <= 1e-195))) tmp = t + x; else tmp = 1.0 * x; end tmp_2 = tmp; end
code[x_, y_, z_, t_, a_] := Block[{t$95$1 = N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision]}, If[Or[LessEqual[t$95$1, -1e-91], N[Not[LessEqual[t$95$1, 1e-195]], $MachinePrecision]], N[(t + x), $MachinePrecision], N[(1.0 * x), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := \frac{\left(y - z\right) \cdot t}{a - z}\\
\mathbf{if}\;t\_1 \leq -1 \cdot 10^{-91} \lor \neg \left(t\_1 \leq 10^{-195}\right):\\
\;\;\;\;t + x\\
\mathbf{else}:\\
\;\;\;\;1 \cdot x\\
\end{array}
\end{array}
if (/.f64 (*.f64 (-.f64 y z) t) (-.f64 a z)) < -1.00000000000000002e-91 or 1.0000000000000001e-195 < (/.f64 (*.f64 (-.f64 y z) t) (-.f64 a z)) Initial program 78.1%
Taylor expanded in z around inf
lower-+.f6460.0
Applied rewrites60.0%
if -1.00000000000000002e-91 < (/.f64 (*.f64 (-.f64 y z) t) (-.f64 a z)) < 1.0000000000000001e-195Initial program 100.0%
Taylor expanded in y around 0
+-commutativeN/A
mul-1-negN/A
associate-/l*N/A
*-commutativeN/A
distribute-rgt-neg-inN/A
mul-1-negN/A
lower-fma.f64N/A
lower-/.f64N/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f6495.9
Applied rewrites95.9%
Taylor expanded in x around inf
*-commutativeN/A
lower-*.f64N/A
+-commutativeN/A
*-commutativeN/A
times-fracN/A
lower-fma.f64N/A
lower-/.f64N/A
lower--.f64N/A
lower-/.f64N/A
lower--.f6491.4
Applied rewrites91.4%
Taylor expanded in x around inf
Applied rewrites93.2%
Final simplification69.1%
(FPCore (x y z t a) :precision binary64 (if (or (<= a -1.02e+50) (not (<= a 1.7e+30))) (fma (- y z) (/ t a) x) (+ (- x (/ (* t y) z)) t)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if ((a <= -1.02e+50) || !(a <= 1.7e+30)) {
tmp = fma((y - z), (t / a), x);
} else {
tmp = (x - ((t * y) / z)) + t;
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if ((a <= -1.02e+50) || !(a <= 1.7e+30)) tmp = fma(Float64(y - z), Float64(t / a), x); else tmp = Float64(Float64(x - Float64(Float64(t * y) / z)) + t); end return tmp end
code[x_, y_, z_, t_, a_] := If[Or[LessEqual[a, -1.02e+50], N[Not[LessEqual[a, 1.7e+30]], $MachinePrecision]], N[(N[(y - z), $MachinePrecision] * N[(t / a), $MachinePrecision] + x), $MachinePrecision], N[(N[(x - N[(N[(t * y), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] + t), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -1.02 \cdot 10^{+50} \lor \neg \left(a \leq 1.7 \cdot 10^{+30}\right):\\
\;\;\;\;\mathsf{fma}\left(y - z, \frac{t}{a}, x\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x - \frac{t \cdot y}{z}\right) + t\\
\end{array}
\end{array}
if a < -1.01999999999999991e50 or 1.7000000000000001e30 < a Initial program 86.4%
Taylor expanded in a around inf
+-commutativeN/A
*-commutativeN/A
associate-/l*N/A
lower-fma.f64N/A
lower--.f64N/A
lower-/.f6489.0
Applied rewrites89.0%
if -1.01999999999999991e50 < a < 1.7000000000000001e30Initial program 82.2%
Taylor expanded in a around 0
fp-cancel-sign-sub-invN/A
metadata-evalN/A
*-lft-identityN/A
associate-/l*N/A
div-subN/A
*-inversesN/A
distribute-rgt-out--N/A
*-commutativeN/A
associate-/l*N/A
*-lft-identityN/A
associate-+l-N/A
*-lft-identityN/A
metadata-evalN/A
fp-cancel-sign-sub-invN/A
lower-+.f64N/A
fp-cancel-sign-sub-invN/A
metadata-evalN/A
*-lft-identityN/A
lower--.f64N/A
lower-/.f64N/A
lower-*.f6488.0
Applied rewrites88.0%
Final simplification88.5%
(FPCore (x y z t a) :precision binary64 (if (<= a -7.2e+49) (+ x (/ (* (- y z) t) a)) (if (<= a 1.7e+30) (+ (- x (/ (* t y) z)) t) (fma (- y z) (/ t a) x))))
double code(double x, double y, double z, double t, double a) {
double tmp;
if (a <= -7.2e+49) {
tmp = x + (((y - z) * t) / a);
} else if (a <= 1.7e+30) {
tmp = (x - ((t * y) / z)) + t;
} else {
tmp = fma((y - z), (t / a), x);
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if (a <= -7.2e+49) tmp = Float64(x + Float64(Float64(Float64(y - z) * t) / a)); elseif (a <= 1.7e+30) tmp = Float64(Float64(x - Float64(Float64(t * y) / z)) + t); else tmp = fma(Float64(y - z), Float64(t / a), x); end return tmp end
code[x_, y_, z_, t_, a_] := If[LessEqual[a, -7.2e+49], N[(x + N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / a), $MachinePrecision]), $MachinePrecision], If[LessEqual[a, 1.7e+30], N[(N[(x - N[(N[(t * y), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision] + t), $MachinePrecision], N[(N[(y - z), $MachinePrecision] * N[(t / a), $MachinePrecision] + x), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -7.2 \cdot 10^{+49}:\\
\;\;\;\;x + \frac{\left(y - z\right) \cdot t}{a}\\
\mathbf{elif}\;a \leq 1.7 \cdot 10^{+30}:\\
\;\;\;\;\left(x - \frac{t \cdot y}{z}\right) + t\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y - z, \frac{t}{a}, x\right)\\
\end{array}
\end{array}
if a < -7.19999999999999993e49Initial program 93.5%
Taylor expanded in a around inf
lower-/.f64N/A
*-commutativeN/A
lower-*.f64N/A
lower--.f6490.2
Applied rewrites90.2%
if -7.19999999999999993e49 < a < 1.7000000000000001e30Initial program 82.2%
Taylor expanded in a around 0
fp-cancel-sign-sub-invN/A
metadata-evalN/A
*-lft-identityN/A
associate-/l*N/A
div-subN/A
*-inversesN/A
distribute-rgt-out--N/A
*-commutativeN/A
associate-/l*N/A
*-lft-identityN/A
associate-+l-N/A
*-lft-identityN/A
metadata-evalN/A
fp-cancel-sign-sub-invN/A
lower-+.f64N/A
fp-cancel-sign-sub-invN/A
metadata-evalN/A
*-lft-identityN/A
lower--.f64N/A
lower-/.f64N/A
lower-*.f6488.0
Applied rewrites88.0%
if 1.7000000000000001e30 < a Initial program 79.6%
Taylor expanded in a around inf
+-commutativeN/A
*-commutativeN/A
associate-/l*N/A
lower-fma.f64N/A
lower--.f64N/A
lower-/.f6488.0
Applied rewrites88.0%
(FPCore (x y z t a) :precision binary64 (if (or (<= a -0.054) (not (<= a 1.7e+30))) (fma (- y z) (/ t a) x) (+ t x)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if ((a <= -0.054) || !(a <= 1.7e+30)) {
tmp = fma((y - z), (t / a), x);
} else {
tmp = t + x;
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if ((a <= -0.054) || !(a <= 1.7e+30)) tmp = fma(Float64(y - z), Float64(t / a), x); else tmp = Float64(t + x); end return tmp end
code[x_, y_, z_, t_, a_] := If[Or[LessEqual[a, -0.054], N[Not[LessEqual[a, 1.7e+30]], $MachinePrecision]], N[(N[(y - z), $MachinePrecision] * N[(t / a), $MachinePrecision] + x), $MachinePrecision], N[(t + x), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;a \leq -0.054 \lor \neg \left(a \leq 1.7 \cdot 10^{+30}\right):\\
\;\;\;\;\mathsf{fma}\left(y - z, \frac{t}{a}, x\right)\\
\mathbf{else}:\\
\;\;\;\;t + x\\
\end{array}
\end{array}
if a < -0.0539999999999999994 or 1.7000000000000001e30 < a Initial program 87.1%
Taylor expanded in a around inf
+-commutativeN/A
*-commutativeN/A
associate-/l*N/A
lower-fma.f64N/A
lower--.f64N/A
lower-/.f6488.1
Applied rewrites88.1%
if -0.0539999999999999994 < a < 1.7000000000000001e30Initial program 81.3%
Taylor expanded in z around inf
lower-+.f6473.6
Applied rewrites73.6%
Final simplification80.6%
(FPCore (x y z t a) :precision binary64 (if (or (<= z -2.7e+60) (not (<= z 7.2e-50))) (+ t x) (fma (/ y a) t x)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if ((z <= -2.7e+60) || !(z <= 7.2e-50)) {
tmp = t + x;
} else {
tmp = fma((y / a), t, x);
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if ((z <= -2.7e+60) || !(z <= 7.2e-50)) tmp = Float64(t + x); else tmp = fma(Float64(y / a), t, x); end return tmp end
code[x_, y_, z_, t_, a_] := If[Or[LessEqual[z, -2.7e+60], N[Not[LessEqual[z, 7.2e-50]], $MachinePrecision]], N[(t + x), $MachinePrecision], N[(N[(y / a), $MachinePrecision] * t + x), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -2.7 \cdot 10^{+60} \lor \neg \left(z \leq 7.2 \cdot 10^{-50}\right):\\
\;\;\;\;t + x\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y}{a}, t, x\right)\\
\end{array}
\end{array}
if z < -2.6999999999999999e60 or 7.19999999999999958e-50 < z Initial program 76.3%
Taylor expanded in z around inf
lower-+.f6480.0
Applied rewrites80.0%
if -2.6999999999999999e60 < z < 7.19999999999999958e-50Initial program 94.1%
Taylor expanded in z around 0
+-commutativeN/A
associate-/l*N/A
*-commutativeN/A
lower-fma.f64N/A
lower-/.f6475.9
Applied rewrites75.9%
Final simplification78.2%
(FPCore (x y z t a) :precision binary64 (if (or (<= z -2.7e+60) (not (<= z 3.7e-50))) (+ t x) (fma (/ t a) y x)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if ((z <= -2.7e+60) || !(z <= 3.7e-50)) {
tmp = t + x;
} else {
tmp = fma((t / a), y, x);
}
return tmp;
}
function code(x, y, z, t, a) tmp = 0.0 if ((z <= -2.7e+60) || !(z <= 3.7e-50)) tmp = Float64(t + x); else tmp = fma(Float64(t / a), y, x); end return tmp end
code[x_, y_, z_, t_, a_] := If[Or[LessEqual[z, -2.7e+60], N[Not[LessEqual[z, 3.7e-50]], $MachinePrecision]], N[(t + x), $MachinePrecision], N[(N[(t / a), $MachinePrecision] * y + x), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -2.7 \cdot 10^{+60} \lor \neg \left(z \leq 3.7 \cdot 10^{-50}\right):\\
\;\;\;\;t + x\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{t}{a}, y, x\right)\\
\end{array}
\end{array}
if z < -2.6999999999999999e60 or 3.7000000000000001e-50 < z Initial program 76.3%
Taylor expanded in z around inf
lower-+.f6480.0
Applied rewrites80.0%
if -2.6999999999999999e60 < z < 3.7000000000000001e-50Initial program 94.1%
Taylor expanded in y around 0
+-commutativeN/A
mul-1-negN/A
associate-/l*N/A
*-commutativeN/A
distribute-rgt-neg-inN/A
mul-1-negN/A
lower-fma.f64N/A
lower-/.f64N/A
lower--.f64N/A
mul-1-negN/A
lower-neg.f6460.4
Applied rewrites60.4%
Taylor expanded in z around 0
+-commutativeN/A
associate-*l/N/A
lower-fma.f64N/A
lower-/.f6475.0
Applied rewrites75.0%
Final simplification77.9%
(FPCore (x y z t a) :precision binary64 (if (<= t 1.55e+233) (+ t x) (* (/ y a) t)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if (t <= 1.55e+233) {
tmp = t + x;
} else {
tmp = (y / a) * t;
}
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 (t <= 1.55d+233) then
tmp = t + x
else
tmp = (y / a) * t
end if
code = tmp
end function
public static double code(double x, double y, double z, double t, double a) {
double tmp;
if (t <= 1.55e+233) {
tmp = t + x;
} else {
tmp = (y / a) * t;
}
return tmp;
}
def code(x, y, z, t, a): tmp = 0 if t <= 1.55e+233: tmp = t + x else: tmp = (y / a) * t return tmp
function code(x, y, z, t, a) tmp = 0.0 if (t <= 1.55e+233) tmp = Float64(t + x); else tmp = Float64(Float64(y / a) * t); end return tmp end
function tmp_2 = code(x, y, z, t, a) tmp = 0.0; if (t <= 1.55e+233) tmp = t + x; else tmp = (y / a) * t; end tmp_2 = tmp; end
code[x_, y_, z_, t_, a_] := If[LessEqual[t, 1.55e+233], N[(t + x), $MachinePrecision], N[(N[(y / a), $MachinePrecision] * t), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq 1.55 \cdot 10^{+233}:\\
\;\;\;\;t + x\\
\mathbf{else}:\\
\;\;\;\;\frac{y}{a} \cdot t\\
\end{array}
\end{array}
if t < 1.55000000000000008e233Initial program 84.3%
Taylor expanded in z around inf
lower-+.f6468.5
Applied rewrites68.5%
if 1.55000000000000008e233 < t Initial program 80.1%
Taylor expanded in y around inf
associate-/l*N/A
*-commutativeN/A
lower-*.f64N/A
lower-/.f64N/A
lower--.f6465.5
Applied rewrites65.5%
Taylor expanded in z around 0
Applied rewrites66.1%
(FPCore (x y z t a) :precision binary64 (if (<= t 1.55e+233) (+ t x) (* (/ t a) y)))
double code(double x, double y, double z, double t, double a) {
double tmp;
if (t <= 1.55e+233) {
tmp = t + x;
} else {
tmp = (t / a) * y;
}
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 (t <= 1.55d+233) then
tmp = t + x
else
tmp = (t / a) * y
end if
code = tmp
end function
public static double code(double x, double y, double z, double t, double a) {
double tmp;
if (t <= 1.55e+233) {
tmp = t + x;
} else {
tmp = (t / a) * y;
}
return tmp;
}
def code(x, y, z, t, a): tmp = 0 if t <= 1.55e+233: tmp = t + x else: tmp = (t / a) * y return tmp
function code(x, y, z, t, a) tmp = 0.0 if (t <= 1.55e+233) tmp = Float64(t + x); else tmp = Float64(Float64(t / a) * y); end return tmp end
function tmp_2 = code(x, y, z, t, a) tmp = 0.0; if (t <= 1.55e+233) tmp = t + x; else tmp = (t / a) * y; end tmp_2 = tmp; end
code[x_, y_, z_, t_, a_] := If[LessEqual[t, 1.55e+233], N[(t + x), $MachinePrecision], N[(N[(t / a), $MachinePrecision] * y), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;t \leq 1.55 \cdot 10^{+233}:\\
\;\;\;\;t + x\\
\mathbf{else}:\\
\;\;\;\;\frac{t}{a} \cdot y\\
\end{array}
\end{array}
if t < 1.55000000000000008e233Initial program 84.3%
Taylor expanded in z around inf
lower-+.f6468.5
Applied rewrites68.5%
if 1.55000000000000008e233 < t Initial program 80.1%
Taylor expanded in a around inf
+-commutativeN/A
*-commutativeN/A
associate-/l*N/A
lower-fma.f64N/A
lower--.f64N/A
lower-/.f6477.8
Applied rewrites77.8%
Taylor expanded in y around inf
Applied rewrites59.1%
Applied rewrites65.9%
(FPCore (x y z t a) :precision binary64 (+ t x))
double code(double x, double y, double z, double t, double a) {
return t + x;
}
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 = t + x
end function
public static double code(double x, double y, double z, double t, double a) {
return t + x;
}
def code(x, y, z, t, a): return t + x
function code(x, y, z, t, a) return Float64(t + x) end
function tmp = code(x, y, z, t, a) tmp = t + x; end
code[x_, y_, z_, t_, a_] := N[(t + x), $MachinePrecision]
\begin{array}{l}
\\
t + x
\end{array}
Initial program 84.1%
Taylor expanded in z around inf
lower-+.f6465.7
Applied rewrites65.7%
(FPCore (x y z t a)
:precision binary64
(let* ((t_1 (+ x (* (/ (- y z) (- a z)) t))))
(if (< t -1.0682974490174067e-39)
t_1
(if (< t 3.9110949887586375e-141) (+ x (/ (* (- y z) t) (- a z))) t_1))))
double code(double x, double y, double z, double t, double a) {
double t_1 = x + (((y - z) / (a - z)) * t);
double tmp;
if (t < -1.0682974490174067e-39) {
tmp = t_1;
} else if (t < 3.9110949887586375e-141) {
tmp = x + (((y - z) * t) / (a - z));
} else {
tmp = t_1;
}
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) :: t_1
real(8) :: tmp
t_1 = x + (((y - z) / (a - z)) * t)
if (t < (-1.0682974490174067d-39)) then
tmp = t_1
else if (t < 3.9110949887586375d-141) then
tmp = x + (((y - z) * t) / (a - z))
else
tmp = t_1
end if
code = tmp
end function
public static double code(double x, double y, double z, double t, double a) {
double t_1 = x + (((y - z) / (a - z)) * t);
double tmp;
if (t < -1.0682974490174067e-39) {
tmp = t_1;
} else if (t < 3.9110949887586375e-141) {
tmp = x + (((y - z) * t) / (a - z));
} else {
tmp = t_1;
}
return tmp;
}
def code(x, y, z, t, a): t_1 = x + (((y - z) / (a - z)) * t) tmp = 0 if t < -1.0682974490174067e-39: tmp = t_1 elif t < 3.9110949887586375e-141: tmp = x + (((y - z) * t) / (a - z)) else: tmp = t_1 return tmp
function code(x, y, z, t, a) t_1 = Float64(x + Float64(Float64(Float64(y - z) / Float64(a - z)) * t)) tmp = 0.0 if (t < -1.0682974490174067e-39) tmp = t_1; elseif (t < 3.9110949887586375e-141) tmp = Float64(x + Float64(Float64(Float64(y - z) * t) / Float64(a - z))); else tmp = t_1; end return tmp end
function tmp_2 = code(x, y, z, t, a) t_1 = x + (((y - z) / (a - z)) * t); tmp = 0.0; if (t < -1.0682974490174067e-39) tmp = t_1; elseif (t < 3.9110949887586375e-141) tmp = x + (((y - z) * t) / (a - z)); else tmp = t_1; end tmp_2 = tmp; end
code[x_, y_, z_, t_, a_] := Block[{t$95$1 = N[(x + N[(N[(N[(y - z), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision] * t), $MachinePrecision]), $MachinePrecision]}, If[Less[t, -1.0682974490174067e-39], t$95$1, If[Less[t, 3.9110949887586375e-141], N[(x + N[(N[(N[(y - z), $MachinePrecision] * t), $MachinePrecision] / N[(a - z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], t$95$1]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := x + \frac{y - z}{a - z} \cdot t\\
\mathbf{if}\;t < -1.0682974490174067 \cdot 10^{-39}:\\
\;\;\;\;t\_1\\
\mathbf{elif}\;t < 3.9110949887586375 \cdot 10^{-141}:\\
\;\;\;\;x + \frac{\left(y - z\right) \cdot t}{a - z}\\
\mathbf{else}:\\
\;\;\;\;t\_1\\
\end{array}
\end{array}
herbie shell --seed 2024329
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTick from plot-0.2.3.4, A"
:precision binary64
:alt
(! :herbie-platform default (if (< t -10682974490174067/10000000000000000000000000000000000000000000000000000000) (+ x (* (/ (- y z) (- a z)) t)) (if (< t 312887599100691/80000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000) (+ x (/ (* (- y z) t) (- a z))) (+ x (* (/ (- y z) (- a z)) t)))))
(+ x (/ (* (- y z) t) (- a z))))