Average Error: 0.1 → 0.1
Time: 24.5s
Precision: 64
\[\left(\left(x \cdot \log y - y\right) - z\right) + \log t\]
\[\left(\left(\left(\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x + \log \left({\left(\frac{1}{y}\right)}^{\frac{-1}{3}}\right) \cdot x\right) - y\right) - z\right) + \log t\]
\left(\left(x \cdot \log y - y\right) - z\right) + \log t
\left(\left(\left(\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x + \log \left({\left(\frac{1}{y}\right)}^{\frac{-1}{3}}\right) \cdot x\right) - y\right) - z\right) + \log t
double f(double x, double y, double z, double t) {
        double r60792 = x;
        double r60793 = y;
        double r60794 = log(r60793);
        double r60795 = r60792 * r60794;
        double r60796 = r60795 - r60793;
        double r60797 = z;
        double r60798 = r60796 - r60797;
        double r60799 = t;
        double r60800 = log(r60799);
        double r60801 = r60798 + r60800;
        return r60801;
}

double f(double x, double y, double z, double t) {
        double r60802 = 2.0;
        double r60803 = y;
        double r60804 = cbrt(r60803);
        double r60805 = log(r60804);
        double r60806 = r60802 * r60805;
        double r60807 = x;
        double r60808 = r60806 * r60807;
        double r60809 = 1.0;
        double r60810 = r60809 / r60803;
        double r60811 = -0.3333333333333333;
        double r60812 = pow(r60810, r60811);
        double r60813 = log(r60812);
        double r60814 = r60813 * r60807;
        double r60815 = r60808 + r60814;
        double r60816 = r60815 - r60803;
        double r60817 = z;
        double r60818 = r60816 - r60817;
        double r60819 = t;
        double r60820 = log(r60819);
        double r60821 = r60818 + r60820;
        return r60821;
}

Error

Bits error versus x

Bits error versus y

Bits error versus z

Bits error versus t

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Derivation

  1. Initial program 0.1

    \[\left(\left(x \cdot \log y - y\right) - z\right) + \log t\]
  2. Using strategy rm
  3. Applied add-cube-cbrt0.1

    \[\leadsto \left(\left(x \cdot \log \color{blue}{\left(\left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) \cdot \sqrt[3]{y}\right)} - y\right) - z\right) + \log t\]
  4. Applied log-prod0.1

    \[\leadsto \left(\left(x \cdot \color{blue}{\left(\log \left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) + \log \left(\sqrt[3]{y}\right)\right)} - y\right) - z\right) + \log t\]
  5. Applied distribute-lft-in0.1

    \[\leadsto \left(\left(\color{blue}{\left(x \cdot \log \left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) + x \cdot \log \left(\sqrt[3]{y}\right)\right)} - y\right) - z\right) + \log t\]
  6. Simplified0.1

    \[\leadsto \left(\left(\left(\color{blue}{\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x} + x \cdot \log \left(\sqrt[3]{y}\right)\right) - y\right) - z\right) + \log t\]
  7. Simplified0.1

    \[\leadsto \left(\left(\left(\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x + \color{blue}{\log \left(\sqrt[3]{y}\right) \cdot x}\right) - y\right) - z\right) + \log t\]
  8. Taylor expanded around inf 0.1

    \[\leadsto \left(\left(\left(\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x + \log \color{blue}{\left({\left(\frac{1}{y}\right)}^{\frac{-1}{3}}\right)} \cdot x\right) - y\right) - z\right) + \log t\]
  9. Final simplification0.1

    \[\leadsto \left(\left(\left(\left(2 \cdot \log \left(\sqrt[3]{y}\right)\right) \cdot x + \log \left({\left(\frac{1}{y}\right)}^{\frac{-1}{3}}\right) \cdot x\right) - y\right) - z\right) + \log t\]

Reproduce

herbie shell --seed 2019303 
(FPCore (x y z t)
  :name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, A"
  :precision binary64
  (+ (- (- (* x (log y)) y) z) (log t)))