\[\frac{b \cdot c - a \cdot d}{{c}^2 + {d}^2}\]
Test:
Complex division, imag part
Bits:
128 bits
Bits error versus a
Bits error versus b
Bits error versus c
Bits error versus d
Time: 11.9 s
Input Error: 12.7
Output Error: 6.3
Log:
Profile: 🕒
\(\begin{cases} \frac{b}{c} - \frac{d}{c} \cdot \frac{a}{c} & \text{when } c \le -2.5839047f+17 \\ \frac{b \cdot c - a \cdot d}{{\left(\sqrt[3]{{c}^2 + {d}^2}\right)}^3} & \text{when } c \le 2.8363323f+14 \\ \frac{b}{c} - \frac{d}{c} \cdot \frac{a}{c} & \text{otherwise} \end{cases}\)

    if c < -2.5839047f+17 or 2.8363323f+14 < c

    1. Started with
      \[\frac{b \cdot c - a \cdot d}{{c}^2 + {d}^2}\]
      21.3
    2. Using strategy rm
      21.3
    3. Applied add-sqr-sqrt to get
      \[\frac{b \cdot c - a \cdot d}{\color{red}{{c}^2 + {d}^2}} \leadsto \frac{b \cdot c - a \cdot d}{\color{blue}{{\left(\sqrt{{c}^2 + {d}^2}\right)}^2}}\]
      21.3
    4. Applied taylor to get
      \[\frac{b \cdot c - a \cdot d}{{\left(\sqrt{{c}^2 + {d}^2}\right)}^2} \leadsto \frac{b \cdot c - a \cdot d}{{\left(-1 \cdot c\right)}^2}\]
      20.7
    5. Taylor expanded around -inf to get
      \[\frac{b \cdot c - a \cdot d}{{\color{red}{\left(-1 \cdot c\right)}}^2} \leadsto \frac{b \cdot c - a \cdot d}{{\color{blue}{\left(-1 \cdot c\right)}}^2}\]
      20.7
    6. Applied simplify to get
      \[\color{red}{\frac{b \cdot c - a \cdot d}{{\left(-1 \cdot c\right)}^2}} \leadsto \color{blue}{\frac{b}{c} - \frac{d}{c} \cdot \frac{a}{c}}\]
      0.3

    if -2.5839047f+17 < c < 2.8363323f+14

    1. Started with
      \[\frac{b \cdot c - a \cdot d}{{c}^2 + {d}^2}\]
      8.8
    2. Using strategy rm
      8.8
    3. Applied add-cube-cbrt to get
      \[\frac{b \cdot c - a \cdot d}{\color{red}{{c}^2 + {d}^2}} \leadsto \frac{b \cdot c - a \cdot d}{\color{blue}{{\left(\sqrt[3]{{c}^2 + {d}^2}\right)}^3}}\]
      9.0

  1. Removed slow pow expressions

Original test:


(lambda ((a default) (b default) (c default) (d default))
  #:name "Complex division, imag part"
  (/ (- (* b c) (* a d)) (+ (sqr c) (sqr d)))
  #:target
  (if (< (fabs d) (fabs c)) (/ (- b (* a (/ d c))) (+ c (* d (/ d c)))) (/ (+ (- a) (* b (/ c d))) (+ d (* c (/ c d))))))