Initial program 0.1
\[\left(\left(x \cdot y + z \cdot z\right) + z \cdot z\right) + z \cdot z
\]
Simplified0.0
\[\leadsto \color{blue}{\mathsf{fma}\left(z, z, \mathsf{fma}\left(x, y, z \cdot \left(z + z\right)\right)\right)}
\]
Proof
(fma.f64 z z (fma.f64 x y (*.f64 z (+.f64 z z)))): 0 points increase in error, 0 points decrease in error
(fma.f64 z z (fma.f64 x y (Rewrite<= distribute-rgt-out_binary64 (+.f64 (*.f64 z z) (*.f64 z z))))): 0 points increase in error, 0 points decrease in error
(fma.f64 z z (Rewrite<= fma-def_binary64 (+.f64 (*.f64 x y) (+.f64 (*.f64 z z) (*.f64 z z))))): 0 points increase in error, 0 points decrease in error
(fma.f64 z z (Rewrite<= associate-+l+_binary64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)))): 1 points increase in error, 0 points decrease in error
(Rewrite<= fma-def_binary64 (+.f64 (*.f64 z z) (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)))): 25 points increase in error, 0 points decrease in error
(Rewrite<= +-commutative_binary64 (+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))): 0 points increase in error, 0 points decrease in error
Final simplification0.0
\[\leadsto \mathsf{fma}\left(z, z, \mathsf{fma}\left(x, y, z \cdot \left(z + z\right)\right)\right)
\]