Average Error: 15.0 → 0.2
Time: 16.3s
Precision: 64
\[x \cdot \log \left(\frac{x}{y}\right) - z\]
\[\left(\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) \cdot x + x \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) - z\]
x \cdot \log \left(\frac{x}{y}\right) - z
\left(\left(2 \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) \cdot x + x \cdot \log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)\right) - z
double f(double x, double y, double z) {
        double r1042265 = x;
        double r1042266 = y;
        double r1042267 = r1042265 / r1042266;
        double r1042268 = log(r1042267);
        double r1042269 = r1042265 * r1042268;
        double r1042270 = z;
        double r1042271 = r1042269 - r1042270;
        return r1042271;
}

double f(double x, double y, double z) {
        double r1042272 = 2.0;
        double r1042273 = x;
        double r1042274 = cbrt(r1042273);
        double r1042275 = y;
        double r1042276 = cbrt(r1042275);
        double r1042277 = r1042274 / r1042276;
        double r1042278 = log(r1042277);
        double r1042279 = r1042272 * r1042278;
        double r1042280 = r1042279 * r1042273;
        double r1042281 = r1042273 * r1042278;
        double r1042282 = r1042280 + r1042281;
        double r1042283 = z;
        double r1042284 = r1042282 - r1042283;
        return r1042284;
}

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

Original15.0
Target7.6
Herbie0.2
\[\begin{array}{l} \mathbf{if}\;y \lt 7.595077799083772773657101400994168792118 \cdot 10^{-308}:\\ \;\;\;\;x \cdot \log \left(\frac{x}{y}\right) - z\\ \mathbf{else}:\\ \;\;\;\;x \cdot \left(\log x - \log y\right) - z\\ \end{array}\]

Derivation

  1. Initial program 15.0

    \[x \cdot \log \left(\frac{x}{y}\right) - z\]
  2. Using strategy rm
  3. Applied add-cube-cbrt15.0

    \[\leadsto x \cdot \log \left(\frac{x}{\color{blue}{\left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) \cdot \sqrt[3]{y}}}\right) - z\]
  4. Applied add-cube-cbrt15.0

    \[\leadsto x \cdot \log \left(\frac{\color{blue}{\left(\sqrt[3]{x} \cdot \sqrt[3]{x}\right) \cdot \sqrt[3]{x}}}{\left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right) \cdot \sqrt[3]{y}}\right) - z\]
  5. Applied times-frac15.0

    \[\leadsto x \cdot \log \color{blue}{\left(\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{\sqrt[3]{y} \cdot \sqrt[3]{y}} \cdot \frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right)} - z\]
  6. Applied log-prod3.5

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

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

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

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

Reproduce

herbie shell --seed 2019303 
(FPCore (x y z)
  :name "Numeric.SpecFunctions.Extra:bd0 from math-functions-0.1.5.2"
  :precision binary64

  :herbie-target
  (if (< y 7.59507779908377277e-308) (- (* x (log (/ x y))) z) (- (* x (- (log x) (log y))) z))

  (- (* x (log (/ x y))) z))