Average Error: 14.6 → 1.1
Time: 14.0s
Precision: binary64
\[\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\]
\[\left(\frac{\sqrt[3]{x}}{z} \cdot \left(\sqrt[3]{x} \cdot \left(\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}\right)\right)\right) \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]
\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}
\left(\frac{\sqrt[3]{x}}{z} \cdot \left(\sqrt[3]{x} \cdot \left(\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}\right)\right)\right) \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}
(FPCore (x y z) :precision binary64 (/ (* x y) (* (* z z) (+ z 1.0))))
(FPCore (x y z)
 :precision binary64
 (*
  (*
   (/ (cbrt x) z)
   (* (cbrt x) (* (cbrt (/ y (+ z 1.0))) (cbrt (/ y (+ z 1.0))))))
  (/ (cbrt x) (/ z (cbrt (/ y (+ z 1.0)))))))
double code(double x, double y, double z) {
	return (x * y) / ((z * z) * (z + 1.0));
}
double code(double x, double y, double z) {
	return ((cbrt(x) / z) * (cbrt(x) * (cbrt(y / (z + 1.0)) * cbrt(y / (z + 1.0))))) * (cbrt(x) / (z / cbrt(y / (z + 1.0))));
}

Error

Bits error versus x

Bits error versus y

Bits error versus z

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original14.6
Target3.9
Herbie1.1
\[\begin{array}{l} \mathbf{if}\;z < 249.6182814532307:\\ \;\;\;\;\frac{y \cdot \frac{x}{z}}{z + z \cdot z}\\ \mathbf{else}:\\ \;\;\;\;\frac{\frac{\frac{y}{z}}{1 + z} \cdot x}{z}\\ \end{array}\]

Derivation

  1. Initial program 14.6

    \[\frac{x \cdot y}{\left(z \cdot z\right) \cdot \left(z + 1\right)}\]
  2. Using strategy rm
  3. Applied associate-/l*_binary64_923013.6

    \[\leadsto \color{blue}{\frac{x}{\frac{\left(z \cdot z\right) \cdot \left(z + 1\right)}{y}}}\]
  4. Simplified11.9

    \[\leadsto \frac{x}{\color{blue}{\frac{z \cdot z}{\frac{y}{z + 1}}}}\]
  5. Using strategy rm
  6. Applied add-cube-cbrt_binary64_932012.3

    \[\leadsto \frac{x}{\frac{z \cdot z}{\color{blue}{\left(\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}\right) \cdot \sqrt[3]{\frac{y}{z + 1}}}}}\]
  7. Applied times-frac_binary64_92918.3

    \[\leadsto \frac{x}{\color{blue}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}} \cdot \frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}}\]
  8. Applied add-cube-cbrt_binary64_93208.5

    \[\leadsto \frac{\color{blue}{\left(\sqrt[3]{x} \cdot \sqrt[3]{x}\right) \cdot \sqrt[3]{x}}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}} \cdot \frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]
  9. Applied times-frac_binary64_92911.4

    \[\leadsto \color{blue}{\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}}} \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}}\]
  10. Using strategy rm
  11. Applied div-inv_binary64_92821.4

    \[\leadsto \frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\color{blue}{z \cdot \frac{1}{\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}}}} \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]
  12. Applied times-frac_binary64_92911.2

    \[\leadsto \color{blue}{\left(\frac{\sqrt[3]{x}}{z} \cdot \frac{\sqrt[3]{x}}{\frac{1}{\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}}}\right)} \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]
  13. Simplified1.1

    \[\leadsto \left(\frac{\sqrt[3]{x}}{z} \cdot \color{blue}{\left(\left(\sqrt[3]{\frac{y}{1 + z}} \cdot \sqrt[3]{\frac{y}{1 + z}}\right) \cdot \sqrt[3]{x}\right)}\right) \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]
  14. Final simplification1.1

    \[\leadsto \left(\frac{\sqrt[3]{x}}{z} \cdot \left(\sqrt[3]{x} \cdot \left(\sqrt[3]{\frac{y}{z + 1}} \cdot \sqrt[3]{\frac{y}{z + 1}}\right)\right)\right) \cdot \frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\frac{y}{z + 1}}}}\]

Reproduce

herbie shell --seed 2021043 
(FPCore (x y z)
  :name "Statistics.Distribution.Beta:$cvariance from math-functions-0.1.5.2"
  :precision binary64

  :herbie-target
  (if (< z 249.6182814532307) (/ (* y (/ x z)) (+ z (* z z))) (/ (* (/ (/ y z) (+ 1.0 z)) x) z))

  (/ (* x y) (* (* z z) (+ z 1.0))))