
(FPCore (x y z t) :precision binary64 (- x (/ (* (* y 2.0) z) (- (* (* z 2.0) z) (* y t)))))
double code(double x, double y, double z, double t) {
return x - (((y * 2.0) * z) / (((z * 2.0) * 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 * 2.0d0) * z) / (((z * 2.0d0) * z) - (y * t)))
end function
public static double code(double x, double y, double z, double t) {
return x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t)));
}
def code(x, y, z, t): return x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t)))
function code(x, y, z, t) return Float64(x - Float64(Float64(Float64(y * 2.0) * z) / Float64(Float64(Float64(z * 2.0) * z) - Float64(y * t)))) end
function tmp = code(x, y, z, t) tmp = x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t))); end
code[x_, y_, z_, t_] := N[(x - N[(N[(N[(y * 2.0), $MachinePrecision] * z), $MachinePrecision] / N[(N[(N[(z * 2.0), $MachinePrecision] * z), $MachinePrecision] - N[(y * t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
x - \frac{\left(y \cdot 2\right) \cdot z}{\left(z \cdot 2\right) \cdot z - y \cdot t}
\end{array}
Sampling outcomes in binary64 precision:
Herbie found 8 alternatives:
| Alternative | Accuracy | Speedup |
|---|
(FPCore (x y z t) :precision binary64 (- x (/ (* (* y 2.0) z) (- (* (* z 2.0) z) (* y t)))))
double code(double x, double y, double z, double t) {
return x - (((y * 2.0) * z) / (((z * 2.0) * 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 * 2.0d0) * z) / (((z * 2.0d0) * z) - (y * t)))
end function
public static double code(double x, double y, double z, double t) {
return x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t)));
}
def code(x, y, z, t): return x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t)))
function code(x, y, z, t) return Float64(x - Float64(Float64(Float64(y * 2.0) * z) / Float64(Float64(Float64(z * 2.0) * z) - Float64(y * t)))) end
function tmp = code(x, y, z, t) tmp = x - (((y * 2.0) * z) / (((z * 2.0) * z) - (y * t))); end
code[x_, y_, z_, t_] := N[(x - N[(N[(N[(y * 2.0), $MachinePrecision] * z), $MachinePrecision] / N[(N[(N[(z * 2.0), $MachinePrecision] * z), $MachinePrecision] - N[(y * t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
x - \frac{\left(y \cdot 2\right) \cdot z}{\left(z \cdot 2\right) \cdot z - y \cdot t}
\end{array}
(FPCore (x y z t) :precision binary64 (fma (/ y (+ (* z -2.0) (/ y (/ z t)))) 2.0 x))
double code(double x, double y, double z, double t) {
return fma((y / ((z * -2.0) + (y / (z / t)))), 2.0, x);
}
function code(x, y, z, t) return fma(Float64(y / Float64(Float64(z * -2.0) + Float64(y / Float64(z / t)))), 2.0, x) end
code[x_, y_, z_, t_] := N[(N[(y / N[(N[(z * -2.0), $MachinePrecision] + N[(y / N[(z / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision] * 2.0 + x), $MachinePrecision]
\begin{array}{l}
\\
\mathsf{fma}\left(\frac{y}{z \cdot -2 + \frac{y}{\frac{z}{t}}}, 2, x\right)
\end{array}
Initial program 86.9%
Simplified98.9%
Final simplification98.9%
(FPCore (x y z t)
:precision binary64
(let* ((t_1 (- (* z (* z 2.0)) (* y t))))
(if (<= (- x (/ (* z (* y 2.0)) t_1)) 5e+89)
(- x (/ (* y 2.0) (/ t_1 z)))
(- x (/ (* y 2.0) (- (* z 2.0) (* t (/ y z))))))))
double code(double x, double y, double z, double t) {
double t_1 = (z * (z * 2.0)) - (y * t);
double tmp;
if ((x - ((z * (y * 2.0)) / t_1)) <= 5e+89) {
tmp = x - ((y * 2.0) / (t_1 / z));
} else {
tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z))));
}
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) :: t_1
real(8) :: tmp
t_1 = (z * (z * 2.0d0)) - (y * t)
if ((x - ((z * (y * 2.0d0)) / t_1)) <= 5d+89) then
tmp = x - ((y * 2.0d0) / (t_1 / z))
else
tmp = x - ((y * 2.0d0) / ((z * 2.0d0) - (t * (y / z))))
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double t_1 = (z * (z * 2.0)) - (y * t);
double tmp;
if ((x - ((z * (y * 2.0)) / t_1)) <= 5e+89) {
tmp = x - ((y * 2.0) / (t_1 / z));
} else {
tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z))));
}
return tmp;
}
def code(x, y, z, t): t_1 = (z * (z * 2.0)) - (y * t) tmp = 0 if (x - ((z * (y * 2.0)) / t_1)) <= 5e+89: tmp = x - ((y * 2.0) / (t_1 / z)) else: tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z)))) return tmp
function code(x, y, z, t) t_1 = Float64(Float64(z * Float64(z * 2.0)) - Float64(y * t)) tmp = 0.0 if (Float64(x - Float64(Float64(z * Float64(y * 2.0)) / t_1)) <= 5e+89) tmp = Float64(x - Float64(Float64(y * 2.0) / Float64(t_1 / z))); else tmp = Float64(x - Float64(Float64(y * 2.0) / Float64(Float64(z * 2.0) - Float64(t * Float64(y / z))))); end return tmp end
function tmp_2 = code(x, y, z, t) t_1 = (z * (z * 2.0)) - (y * t); tmp = 0.0; if ((x - ((z * (y * 2.0)) / t_1)) <= 5e+89) tmp = x - ((y * 2.0) / (t_1 / z)); else tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z)))); end tmp_2 = tmp; end
code[x_, y_, z_, t_] := Block[{t$95$1 = N[(N[(z * N[(z * 2.0), $MachinePrecision]), $MachinePrecision] - N[(y * t), $MachinePrecision]), $MachinePrecision]}, If[LessEqual[N[(x - N[(N[(z * N[(y * 2.0), $MachinePrecision]), $MachinePrecision] / t$95$1), $MachinePrecision]), $MachinePrecision], 5e+89], N[(x - N[(N[(y * 2.0), $MachinePrecision] / N[(t$95$1 / z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(x - N[(N[(y * 2.0), $MachinePrecision] / N[(N[(z * 2.0), $MachinePrecision] - N[(t * N[(y / z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]]
\begin{array}{l}
\\
\begin{array}{l}
t_1 := z \cdot \left(z \cdot 2\right) - y \cdot t\\
\mathbf{if}\;x - \frac{z \cdot \left(y \cdot 2\right)}{t\_1} \leq 5 \cdot 10^{+89}:\\
\;\;\;\;x - \frac{y \cdot 2}{\frac{t\_1}{z}}\\
\mathbf{else}:\\
\;\;\;\;x - \frac{y \cdot 2}{z \cdot 2 - t \cdot \frac{y}{z}}\\
\end{array}
\end{array}
if (-.f64 x (/.f64 (*.f64 (*.f64 y 2) z) (-.f64 (*.f64 (*.f64 z 2) z) (*.f64 y t)))) < 4.99999999999999983e89Initial program 95.9%
associate-/l*97.7%
associate-*l*97.7%
Simplified97.7%
if 4.99999999999999983e89 < (-.f64 x (/.f64 (*.f64 (*.f64 y 2) z) (-.f64 (*.f64 (*.f64 z 2) z) (*.f64 y t)))) Initial program 64.6%
associate-/l*82.7%
associate-*l*82.7%
Simplified82.7%
Taylor expanded in z around 0 96.6%
+-commutative96.6%
mul-1-neg96.6%
*-commutative96.6%
associate-*l/100.0%
unsub-neg100.0%
*-commutative100.0%
*-commutative100.0%
Simplified100.0%
Final simplification98.3%
(FPCore (x y z t) :precision binary64 (if (or (<= z -3.8e-46) (not (<= z 9e-135))) (- x (/ (* y 2.0) (- (* z 2.0) (* t (/ y z))))) (- x (* -2.0 (/ z t)))))
double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -3.8e-46) || !(z <= 9e-135)) {
tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z))));
} else {
tmp = x - (-2.0 * (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 ((z <= (-3.8d-46)) .or. (.not. (z <= 9d-135))) then
tmp = x - ((y * 2.0d0) / ((z * 2.0d0) - (t * (y / z))))
else
tmp = x - ((-2.0d0) * (z / t))
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -3.8e-46) || !(z <= 9e-135)) {
tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z))));
} else {
tmp = x - (-2.0 * (z / t));
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if (z <= -3.8e-46) or not (z <= 9e-135): tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z)))) else: tmp = x - (-2.0 * (z / t)) return tmp
function code(x, y, z, t) tmp = 0.0 if ((z <= -3.8e-46) || !(z <= 9e-135)) tmp = Float64(x - Float64(Float64(y * 2.0) / Float64(Float64(z * 2.0) - Float64(t * Float64(y / z))))); else tmp = Float64(x - Float64(-2.0 * Float64(z / t))); end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if ((z <= -3.8e-46) || ~((z <= 9e-135))) tmp = x - ((y * 2.0) / ((z * 2.0) - (t * (y / z)))); else tmp = x - (-2.0 * (z / t)); end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[Or[LessEqual[z, -3.8e-46], N[Not[LessEqual[z, 9e-135]], $MachinePrecision]], N[(x - N[(N[(y * 2.0), $MachinePrecision] / N[(N[(z * 2.0), $MachinePrecision] - N[(t * N[(y / z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision], N[(x - N[(-2.0 * N[(z / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -3.8 \cdot 10^{-46} \lor \neg \left(z \leq 9 \cdot 10^{-135}\right):\\
\;\;\;\;x - \frac{y \cdot 2}{z \cdot 2 - t \cdot \frac{y}{z}}\\
\mathbf{else}:\\
\;\;\;\;x - -2 \cdot \frac{z}{t}\\
\end{array}
\end{array}
if z < -3.7999999999999997e-46 or 8.99999999999999975e-135 < z Initial program 80.1%
associate-/l*91.4%
associate-*l*91.4%
Simplified91.4%
Taylor expanded in z around 0 98.3%
+-commutative98.3%
mul-1-neg98.3%
*-commutative98.3%
associate-*l/99.3%
unsub-neg99.3%
*-commutative99.3%
*-commutative99.3%
Simplified99.3%
if -3.7999999999999997e-46 < z < 8.99999999999999975e-135Initial program 96.9%
associate-/l*96.3%
associate-*l*96.3%
Simplified96.3%
Taylor expanded in y around inf 98.2%
*-commutative98.2%
Simplified98.2%
Final simplification98.8%
(FPCore (x y z t) :precision binary64 (if (or (<= z -15000.0) (not (<= z 0.00062))) (- x (/ y z)) (+ x (* z (/ 2.0 t)))))
double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -15000.0) || !(z <= 0.00062)) {
tmp = x - (y / z);
} else {
tmp = x + (z * (2.0 / 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 ((z <= (-15000.0d0)) .or. (.not. (z <= 0.00062d0))) then
tmp = x - (y / z)
else
tmp = x + (z * (2.0d0 / t))
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -15000.0) || !(z <= 0.00062)) {
tmp = x - (y / z);
} else {
tmp = x + (z * (2.0 / t));
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if (z <= -15000.0) or not (z <= 0.00062): tmp = x - (y / z) else: tmp = x + (z * (2.0 / t)) return tmp
function code(x, y, z, t) tmp = 0.0 if ((z <= -15000.0) || !(z <= 0.00062)) tmp = Float64(x - Float64(y / z)); else tmp = Float64(x + Float64(z * Float64(2.0 / t))); end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if ((z <= -15000.0) || ~((z <= 0.00062))) tmp = x - (y / z); else tmp = x + (z * (2.0 / t)); end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[Or[LessEqual[z, -15000.0], N[Not[LessEqual[z, 0.00062]], $MachinePrecision]], N[(x - N[(y / z), $MachinePrecision]), $MachinePrecision], N[(x + N[(z * N[(2.0 / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -15000 \lor \neg \left(z \leq 0.00062\right):\\
\;\;\;\;x - \frac{y}{z}\\
\mathbf{else}:\\
\;\;\;\;x + z \cdot \frac{2}{t}\\
\end{array}
\end{array}
if z < -15000 or 6.2e-4 < z Initial program 74.2%
sub-neg74.2%
associate-/l*89.0%
distribute-neg-frac89.0%
distribute-lft-neg-out89.0%
associate-/r/88.9%
distribute-lft-neg-out88.9%
distribute-rgt-neg-in88.9%
metadata-eval88.9%
*-commutative88.9%
associate-*l*88.9%
fma-neg88.9%
Simplified88.9%
Taylor expanded in y around 0 93.5%
mul-1-neg93.5%
sub-neg93.5%
Simplified93.5%
if -15000 < z < 6.2e-4Initial program 97.7%
sub-neg97.7%
associate-/l*97.1%
distribute-neg-frac97.1%
distribute-lft-neg-out97.1%
associate-/r/99.1%
distribute-lft-neg-out99.1%
distribute-rgt-neg-in99.1%
metadata-eval99.1%
*-commutative99.1%
associate-*l*99.1%
fma-neg99.1%
Simplified99.1%
Taylor expanded in y around inf 93.9%
Final simplification93.7%
(FPCore (x y z t) :precision binary64 (if (or (<= z -14000.0) (not (<= z 7e-6))) (- x (/ y z)) (- x (* -2.0 (/ z t)))))
double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -14000.0) || !(z <= 7e-6)) {
tmp = x - (y / z);
} else {
tmp = x - (-2.0 * (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 ((z <= (-14000.0d0)) .or. (.not. (z <= 7d-6))) then
tmp = x - (y / z)
else
tmp = x - ((-2.0d0) * (z / t))
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -14000.0) || !(z <= 7e-6)) {
tmp = x - (y / z);
} else {
tmp = x - (-2.0 * (z / t));
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if (z <= -14000.0) or not (z <= 7e-6): tmp = x - (y / z) else: tmp = x - (-2.0 * (z / t)) return tmp
function code(x, y, z, t) tmp = 0.0 if ((z <= -14000.0) || !(z <= 7e-6)) tmp = Float64(x - Float64(y / z)); else tmp = Float64(x - Float64(-2.0 * Float64(z / t))); end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if ((z <= -14000.0) || ~((z <= 7e-6))) tmp = x - (y / z); else tmp = x - (-2.0 * (z / t)); end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[Or[LessEqual[z, -14000.0], N[Not[LessEqual[z, 7e-6]], $MachinePrecision]], N[(x - N[(y / z), $MachinePrecision]), $MachinePrecision], N[(x - N[(-2.0 * N[(z / t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -14000 \lor \neg \left(z \leq 7 \cdot 10^{-6}\right):\\
\;\;\;\;x - \frac{y}{z}\\
\mathbf{else}:\\
\;\;\;\;x - -2 \cdot \frac{z}{t}\\
\end{array}
\end{array}
if z < -14000 or 6.99999999999999989e-6 < z Initial program 74.2%
sub-neg74.2%
associate-/l*89.0%
distribute-neg-frac89.0%
distribute-lft-neg-out89.0%
associate-/r/88.9%
distribute-lft-neg-out88.9%
distribute-rgt-neg-in88.9%
metadata-eval88.9%
*-commutative88.9%
associate-*l*88.9%
fma-neg88.9%
Simplified88.9%
Taylor expanded in y around 0 93.5%
mul-1-neg93.5%
sub-neg93.5%
Simplified93.5%
if -14000 < z < 6.99999999999999989e-6Initial program 97.7%
associate-/l*97.1%
associate-*l*97.1%
Simplified97.1%
Taylor expanded in y around inf 94.0%
*-commutative94.0%
Simplified94.0%
Final simplification93.8%
(FPCore (x y z t) :precision binary64 (if (or (<= z -4000.0) (not (<= z 1.55))) (- x (/ y z)) x))
double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -4000.0) || !(z <= 1.55)) {
tmp = x - (y / z);
} else {
tmp = x;
}
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 ((z <= (-4000.0d0)) .or. (.not. (z <= 1.55d0))) then
tmp = x - (y / z)
else
tmp = x
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if ((z <= -4000.0) || !(z <= 1.55)) {
tmp = x - (y / z);
} else {
tmp = x;
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if (z <= -4000.0) or not (z <= 1.55): tmp = x - (y / z) else: tmp = x return tmp
function code(x, y, z, t) tmp = 0.0 if ((z <= -4000.0) || !(z <= 1.55)) tmp = Float64(x - Float64(y / z)); else tmp = x; end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if ((z <= -4000.0) || ~((z <= 1.55))) tmp = x - (y / z); else tmp = x; end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[Or[LessEqual[z, -4000.0], N[Not[LessEqual[z, 1.55]], $MachinePrecision]], N[(x - N[(y / z), $MachinePrecision]), $MachinePrecision], x]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;z \leq -4000 \lor \neg \left(z \leq 1.55\right):\\
\;\;\;\;x - \frac{y}{z}\\
\mathbf{else}:\\
\;\;\;\;x\\
\end{array}
\end{array}
if z < -4e3 or 1.55000000000000004 < z Initial program 74.2%
sub-neg74.2%
associate-/l*89.0%
distribute-neg-frac89.0%
distribute-lft-neg-out89.0%
associate-/r/88.9%
distribute-lft-neg-out88.9%
distribute-rgt-neg-in88.9%
metadata-eval88.9%
*-commutative88.9%
associate-*l*88.9%
fma-neg88.9%
Simplified88.9%
Taylor expanded in y around 0 93.5%
mul-1-neg93.5%
sub-neg93.5%
Simplified93.5%
if -4e3 < z < 1.55000000000000004Initial program 97.7%
sub-neg97.7%
associate-/l*97.1%
distribute-neg-frac97.1%
distribute-lft-neg-out97.1%
associate-/r/99.1%
distribute-lft-neg-out99.1%
distribute-rgt-neg-in99.1%
metadata-eval99.1%
*-commutative99.1%
associate-*l*99.1%
fma-neg99.1%
Simplified99.1%
Taylor expanded in x around inf 77.4%
Final simplification84.8%
(FPCore (x y z t) :precision binary64 (if (<= x -4e-227) x (if (<= x 9e-295) (* (/ z t) 2.0) x)))
double code(double x, double y, double z, double t) {
double tmp;
if (x <= -4e-227) {
tmp = x;
} else if (x <= 9e-295) {
tmp = (z / t) * 2.0;
} else {
tmp = x;
}
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 (x <= (-4d-227)) then
tmp = x
else if (x <= 9d-295) then
tmp = (z / t) * 2.0d0
else
tmp = x
end if
code = tmp
end function
public static double code(double x, double y, double z, double t) {
double tmp;
if (x <= -4e-227) {
tmp = x;
} else if (x <= 9e-295) {
tmp = (z / t) * 2.0;
} else {
tmp = x;
}
return tmp;
}
def code(x, y, z, t): tmp = 0 if x <= -4e-227: tmp = x elif x <= 9e-295: tmp = (z / t) * 2.0 else: tmp = x return tmp
function code(x, y, z, t) tmp = 0.0 if (x <= -4e-227) tmp = x; elseif (x <= 9e-295) tmp = Float64(Float64(z / t) * 2.0); else tmp = x; end return tmp end
function tmp_2 = code(x, y, z, t) tmp = 0.0; if (x <= -4e-227) tmp = x; elseif (x <= 9e-295) tmp = (z / t) * 2.0; else tmp = x; end tmp_2 = tmp; end
code[x_, y_, z_, t_] := If[LessEqual[x, -4e-227], x, If[LessEqual[x, 9e-295], N[(N[(z / t), $MachinePrecision] * 2.0), $MachinePrecision], x]]
\begin{array}{l}
\\
\begin{array}{l}
\mathbf{if}\;x \leq -4 \cdot 10^{-227}:\\
\;\;\;\;x\\
\mathbf{elif}\;x \leq 9 \cdot 10^{-295}:\\
\;\;\;\;\frac{z}{t} \cdot 2\\
\mathbf{else}:\\
\;\;\;\;x\\
\end{array}
\end{array}
if x < -3.99999999999999978e-227 or 9.0000000000000003e-295 < x Initial program 87.0%
sub-neg87.0%
associate-/l*93.7%
distribute-neg-frac93.7%
distribute-lft-neg-out93.7%
associate-/r/94.5%
distribute-lft-neg-out94.5%
distribute-rgt-neg-in94.5%
metadata-eval94.5%
*-commutative94.5%
associate-*l*94.5%
fma-neg94.5%
Simplified94.5%
Taylor expanded in x around inf 85.2%
if -3.99999999999999978e-227 < x < 9.0000000000000003e-295Initial program 86.2%
Simplified96.2%
Taylor expanded in x around 0 80.7%
Taylor expanded in y around inf 53.7%
Final simplification82.2%
(FPCore (x y z t) :precision binary64 x)
double code(double x, double y, double z, double t) {
return x;
}
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
end function
public static double code(double x, double y, double z, double t) {
return x;
}
def code(x, y, z, t): return x
function code(x, y, z, t) return x end
function tmp = code(x, y, z, t) tmp = x; end
code[x_, y_, z_, t_] := x
\begin{array}{l}
\\
x
\end{array}
Initial program 86.9%
sub-neg86.9%
associate-/l*93.4%
distribute-neg-frac93.4%
distribute-lft-neg-out93.4%
associate-/r/94.5%
distribute-lft-neg-out94.5%
distribute-rgt-neg-in94.5%
metadata-eval94.5%
*-commutative94.5%
associate-*l*94.5%
fma-neg94.5%
Simplified94.5%
Taylor expanded in x around inf 79.0%
Final simplification79.0%
(FPCore (x y z t) :precision binary64 (- x (/ 1.0 (- (/ z y) (/ (/ t 2.0) z)))))
double code(double x, double y, double z, double t) {
return x - (1.0 / ((z / y) - ((t / 2.0) / z)));
}
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 - (1.0d0 / ((z / y) - ((t / 2.0d0) / z)))
end function
public static double code(double x, double y, double z, double t) {
return x - (1.0 / ((z / y) - ((t / 2.0) / z)));
}
def code(x, y, z, t): return x - (1.0 / ((z / y) - ((t / 2.0) / z)))
function code(x, y, z, t) return Float64(x - Float64(1.0 / Float64(Float64(z / y) - Float64(Float64(t / 2.0) / z)))) end
function tmp = code(x, y, z, t) tmp = x - (1.0 / ((z / y) - ((t / 2.0) / z))); end
code[x_, y_, z_, t_] := N[(x - N[(1.0 / N[(N[(z / y), $MachinePrecision] - N[(N[(t / 2.0), $MachinePrecision] / z), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\begin{array}{l}
\\
x - \frac{1}{\frac{z}{y} - \frac{\frac{t}{2}}{z}}
\end{array}
herbie shell --seed 2024027
(FPCore (x y z t)
:name "Numeric.AD.Rank1.Halley:findZero from ad-4.2.4"
:precision binary64
:herbie-target
(- x (/ 1.0 (- (/ z y) (/ (/ t 2.0) z))))
(- x (/ (* (* y 2.0) z) (- (* (* z 2.0) z) (* y t)))))