Average Error: 29.0 → 1.2
Time: 9.3s
Precision: 64
\[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}\]
\[\begin{array}{l} \mathbf{if}\;z \le -2.078108004357145 \cdot 10^{59} \lor \neg \left(z \le 9.5295344732185015 \cdot 10^{30}\right):\\ \;\;\;\;\mathsf{fma}\left(y, 3.13060547622999996 + \frac{t}{{z}^{2}}, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(y \cdot \frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)\\ \end{array}\]
x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}
\begin{array}{l}
\mathbf{if}\;z \le -2.078108004357145 \cdot 10^{59} \lor \neg \left(z \le 9.5295344732185015 \cdot 10^{30}\right):\\
\;\;\;\;\mathsf{fma}\left(y, 3.13060547622999996 + \frac{t}{{z}^{2}}, x\right)\\

\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y \cdot \frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)\\

\end{array}
double f(double x, double y, double z, double t, double a, double b) {
        double r403084 = x;
        double r403085 = y;
        double r403086 = z;
        double r403087 = 3.13060547623;
        double r403088 = r403086 * r403087;
        double r403089 = 11.1667541262;
        double r403090 = r403088 + r403089;
        double r403091 = r403090 * r403086;
        double r403092 = t;
        double r403093 = r403091 + r403092;
        double r403094 = r403093 * r403086;
        double r403095 = a;
        double r403096 = r403094 + r403095;
        double r403097 = r403096 * r403086;
        double r403098 = b;
        double r403099 = r403097 + r403098;
        double r403100 = r403085 * r403099;
        double r403101 = 15.234687407;
        double r403102 = r403086 + r403101;
        double r403103 = r403102 * r403086;
        double r403104 = 31.4690115749;
        double r403105 = r403103 + r403104;
        double r403106 = r403105 * r403086;
        double r403107 = 11.9400905721;
        double r403108 = r403106 + r403107;
        double r403109 = r403108 * r403086;
        double r403110 = 0.607771387771;
        double r403111 = r403109 + r403110;
        double r403112 = r403100 / r403111;
        double r403113 = r403084 + r403112;
        return r403113;
}

double f(double x, double y, double z, double t, double a, double b) {
        double r403114 = z;
        double r403115 = -2.078108004357145e+59;
        bool r403116 = r403114 <= r403115;
        double r403117 = 9.529534473218501e+30;
        bool r403118 = r403114 <= r403117;
        double r403119 = !r403118;
        bool r403120 = r403116 || r403119;
        double r403121 = y;
        double r403122 = 3.13060547623;
        double r403123 = t;
        double r403124 = 2.0;
        double r403125 = pow(r403114, r403124);
        double r403126 = r403123 / r403125;
        double r403127 = r403122 + r403126;
        double r403128 = x;
        double r403129 = fma(r403121, r403127, r403128);
        double r403130 = 1.0;
        double r403131 = 15.234687407;
        double r403132 = r403114 + r403131;
        double r403133 = 31.4690115749;
        double r403134 = fma(r403132, r403114, r403133);
        double r403135 = 11.9400905721;
        double r403136 = fma(r403134, r403114, r403135);
        double r403137 = 0.607771387771;
        double r403138 = fma(r403136, r403114, r403137);
        double r403139 = r403130 / r403138;
        double r403140 = r403121 * r403139;
        double r403141 = 11.1667541262;
        double r403142 = fma(r403114, r403122, r403141);
        double r403143 = fma(r403142, r403114, r403123);
        double r403144 = a;
        double r403145 = fma(r403143, r403114, r403144);
        double r403146 = b;
        double r403147 = fma(r403145, r403114, r403146);
        double r403148 = fma(r403140, r403147, r403128);
        double r403149 = r403120 ? r403129 : r403148;
        return r403149;
}

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

Target

Original29.0
Target1.1
Herbie1.2
\[\begin{array}{l} \mathbf{if}\;z \lt -6.4993449962526318 \cdot 10^{53}:\\ \;\;\;\;x + \left(\left(3.13060547622999996 - \frac{36.527041698806414}{z}\right) + \frac{t}{z \cdot z}\right) \cdot \frac{y}{1}\\ \mathbf{elif}\;z \lt 7.0669654369142868 \cdot 10^{59}:\\ \;\;\;\;x + \frac{y}{\frac{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}{\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}}\\ \mathbf{else}:\\ \;\;\;\;x + \left(\left(3.13060547622999996 - \frac{36.527041698806414}{z}\right) + \frac{t}{z \cdot z}\right) \cdot \frac{y}{1}\\ \end{array}\]

Derivation

  1. Split input into 2 regimes
  2. if z < -2.078108004357145e+59 or 9.529534473218501e+30 < z

    1. Initial program 60.3

      \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}\]
    2. Simplified58.8

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)}\]
    3. Taylor expanded around inf 9.0

      \[\leadsto \color{blue}{x + \left(\frac{t \cdot y}{{z}^{2}} + 3.13060547622999996 \cdot y\right)}\]
    4. Simplified1.2

      \[\leadsto \color{blue}{\mathsf{fma}\left(y, 3.13060547622999996 + \frac{t}{{z}^{2}}, x\right)}\]

    if -2.078108004357145e+59 < z < 9.529534473218501e+30

    1. Initial program 2.2

      \[x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}\]
    2. Simplified1.0

      \[\leadsto \color{blue}{\mathsf{fma}\left(\frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)}\]
    3. Using strategy rm
    4. Applied div-inv1.1

      \[\leadsto \mathsf{fma}\left(\color{blue}{y \cdot \frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)\]
  3. Recombined 2 regimes into one program.
  4. Final simplification1.2

    \[\leadsto \begin{array}{l} \mathbf{if}\;z \le -2.078108004357145 \cdot 10^{59} \lor \neg \left(z \le 9.5295344732185015 \cdot 10^{30}\right):\\ \;\;\;\;\mathsf{fma}\left(y, 3.13060547622999996 + \frac{t}{{z}^{2}}, x\right)\\ \mathbf{else}:\\ \;\;\;\;\mathsf{fma}\left(y \cdot \frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\right), z, t\right), z, a\right), z, b\right), x\right)\\ \end{array}\]

Reproduce

herbie shell --seed 2020062 +o rules:numerics
(FPCore (x y z t a b)
  :name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, D"
  :precision binary64

  :herbie-target
  (if (< z -6.499344996252632e+53) (+ x (* (+ (- 3.13060547623 (/ 36.527041698806414 z)) (/ t (* z z))) (/ y 1))) (if (< z 7.066965436914287e+59) (+ x (/ y (/ (+ (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z) 0.607771387771) (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b)))) (+ x (* (+ (- 3.13060547623 (/ 36.527041698806414 z)) (/ t (* z z))) (/ y 1)))))

  (+ x (/ (* y (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b)) (+ (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z) 0.607771387771))))