\[\sqrt{re \cdot re + im \cdot im}\]
Test:
math.abs on complex
Bits:
128 bits
Bits error versus re
Bits error versus im
Time: 4.8 s
Input Error: 13.3
Output Error: 6.3
Log:
Profile: 🕒
\(\begin{cases} -re & \text{when } re \le -3.924884f+16 \\ \sqrt{{re}^2 + im \cdot im} & \text{when } re \le 1.6052693f+16 \\ re + \frac{\frac{1}{2} \cdot im}{\frac{re}{im}} & \text{otherwise} \end{cases}\)

    if re < -3.924884f+16

    1. Started with
      \[\sqrt{re \cdot re + im \cdot im}\]
      25.4
    2. Applied simplify to get
      \[\color{red}{\sqrt{re \cdot re + im \cdot im}} \leadsto \color{blue}{\sqrt{{re}^2 + im \cdot im}}\]
      25.4
    3. Applied taylor to get
      \[\sqrt{{re}^2 + im \cdot im} \leadsto -1 \cdot re\]
      0
    4. Taylor expanded around -inf to get
      \[\color{red}{-1 \cdot re} \leadsto \color{blue}{-1 \cdot re}\]
      0
    5. Applied simplify to get
      \[\color{red}{-1 \cdot re} \leadsto \color{blue}{-re}\]
      0

    if -3.924884f+16 < re < 1.6052693f+16

    1. Started with
      \[\sqrt{re \cdot re + im \cdot im}\]
      8.7
    2. Applied simplify to get
      \[\color{red}{\sqrt{re \cdot re + im \cdot im}} \leadsto \color{blue}{\sqrt{{re}^2 + im \cdot im}}\]
      8.7

    if 1.6052693f+16 < re

    1. Started with
      \[\sqrt{re \cdot re + im \cdot im}\]
      24.9
    2. Applied simplify to get
      \[\color{red}{\sqrt{re \cdot re + im \cdot im}} \leadsto \color{blue}{\sqrt{{re}^2 + im \cdot im}}\]
      24.9
    3. Using strategy rm
      24.9
    4. Applied add-cube-cbrt to get
      \[\color{red}{\sqrt{{re}^2 + im \cdot im}} \leadsto \color{blue}{{\left(\sqrt[3]{\sqrt{{re}^2 + im \cdot im}}\right)}^3}\]
      25.0
    5. Applied taylor to get
      \[{\left(\sqrt[3]{\sqrt{{re}^2 + im \cdot im}}\right)}^3 \leadsto re + \frac{1}{2} \cdot \frac{{im}^2}{re}\]
      5.5
    6. Taylor expanded around 0 to get
      \[\color{red}{re + \frac{1}{2} \cdot \frac{{im}^2}{re}} \leadsto \color{blue}{re + \frac{1}{2} \cdot \frac{{im}^2}{re}}\]
      5.5
    7. Applied taylor to get
      \[re + \frac{1}{2} \cdot \frac{{im}^2}{re} \leadsto re + \frac{1}{2} \cdot \frac{{im}^2}{re}\]
      5.5
    8. Taylor expanded around 0 to get
      \[re + \frac{1}{2} \cdot \color{red}{\frac{{im}^2}{re}} \leadsto re + \frac{1}{2} \cdot \color{blue}{\frac{{im}^2}{re}}\]
      5.5
    9. Applied simplify to get
      \[re + \frac{1}{2} \cdot \frac{{im}^2}{re} \leadsto re + \frac{\frac{1}{2} \cdot im}{\frac{re}{im}}\]
      0.0

    10. Applied final simplification

  1. Removed slow pow expressions

Original test:


(lambda ((re default) (im default))
  #:name "math.abs on complex"
  (sqrt (+ (* re re) (* im im))))