Simplified0.1
\[\leadsto \color{blue}{0.5 \cdot \mathsf{fma}\left(\frac{z + x}{y}, x - z, y\right)}
\]
Proof
(*.f64 1/2 (fma.f64 (/.f64 (+.f64 z x) y) (-.f64 x z) y)): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (fma.f64 (/.f64 (Rewrite<= +-commutative_binary64 (+.f64 x z)) y) (-.f64 x z) y)): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (Rewrite<= fma-def_binary64 (+.f64 (*.f64 (/.f64 (+.f64 x z) y) (-.f64 x z)) y))): 3 points increase in error, 1 points decrease in error
(*.f64 1/2 (+.f64 (Rewrite=> associate-*l/_binary64 (/.f64 (*.f64 (+.f64 x z) (-.f64 x z)) y)) y)): 63 points increase in error, 15 points decrease in error
(*.f64 1/2 (+.f64 (/.f64 (Rewrite<= difference-of-squares_binary64 (-.f64 (*.f64 x x) (*.f64 z z))) y) y)): 1 points increase in error, 0 points decrease in error
(*.f64 1/2 (+.f64 (/.f64 (-.f64 (Rewrite<= unpow2_binary64 (pow.f64 x 2)) (*.f64 z z)) y) y)): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (+.f64 (/.f64 (-.f64 (pow.f64 x 2) (Rewrite<= unpow2_binary64 (pow.f64 z 2))) y) y)): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (Rewrite<= +-commutative_binary64 (+.f64 y (/.f64 (-.f64 (pow.f64 x 2) (pow.f64 z 2)) y)))): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (+.f64 y (Rewrite=> div-sub_binary64 (-.f64 (/.f64 (pow.f64 x 2) y) (/.f64 (pow.f64 z 2) y))))): 0 points increase in error, 0 points decrease in error
(*.f64 1/2 (Rewrite=> associate-+r-_binary64 (-.f64 (+.f64 y (/.f64 (pow.f64 x 2) y)) (/.f64 (pow.f64 z 2) y)))): 0 points increase in error, 0 points decrease in error
(Rewrite<= distribute-lft-out--_binary64 (-.f64 (*.f64 1/2 (+.f64 y (/.f64 (pow.f64 x 2) y))) (*.f64 1/2 (/.f64 (pow.f64 z 2) y)))): 0 points increase in error, 0 points decrease in error
(Rewrite=> cancel-sign-sub-inv_binary64 (+.f64 (*.f64 1/2 (+.f64 y (/.f64 (pow.f64 x 2) y))) (*.f64 (neg.f64 1/2) (/.f64 (pow.f64 z 2) y)))): 0 points increase in error, 0 points decrease in error
(+.f64 (Rewrite=> distribute-lft-in_binary64 (+.f64 (*.f64 1/2 y) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))) (*.f64 (neg.f64 1/2) (/.f64 (pow.f64 z 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (+.f64 (*.f64 1/2 y) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))) (*.f64 (Rewrite=> metadata-eval -1/2) (/.f64 (pow.f64 z 2) y))): 0 points increase in error, 0 points decrease in error
(Rewrite=> associate-+l+_binary64 (+.f64 (*.f64 1/2 y) (+.f64 (*.f64 1/2 (/.f64 (pow.f64 x 2) y)) (*.f64 -1/2 (/.f64 (pow.f64 z 2) y))))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 y) (Rewrite=> +-commutative_binary64 (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 z 2) y)) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 (Rewrite<= /-rgt-identity_binary64 (/.f64 y 1))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 z 2) y)) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 (/.f64 y (Rewrite<= *-inverses_binary64 (/.f64 y y)))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 z 2) y)) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 (Rewrite<= associate-/l*_binary64 (/.f64 (*.f64 y y) y))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 z 2) y)) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))): 78 points increase in error, 1 points decrease in error
(+.f64 (*.f64 1/2 (/.f64 (Rewrite<= unpow2_binary64 (pow.f64 y 2)) y)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 z 2) y)) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))): 0 points increase in error, 0 points decrease in error
(Rewrite<= associate-+l+_binary64 (+.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y 2) y)) (*.f64 -1/2 (/.f64 (pow.f64 z 2) y))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y)))): 0 points increase in error, 0 points decrease in error
(+.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y 2) y)) (*.f64 (Rewrite<= metadata-eval (*.f64 1/2 -1)) (/.f64 (pow.f64 z 2) y))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y 2) y)) (Rewrite<= associate-*r*_binary64 (*.f64 1/2 (*.f64 -1 (/.f64 (pow.f64 z 2) y))))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 y 2) y)) (*.f64 1/2 (Rewrite<= neg-mul-1_binary64 (neg.f64 (/.f64 (pow.f64 z 2) y))))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (Rewrite<= distribute-lft-in_binary64 (*.f64 1/2 (+.f64 (/.f64 (pow.f64 y 2) y) (neg.f64 (/.f64 (pow.f64 z 2) y))))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 (Rewrite<= sub-neg_binary64 (-.f64 (/.f64 (pow.f64 y 2) y) (/.f64 (pow.f64 z 2) y)))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 0 points decrease in error
(+.f64 (*.f64 1/2 (Rewrite<= div-sub_binary64 (/.f64 (-.f64 (pow.f64 y 2) (pow.f64 z 2)) y))) (*.f64 1/2 (/.f64 (pow.f64 x 2) y))): 0 points increase in error, 2 points decrease in error