?

Average Accuracy: 96.8% → 96.8%
Time: 10.9s
Precision: binary64
Cost: 576

?

\[\frac{x}{y} \cdot \left(z - t\right) + t \]
\[t + \frac{x}{y} \cdot \left(z - t\right) \]
(FPCore (x y z t) :precision binary64 (+ (* (/ x y) (- z t)) t))
(FPCore (x y z t) :precision binary64 (+ t (* (/ x y) (- z t))))
double code(double x, double y, double z, double t) {
	return ((x / y) * (z - t)) + t;
}
double code(double x, double y, double z, double t) {
	return t + ((x / y) * (z - 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 - t)) + t
end function
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 = t + ((x / y) * (z - t))
end function
public static double code(double x, double y, double z, double t) {
	return ((x / y) * (z - t)) + t;
}
public static double code(double x, double y, double z, double t) {
	return t + ((x / y) * (z - t));
}
def code(x, y, z, t):
	return ((x / y) * (z - t)) + t
def code(x, y, z, t):
	return t + ((x / y) * (z - t))
function code(x, y, z, t)
	return Float64(Float64(Float64(x / y) * Float64(z - t)) + t)
end
function code(x, y, z, t)
	return Float64(t + Float64(Float64(x / y) * Float64(z - t)))
end
function tmp = code(x, y, z, t)
	tmp = ((x / y) * (z - t)) + t;
end
function tmp = code(x, y, z, t)
	tmp = t + ((x / y) * (z - t));
end
code[x_, y_, z_, t_] := N[(N[(N[(x / y), $MachinePrecision] * N[(z - t), $MachinePrecision]), $MachinePrecision] + t), $MachinePrecision]
code[x_, y_, z_, t_] := N[(t + N[(N[(x / y), $MachinePrecision] * N[(z - t), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\frac{x}{y} \cdot \left(z - t\right) + t
t + \frac{x}{y} \cdot \left(z - t\right)

Error?

Try it out?

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original96.8%
Target96.3%
Herbie96.8%
\[\begin{array}{l} \mathbf{if}\;z < 2.759456554562692 \cdot 10^{-282}:\\ \;\;\;\;\frac{x}{y} \cdot \left(z - t\right) + t\\ \mathbf{elif}\;z < 2.326994450874436 \cdot 10^{-110}:\\ \;\;\;\;x \cdot \frac{z - t}{y} + t\\ \mathbf{else}:\\ \;\;\;\;\frac{x}{y} \cdot \left(z - t\right) + t\\ \end{array} \]

Derivation?

  1. Initial program 96.8%

    \[\frac{x}{y} \cdot \left(z - t\right) + t \]
  2. Final simplification96.8%

    \[\leadsto t + \frac{x}{y} \cdot \left(z - t\right) \]

Alternatives

Alternative 1
Accuracy64.2%
Cost2205
\[\begin{array}{l} t_1 := \frac{x}{y} \cdot \left(-t\right)\\ t_2 := \frac{x}{y} \cdot z\\ \mathbf{if}\;\frac{x}{y} \leq -5 \cdot 10^{+200}:\\ \;\;\;\;x \cdot \frac{z}{y}\\ \mathbf{elif}\;\frac{x}{y} \leq -2 \cdot 10^{+42}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\frac{x}{y} \leq -4 \cdot 10^{-55}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\frac{x}{y} \leq 10^{-98}:\\ \;\;\;\;t\\ \mathbf{elif}\;\frac{x}{y} \leq 2 \cdot 10^{+20}:\\ \;\;\;\;\frac{z}{\frac{y}{x}}\\ \mathbf{elif}\;\frac{x}{y} \leq 6 \cdot 10^{+88} \lor \neg \left(\frac{x}{y} \leq 5 \cdot 10^{+127}\right):\\ \;\;\;\;t_1\\ \mathbf{else}:\\ \;\;\;\;t_2\\ \end{array} \]
Alternative 2
Accuracy64.5%
Cost2204
\[\begin{array}{l} t_1 := \frac{x}{y} \cdot \left(-t\right)\\ t_2 := \frac{x}{y} \cdot z\\ \mathbf{if}\;\frac{x}{y} \leq -5 \cdot 10^{+200}:\\ \;\;\;\;x \cdot \frac{z}{y}\\ \mathbf{elif}\;\frac{x}{y} \leq -2 \cdot 10^{+42}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\frac{x}{y} \leq -4 \cdot 10^{-55}:\\ \;\;\;\;t_2\\ \mathbf{elif}\;\frac{x}{y} \leq 10^{-98}:\\ \;\;\;\;t\\ \mathbf{elif}\;\frac{x}{y} \leq 2 \cdot 10^{+20}:\\ \;\;\;\;\frac{z}{\frac{y}{x}}\\ \mathbf{elif}\;\frac{x}{y} \leq 6 \cdot 10^{+88}:\\ \;\;\;\;t_1\\ \mathbf{elif}\;\frac{x}{y} \leq 5 \cdot 10^{+127}:\\ \;\;\;\;t_2\\ \mathbf{else}:\\ \;\;\;\;\frac{t}{y} \cdot \left(-x\right)\\ \end{array} \]
Alternative 3
Accuracy77.3%
Cost969
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -4 \cdot 10^{-55} \lor \neg \left(\frac{x}{y} \leq 5 \cdot 10^{-27}\right):\\ \;\;\;\;x \cdot \frac{z - t}{y}\\ \mathbf{else}:\\ \;\;\;\;t\\ \end{array} \]
Alternative 4
Accuracy88.7%
Cost969
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -2 \cdot 10^{-46} \lor \neg \left(\frac{x}{y} \leq 4 \cdot 10^{-17}\right):\\ \;\;\;\;x \cdot \frac{z - t}{y}\\ \mathbf{else}:\\ \;\;\;\;t + \frac{x \cdot z}{y}\\ \end{array} \]
Alternative 5
Accuracy87.9%
Cost968
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -2 \cdot 10^{-46}:\\ \;\;\;\;x \cdot \frac{z - t}{y}\\ \mathbf{elif}\;\frac{x}{y} \leq 5 \cdot 10^{-27}:\\ \;\;\;\;t + \frac{x \cdot z}{y}\\ \mathbf{else}:\\ \;\;\;\;\frac{x \cdot \left(z - t\right)}{y}\\ \end{array} \]
Alternative 6
Accuracy87.9%
Cost968
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -2 \cdot 10^{-46}:\\ \;\;\;\;x \cdot \left(\frac{z}{y} - \frac{t}{y}\right)\\ \mathbf{elif}\;\frac{x}{y} \leq 5 \cdot 10^{-27}:\\ \;\;\;\;t + \frac{x \cdot z}{y}\\ \mathbf{else}:\\ \;\;\;\;\frac{x \cdot \left(z - t\right)}{y}\\ \end{array} \]
Alternative 7
Accuracy63.8%
Cost841
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -4 \cdot 10^{-55} \lor \neg \left(\frac{x}{y} \leq 10^{-98}\right):\\ \;\;\;\;\frac{x}{y} \cdot z\\ \mathbf{else}:\\ \;\;\;\;t\\ \end{array} \]
Alternative 8
Accuracy63.8%
Cost840
\[\begin{array}{l} \mathbf{if}\;\frac{x}{y} \leq -4 \cdot 10^{-55}:\\ \;\;\;\;\frac{x}{y} \cdot z\\ \mathbf{elif}\;\frac{x}{y} \leq 10^{-98}:\\ \;\;\;\;t\\ \mathbf{else}:\\ \;\;\;\;\frac{z}{\frac{y}{x}}\\ \end{array} \]
Alternative 9
Accuracy50.7%
Cost64
\[t \]

Error

Reproduce?

herbie shell --seed 2023130 
(FPCore (x y z t)
  :name "Numeric.Signal.Multichannel:$cget from hsignal-0.2.7.1"
  :precision binary64

  :herbie-target
  (if (< z 2.759456554562692e-282) (+ (* (/ x y) (- z t)) t) (if (< z 2.326994450874436e-110) (+ (* x (/ (- z t) y)) t) (+ (* (/ x y) (- z t)) t)))

  (+ (* (/ x y) (- z t)) t))