\[\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1\]
Test:
FastMath dist4
Bits:
128 bits
Bits error versus d1
Bits error versus d2
Bits error versus d3
Bits error versus d4
Time: 7.2 s
Input Error: 0.1
Output Error: 0.1
Log:
Profile: 🕒
\(d1 \cdot \left((1 * \left(d2 - d3\right) + d4)_* + \left(-d1\right)\right)\)
  1. Started with
    \[\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1\]
    0.1
  2. Applied simplify to get
    \[\color{red}{\left(\left(d1 \cdot d2 - d1 \cdot d3\right) + d4 \cdot d1\right) - d1 \cdot d1} \leadsto \color{blue}{d1 \cdot \left(\left(d2 - d3\right) + \left(d4 - d1\right)\right)}\]
    0.1
  3. Using strategy rm
    0.1
  4. Applied sub-neg to get
    \[d1 \cdot \left(\left(d2 - d3\right) + \color{red}{\left(d4 - d1\right)}\right) \leadsto d1 \cdot \left(\left(d2 - d3\right) + \color{blue}{\left(d4 + \left(-d1\right)\right)}\right)\]
    0.1
  5. Applied associate-+r+ to get
    \[d1 \cdot \color{red}{\left(\left(d2 - d3\right) + \left(d4 + \left(-d1\right)\right)\right)} \leadsto d1 \cdot \color{blue}{\left(\left(\left(d2 - d3\right) + d4\right) + \left(-d1\right)\right)}\]
    0.1
  6. Using strategy rm
    0.1
  7. Applied *-un-lft-identity to get
    \[d1 \cdot \left(\left(\color{red}{\left(d2 - d3\right)} + d4\right) + \left(-d1\right)\right) \leadsto d1 \cdot \left(\left(\color{blue}{1 \cdot \left(d2 - d3\right)} + d4\right) + \left(-d1\right)\right)\]
    0.1
  8. Applied fma-def to get
    \[d1 \cdot \left(\color{red}{\left(1 \cdot \left(d2 - d3\right) + d4\right)} + \left(-d1\right)\right) \leadsto d1 \cdot \left(\color{blue}{(1 * \left(d2 - d3\right) + d4)_*} + \left(-d1\right)\right)\]
    0.1

Original test:


(lambda ((d1 default) (d2 default) (d3 default) (d4 default))
  #:name "FastMath dist4"
  (- (+ (- (* d1 d2) (* d1 d3)) (* d4 d1)) (* d1 d1))
  #:target
  (* d1 (- (+ (- d2 d3) d4) d1)))