Average Error: 0 → 0
Time: 407.0ms
Precision: 64
\[2 \cdot \left(\left(1 \cdot \frac{1}{9} + \frac{1}{9} \cdot \frac{1}{9}\right) + \frac{1}{9} \cdot 1\right)\]
\[\left(\mathsf{fma}\left(2, 1, \frac{1}{9}\right) \cdot \frac{2}{9}\right) \cdot 1\]
2 \cdot \left(\left(1 \cdot \frac{1}{9} + \frac{1}{9} \cdot \frac{1}{9}\right) + \frac{1}{9} \cdot 1\right)
\left(\mathsf{fma}\left(2, 1, \frac{1}{9}\right) \cdot \frac{2}{9}\right) \cdot 1
double f() {
        double r103513 = 2.0;
        double r103514 = 1.0;
        double r103515 = 9.0;
        double r103516 = r103514 / r103515;
        double r103517 = r103514 * r103516;
        double r103518 = r103516 * r103516;
        double r103519 = r103517 + r103518;
        double r103520 = r103516 * r103514;
        double r103521 = r103519 + r103520;
        double r103522 = r103513 * r103521;
        return r103522;
}

double f() {
        double r103523 = 2.0;
        double r103524 = 1.0;
        double r103525 = 9.0;
        double r103526 = r103524 / r103525;
        double r103527 = fma(r103523, r103524, r103526);
        double r103528 = 2.0;
        double r103529 = r103528 / r103525;
        double r103530 = r103527 * r103529;
        double r103531 = r103530 * r103524;
        return r103531;
}

Error

Target

Original0
Target0
Herbie0
\[\left(\left(\frac{1}{9} \cdot 1\right) \cdot 2 + 2 \cdot \left(\frac{1}{9} \cdot \frac{1}{9}\right)\right) + 2 \cdot \left(1 \cdot \frac{1}{9}\right)\]

Derivation

  1. Initial program 0

    \[2 \cdot \left(\left(1 \cdot \frac{1}{9} + \frac{1}{9} \cdot \frac{1}{9}\right) + \frac{1}{9} \cdot 1\right)\]
  2. Simplified0

    \[\leadsto \color{blue}{\left(\mathsf{fma}\left(2, 1, \frac{1}{9}\right) \cdot \frac{2}{9}\right) \cdot 1}\]
  3. Final simplification0

    \[\leadsto \left(\mathsf{fma}\left(2, 1, \frac{1}{9}\right) \cdot \frac{2}{9}\right) \cdot 1\]

Reproduce

herbie shell --seed 2020056 +o rules:numerics
(FPCore ()
  :name "Rectangular parallelepiped of dimension a×b×c"
  :precision binary64

  :herbie-target
  (+ (+ (* (* (/ 1 9) 1) 2) (* 2 (* (/ 1 9) (/ 1 9)))) (* 2 (* 1 (/ 1 9))))

  (* 2 (+ (+ (* 1 (/ 1 9)) (* (/ 1 9) (/ 1 9))) (* (/ 1 9) 1))))