Initial program 37.4
\[\sqrt{\left(x \cdot x + y \cdot y\right) + z \cdot z}
\]
Simplified37.4
\[\leadsto \color{blue}{\sqrt{\mathsf{fma}\left(x, x, \mathsf{fma}\left(y, y, z \cdot z\right)\right)}}
\]
Proof
(sqrt.f64 (fma.f64 x x (fma.f64 y y (*.f64 z z)))): 0 points increase in error, 0 points decrease in error
(sqrt.f64 (fma.f64 x x (Rewrite<= fma-def_binary64 (+.f64 (*.f64 y y) (*.f64 z z))))): 0 points increase in error, 0 points decrease in error
(sqrt.f64 (Rewrite<= fma-def_binary64 (+.f64 (*.f64 x x) (+.f64 (*.f64 y y) (*.f64 z z))))): 1 points increase in error, 0 points decrease in error
(sqrt.f64 (Rewrite<= associate-+l+_binary64 (+.f64 (+.f64 (*.f64 x x) (*.f64 y y)) (*.f64 z z)))): 0 points increase in error, 0 points decrease in error
Taylor expanded in y around 0 37.5
\[\leadsto \color{blue}{\sqrt{{z}^{2} + {x}^{2}}}
\]
Simplified0.4
\[\leadsto \color{blue}{\mathsf{hypot}\left(z, x\right)}
\]
Proof
(hypot.f64 z x): 0 points increase in error, 0 points decrease in error
(Rewrite<= hypot-def_binary64 (sqrt.f64 (+.f64 (*.f64 z z) (*.f64 x x)))): 149 points increase in error, 0 points decrease in error
(sqrt.f64 (+.f64 (Rewrite<= unpow2_binary64 (pow.f64 z 2)) (*.f64 x x))): 0 points increase in error, 0 points decrease in error
(sqrt.f64 (+.f64 (pow.f64 z 2) (Rewrite<= unpow2_binary64 (pow.f64 x 2)))): 0 points increase in error, 0 points decrease in error
Final simplification0.4
\[\leadsto \mathsf{hypot}\left(z, x\right)
\]