Average Error: 28.5 → 10.5
Time: 3.4m
Precision: 64
Internal Precision: 576
\[\frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}\]
\[\begin{array}{l} \mathbf{if}\;\frac{(\left((\left((y \cdot x + z)_*\right) \cdot y + 27464.7644705)_*\right) \cdot \left(y \cdot y\right) + \left((230661.510616 \cdot y + t)_*\right))_*}{(y \cdot \left((y \cdot b + c)_*\right) + i)_*} \le -1.6993244313287369 \cdot 10^{+279}:\\ \;\;\;\;\frac{z}{y} + x\\ \mathbf{if}\;\frac{(\left((\left((y \cdot x + z)_*\right) \cdot y + 27464.7644705)_*\right) \cdot \left(y \cdot y\right) + \left((230661.510616 \cdot y + t)_*\right))_*}{(y \cdot \left((y \cdot b + c)_*\right) + i)_*} \le 1.1231032969906933 \cdot 10^{+298}:\\ \;\;\;\;\frac{1}{\frac{(\left((\left(y \cdot y\right) \cdot \left(a + y\right) + \left((y \cdot b + c)_*\right))_*\right) \cdot y + i)_*}{(\left((\left((x \cdot y + z)_*\right) \cdot y + 27464.7644705)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot 230661.510616 + t)_*\right))_*}}\\ \mathbf{else}:\\ \;\;\;\;\frac{z}{y} + x\\ \end{array}\]

Error

Bits error versus x

Bits error versus y

Bits error versus z

Bits error versus t

Bits error versus a

Bits error versus b

Bits error versus c

Bits error versus i

Derivation

  1. Split input into 2 regimes
  2. if (/ (fma (fma (fma y x z) y 27464.7644705) (* y y) (fma 230661.510616 y t)) (fma y (fma y b c) i)) < -1.6993244313287369e+279 or 1.1231032969906933e+298 < (/ (fma (fma (fma y x z) y 27464.7644705) (* y y) (fma 230661.510616 y t)) (fma y (fma y b c) i))

    1. Initial program 60.9

      \[\frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}\]
    2. Using strategy rm
    3. Applied add-cube-cbrt60.9

      \[\leadsto \frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\color{blue}{\left(\sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i} \cdot \sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}\right) \cdot \sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}}}\]
    4. Applied *-un-lft-identity60.9

      \[\leadsto \frac{\color{blue}{1 \cdot \left(\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t\right)}}{\left(\sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i} \cdot \sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}\right) \cdot \sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}}\]
    5. Applied times-frac60.9

      \[\leadsto \color{blue}{\frac{1}{\sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i} \cdot \sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}} \cdot \frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}}}\]
    6. Applied simplify60.9

      \[\leadsto \color{blue}{\frac{\frac{1}{\sqrt[3]{(\left((\left(y + a\right) \cdot y + b)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot c + i)_*\right))_*}}}{\sqrt[3]{(\left((\left(y + a\right) \cdot y + b)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot c + i)_*\right))_*}}} \cdot \frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\sqrt[3]{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}}\]
    7. Applied simplify60.9

      \[\leadsto \frac{\frac{1}{\sqrt[3]{(\left((\left(y + a\right) \cdot y + b)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot c + i)_*\right))_*}}}{\sqrt[3]{(\left((\left(y + a\right) \cdot y + b)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot c + i)_*\right))_*}} \cdot \color{blue}{\frac{(\left((\left(y \cdot y\right) \cdot \left((x \cdot y + z)_*\right) + \left((y \cdot 27464.7644705 + 230661.510616)_*\right))_*\right) \cdot y + t)_*}{\sqrt[3]{(\left((\left(y + a\right) \cdot y + b)_*\right) \cdot \left(y \cdot y\right) + \left((c \cdot y + i)_*\right))_*}}}\]
    8. Taylor expanded around inf 18.8

      \[\leadsto \color{blue}{\frac{z}{y} + x}\]

    if -1.6993244313287369e+279 < (/ (fma (fma (fma y x z) y 27464.7644705) (* y y) (fma 230661.510616 y t)) (fma y (fma y b c) i)) < 1.1231032969906933e+298

    1. Initial program 3.8

      \[\frac{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}\]
    2. Using strategy rm
    3. Applied clear-num4.2

      \[\leadsto \color{blue}{\frac{1}{\frac{\left(\left(\left(y + a\right) \cdot y + b\right) \cdot y + c\right) \cdot y + i}{\left(\left(\left(x \cdot y + z\right) \cdot y + 27464.7644705\right) \cdot y + 230661.510616\right) \cdot y + t}}}\]
    4. Applied simplify4.2

      \[\leadsto \frac{1}{\color{blue}{\frac{(\left((\left(y \cdot y\right) \cdot \left(a + y\right) + \left((y \cdot b + c)_*\right))_*\right) \cdot y + i)_*}{(\left((\left((x \cdot y + z)_*\right) \cdot y + 27464.7644705)_*\right) \cdot \left(y \cdot y\right) + \left((y \cdot 230661.510616 + t)_*\right))_*}}}\]
  3. Recombined 2 regimes into one program.

Runtime

Time bar (total: 3.4m)Debug logProfile

herbie shell --seed 2018206 +o rules:numerics
(FPCore (x y z t a b c i)
  :name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2"
  (/ (+ (* (+ (* (+ (* (+ (* x y) z) y) 27464.7644705) y) 230661.510616) y) t) (+ (* (+ (* (+ (* (+ y a) y) b) y) c) y) i)))