Average Error: 10.2 → 0.0
Time: 21.7s
Precision: 64
\[\frac{x + y \cdot \left(z - x\right)}{z}\]
\[\mathsf{fma}\left(1, \frac{x}{z} + y, \frac{x}{z} \cdot \left(-y\right)\right)\]
\frac{x + y \cdot \left(z - x\right)}{z}
\mathsf{fma}\left(1, \frac{x}{z} + y, \frac{x}{z} \cdot \left(-y\right)\right)
double f(double x, double y, double z) {
        double r495355 = x;
        double r495356 = y;
        double r495357 = z;
        double r495358 = r495357 - r495355;
        double r495359 = r495356 * r495358;
        double r495360 = r495355 + r495359;
        double r495361 = r495360 / r495357;
        return r495361;
}

double f(double x, double y, double z) {
        double r495362 = 1.0;
        double r495363 = x;
        double r495364 = z;
        double r495365 = r495363 / r495364;
        double r495366 = y;
        double r495367 = r495365 + r495366;
        double r495368 = -r495366;
        double r495369 = r495365 * r495368;
        double r495370 = fma(r495362, r495367, r495369);
        return r495370;
}

Error

Bits error versus x

Bits error versus y

Bits error versus z

Target

Original10.2
Target0.0
Herbie0.0
\[\left(y + \frac{x}{z}\right) - \frac{y}{\frac{z}{x}}\]

Derivation

  1. Initial program 10.2

    \[\frac{x + y \cdot \left(z - x\right)}{z}\]
  2. Simplified10.2

    \[\leadsto \color{blue}{\frac{\mathsf{fma}\left(z - x, y, x\right)}{z}}\]
  3. Taylor expanded around 0 3.3

    \[\leadsto \color{blue}{\left(\frac{x}{z} + y\right) - \frac{x \cdot y}{z}}\]
  4. Using strategy rm
  5. Applied *-un-lft-identity3.3

    \[\leadsto \color{blue}{1 \cdot \left(\frac{x}{z} + y\right)} - \frac{x \cdot y}{z}\]
  6. Applied fma-neg3.3

    \[\leadsto \color{blue}{\mathsf{fma}\left(1, \frac{x}{z} + y, -\frac{x \cdot y}{z}\right)}\]
  7. Simplified0.0

    \[\leadsto \mathsf{fma}\left(1, \frac{x}{z} + y, \color{blue}{\frac{x}{z} \cdot \left(-y\right)}\right)\]
  8. Final simplification0.0

    \[\leadsto \mathsf{fma}\left(1, \frac{x}{z} + y, \frac{x}{z} \cdot \left(-y\right)\right)\]

Reproduce

herbie shell --seed 2019323 +o rules:numerics
(FPCore (x y z)
  :name "Diagrams.Backend.Rasterific:rasterificRadialGradient from diagrams-rasterific-1.3.1.3"
  :precision binary64

  :herbie-target
  (- (+ y (/ x z)) (/ y (/ z x)))

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