\frac{x}{x + y \cdot e^{2.0 \cdot \left(\frac{z \cdot \sqrt{t + a}}{t} - \left(b - c\right) \cdot \left(\left(a + \frac{5.0}{6.0}\right) - \frac{2.0}{t \cdot 3.0}\right)\right)}}\begin{array}{l}
\mathbf{if}\;t \le -5.0089747297515344 \cdot 10^{-254}:\\
\;\;\;\;\frac{x}{x + e^{\mathsf{fma}\left(z, \frac{\sqrt{t + a}}{t}, \left(-\left(b - c\right)\right) \cdot \left(\left(a + \frac{5.0}{6.0}\right) - \frac{2.0}{t \cdot 3.0}\right)\right) \cdot 2.0} \cdot y}\\
\mathbf{elif}\;t \le 5.358377107920803 \cdot 10^{-277}:\\
\;\;\;\;\frac{x}{\mathsf{fma}\left(y, e^{2.0 \cdot \mathsf{fma}\left(c - b, \frac{5.0}{6.0} - \left(\frac{\frac{2.0}{t}}{3.0} - a\right), \left(\left(\frac{\sqrt{t + a}}{\frac{t}{z}}\right)\right)\right)}, x\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{x + e^{\mathsf{fma}\left(z, \frac{\sqrt{t + a}}{t}, \left(-\left(b - c\right)\right) \cdot \left(\left(a + \frac{5.0}{6.0}\right) - \frac{2.0}{t \cdot 3.0}\right)\right) \cdot 2.0} \cdot y}\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c) {
double r20687660 = x;
double r20687661 = y;
double r20687662 = 2.0;
double r20687663 = z;
double r20687664 = t;
double r20687665 = a;
double r20687666 = r20687664 + r20687665;
double r20687667 = sqrt(r20687666);
double r20687668 = r20687663 * r20687667;
double r20687669 = r20687668 / r20687664;
double r20687670 = b;
double r20687671 = c;
double r20687672 = r20687670 - r20687671;
double r20687673 = 5.0;
double r20687674 = 6.0;
double r20687675 = r20687673 / r20687674;
double r20687676 = r20687665 + r20687675;
double r20687677 = 3.0;
double r20687678 = r20687664 * r20687677;
double r20687679 = r20687662 / r20687678;
double r20687680 = r20687676 - r20687679;
double r20687681 = r20687672 * r20687680;
double r20687682 = r20687669 - r20687681;
double r20687683 = r20687662 * r20687682;
double r20687684 = exp(r20687683);
double r20687685 = r20687661 * r20687684;
double r20687686 = r20687660 + r20687685;
double r20687687 = r20687660 / r20687686;
return r20687687;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r20687688 = t;
double r20687689 = -5.0089747297515344e-254;
bool r20687690 = r20687688 <= r20687689;
double r20687691 = x;
double r20687692 = z;
double r20687693 = a;
double r20687694 = r20687688 + r20687693;
double r20687695 = sqrt(r20687694);
double r20687696 = r20687695 / r20687688;
double r20687697 = b;
double r20687698 = c;
double r20687699 = r20687697 - r20687698;
double r20687700 = -r20687699;
double r20687701 = 5.0;
double r20687702 = 6.0;
double r20687703 = r20687701 / r20687702;
double r20687704 = r20687693 + r20687703;
double r20687705 = 2.0;
double r20687706 = 3.0;
double r20687707 = r20687688 * r20687706;
double r20687708 = r20687705 / r20687707;
double r20687709 = r20687704 - r20687708;
double r20687710 = r20687700 * r20687709;
double r20687711 = fma(r20687692, r20687696, r20687710);
double r20687712 = r20687711 * r20687705;
double r20687713 = exp(r20687712);
double r20687714 = y;
double r20687715 = r20687713 * r20687714;
double r20687716 = r20687691 + r20687715;
double r20687717 = r20687691 / r20687716;
double r20687718 = 5.358377107920803e-277;
bool r20687719 = r20687688 <= r20687718;
double r20687720 = r20687698 - r20687697;
double r20687721 = r20687705 / r20687688;
double r20687722 = r20687721 / r20687706;
double r20687723 = r20687722 - r20687693;
double r20687724 = r20687703 - r20687723;
double r20687725 = r20687688 / r20687692;
double r20687726 = r20687695 / r20687725;
double r20687727 = /* ERROR: no posit support in C */;
double r20687728 = /* ERROR: no posit support in C */;
double r20687729 = fma(r20687720, r20687724, r20687728);
double r20687730 = r20687705 * r20687729;
double r20687731 = exp(r20687730);
double r20687732 = fma(r20687714, r20687731, r20687691);
double r20687733 = r20687691 / r20687732;
double r20687734 = r20687719 ? r20687733 : r20687717;
double r20687735 = r20687690 ? r20687717 : r20687734;
return r20687735;
}




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
| Original | 3.8 |
|---|---|
| Target | 3.1 |
| Herbie | 2.5 |
if t < -5.0089747297515344e-254 or 5.358377107920803e-277 < t Initial program 3.1
rmApplied *-un-lft-identity3.1
Applied times-frac2.3
Applied fma-neg1.4
if -5.0089747297515344e-254 < t < 5.358377107920803e-277Initial program 12.0
Simplified7.8
rmApplied insert-posit1616.9
Final simplification2.5
herbie shell --seed 2019158 +o rules:numerics
(FPCore (x y z t a b c)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, I"
:herbie-target
(if (< t -2.118326644891581e-50) (/ x (+ x (* y (exp (* 2.0 (- (+ (* a c) (* 0.8333333333333334 c)) (* a b))))))) (if (< t 5.196588770651547e-123) (/ x (+ x (* y (exp (* 2.0 (/ (- (* (* z (sqrt (+ t a))) (* (* 3.0 t) (- a (/ 5.0 6.0)))) (* (- (* (+ (/ 5.0 6.0) a) (* 3.0 t)) 2.0) (* (- a (/ 5.0 6.0)) (* (- b c) t)))) (* (* (* t t) 3.0) (- a (/ 5.0 6.0))))))))) (/ x (+ x (* y (exp (* 2.0 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0))))))))))))
(/ x (+ x (* y (exp (* 2.0 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5.0 6.0)) (/ 2.0 (* t 3.0)))))))))))