\[(x * y + z)_* - \left(1 + \left(x \cdot y + z\right)\right)\]
Test:
simple fma test
Bits:
128 bits
Bits error versus x
Bits error versus y
Bits error versus z
Time: 5.9 s
Input Error: 19.7
Output Error: 15.7
Log:
Profile: 🕒
\(\left((x * y + z)_* - y \cdot x\right) - \left(z + 1\right)\)
  1. Started with
    \[(x * y + z)_* - \left(1 + \left(x \cdot y + z\right)\right)\]
    19.7
  2. Using strategy rm
    19.7
  3. Applied associate--r+ to get
    \[\color{red}{(x * y + z)_* - \left(1 + \left(x \cdot y + z\right)\right)} \leadsto \color{blue}{\left((x * y + z)_* - 1\right) - \left(x \cdot y + z\right)}\]
    15.6
  4. Using strategy rm
    15.6
  5. Applied associate--r+ to get
    \[\color{red}{\left((x * y + z)_* - 1\right) - \left(x \cdot y + z\right)} \leadsto \color{blue}{\left(\left((x * y + z)_* - 1\right) - x \cdot y\right) - z}\]
    16.7
  6. Applied taylor to get
    \[\left(\left((x * y + z)_* - 1\right) - x \cdot y\right) - z \leadsto \left((x * y + z)_* - \left(y \cdot x + 1\right)\right) - z\]
    18.1
  7. Taylor expanded around 0 to get
    \[\color{red}{\left((x * y + z)_* - \left(y \cdot x + 1\right)\right)} - z \leadsto \color{blue}{\left((x * y + z)_* - \left(y \cdot x + 1\right)\right)} - z\]
    18.1
  8. Applied simplify to get
    \[\left((x * y + z)_* - \left(y \cdot x + 1\right)\right) - z \leadsto \left((x * y + z)_* - y \cdot x\right) - \left(z + 1\right)\]
    15.7

  9. Applied final simplification

Original test:


(lambda ((x default) (y default) (z default))
  #:name "simple fma test"
  (- (fma x y z) (+ 1 (+ (* x y) z)))
  #:target
  -1)