?

Average Accuracy: 99.8% → 99.8%
Time: 7.2s
Precision: binary64
Cost: 448

?

\[ \begin{array}{c}[x, y] = \mathsf{sort}([x, y])\\ \end{array} \]
\[\left(x \cdot 3\right) \cdot y - z \]
\[x \cdot \left(3 \cdot y\right) - z \]
(FPCore (x y z) :precision binary64 (- (* (* x 3.0) y) z))
(FPCore (x y z) :precision binary64 (- (* x (* 3.0 y)) z))
double code(double x, double y, double z) {
	return ((x * 3.0) * y) - z;
}
double code(double x, double y, double z) {
	return (x * (3.0 * y)) - z;
}
real(8) function code(x, y, z)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    code = ((x * 3.0d0) * y) - z
end function
real(8) function code(x, y, z)
    real(8), intent (in) :: x
    real(8), intent (in) :: y
    real(8), intent (in) :: z
    code = (x * (3.0d0 * y)) - z
end function
public static double code(double x, double y, double z) {
	return ((x * 3.0) * y) - z;
}
public static double code(double x, double y, double z) {
	return (x * (3.0 * y)) - z;
}
def code(x, y, z):
	return ((x * 3.0) * y) - z
def code(x, y, z):
	return (x * (3.0 * y)) - z
function code(x, y, z)
	return Float64(Float64(Float64(x * 3.0) * y) - z)
end
function code(x, y, z)
	return Float64(Float64(x * Float64(3.0 * y)) - z)
end
function tmp = code(x, y, z)
	tmp = ((x * 3.0) * y) - z;
end
function tmp = code(x, y, z)
	tmp = (x * (3.0 * y)) - z;
end
code[x_, y_, z_] := N[(N[(N[(x * 3.0), $MachinePrecision] * y), $MachinePrecision] - z), $MachinePrecision]
code[x_, y_, z_] := N[(N[(x * N[(3.0 * y), $MachinePrecision]), $MachinePrecision] - z), $MachinePrecision]
\left(x \cdot 3\right) \cdot y - z
x \cdot \left(3 \cdot y\right) - z

Error?

Try it out?

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original99.8%
Target99.8%
Herbie99.8%
\[x \cdot \left(3 \cdot y\right) - z \]

Derivation?

  1. Initial program 99.8%

    \[\left(x \cdot 3\right) \cdot y - z \]
  2. Simplified99.8%

    \[\leadsto \color{blue}{x \cdot \left(3 \cdot y\right) - z} \]
    Proof

    [Start]99.8

    \[ \left(x \cdot 3\right) \cdot y - z \]

    associate-*l* [=>]99.8

    \[ \color{blue}{x \cdot \left(3 \cdot y\right)} - z \]
  3. Final simplification99.8%

    \[\leadsto x \cdot \left(3 \cdot y\right) - z \]

Alternatives

Alternative 1
Accuracy74.1%
Cost849
\[\begin{array}{l} \mathbf{if}\;z \leq -2.6 \cdot 10^{-96}:\\ \;\;\;\;-z\\ \mathbf{elif}\;z \leq 2.2 \cdot 10^{-49} \lor \neg \left(z \leq 32000000000000\right) \land z \leq 1.72 \cdot 10^{+31}:\\ \;\;\;\;3 \cdot \left(x \cdot y\right)\\ \mathbf{else}:\\ \;\;\;\;-z\\ \end{array} \]
Alternative 2
Accuracy99.8%
Cost448
\[3 \cdot \left(x \cdot y\right) - z \]
Alternative 3
Accuracy57.0%
Cost128
\[-z \]
Alternative 4
Accuracy2.3%
Cost64
\[z \]

Error

Reproduce?

herbie shell --seed 2023135 
(FPCore (x y z)
  :name "Diagrams.Solve.Polynomial:cubForm  from diagrams-solve-0.1, B"
  :precision binary64

  :herbie-target
  (- (* x (* 3.0 y)) z)

  (- (* (* x 3.0) y) z))