\[\frac{a \cdot c + b \cdot d}{{c}^2 + {d}^2}\]
Test:
Complex division, real part
Bits:
128 bits
Bits error versus a
Bits error versus b
Bits error versus c
Bits error versus d
Time: 12.6 s
Input Error: 25.7
Output Error: 13.0
Log:
Profile: 🕒
\(\begin{cases} (\left(\frac{b}{c}\right) * \left(\frac{d}{c}\right) + \left(\frac{a}{c}\right))_* & \text{when } c \le -2.2494752454919133 \cdot 10^{+113} \\ \left(a \cdot c + b \cdot d\right) \cdot \frac{1}{{c}^2 + {d}^2} & \text{when } c \le 1.9927352307154392 \cdot 10^{+127} \\ (\left(\frac{b}{c}\right) * \left(\frac{d}{c}\right) + \left(\frac{a}{c}\right))_* & \text{otherwise} \end{cases}\)

    if c < -2.2494752454919133e+113 or 1.9927352307154392e+127 < c

    1. Started with
      \[\frac{a \cdot c + b \cdot d}{{c}^2 + {d}^2}\]
      41.5
    2. Using strategy rm
      41.5
    3. Applied add-cube-cbrt to get
      \[\frac{a \cdot c + b \cdot d}{\color{red}{{c}^2 + {d}^2}} \leadsto \frac{a \cdot c + b \cdot d}{\color{blue}{{\left(\sqrt[3]{{c}^2 + {d}^2}\right)}^3}}\]
      41.6
    4. Applied taylor to get
      \[\frac{a \cdot c + b \cdot d}{{\left(\sqrt[3]{{c}^2 + {d}^2}\right)}^3} \leadsto \frac{a}{c} + \frac{b \cdot d}{{c}^2}\]
      12.1
    5. Taylor expanded around inf to get
      \[\color{red}{\frac{a}{c} + \frac{b \cdot d}{{c}^2}} \leadsto \color{blue}{\frac{a}{c} + \frac{b \cdot d}{{c}^2}}\]
      12.1
    6. Applied simplify to get
      \[\frac{a}{c} + \frac{b \cdot d}{{c}^2} \leadsto (\left(\frac{b}{c}\right) * \left(\frac{d}{c}\right) + \left(\frac{a}{c}\right))_*\]
      0.9

    7. Applied final simplification

    if -2.2494752454919133e+113 < c < 1.9927352307154392e+127

    1. Started with
      \[\frac{a \cdot c + b \cdot d}{{c}^2 + {d}^2}\]
      18.4
    2. Using strategy rm
      18.4
    3. Applied div-inv to get
      \[\color{red}{\frac{a \cdot c + b \cdot d}{{c}^2 + {d}^2}} \leadsto \color{blue}{\left(a \cdot c + b \cdot d\right) \cdot \frac{1}{{c}^2 + {d}^2}}\]
      18.6

  1. Removed slow pow expressions

Original test:


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