\frac{x}{x + y \cdot e^{2 \cdot \left(\frac{z \cdot \sqrt{t + a}}{t} - \left(b - c\right) \cdot \left(\left(a + \frac{5}{6}\right) - \frac{2}{t \cdot 3}\right)\right)}}\frac{x}{x + y \cdot e^{2 \cdot \left(\frac{z}{\sqrt[3]{t} \cdot \sqrt[3]{t}} \cdot \frac{\sqrt{t + a}}{\sqrt[3]{t}} - \left(b - c\right) \cdot \left(\left(a + \frac{5}{6}\right) - \frac{2}{t \cdot 3}\right)\right)}}double f(double x, double y, double z, double t, double a, double b, double c) {
double r323442 = x;
double r323443 = y;
double r323444 = 2.0;
double r323445 = z;
double r323446 = t;
double r323447 = a;
double r323448 = r323446 + r323447;
double r323449 = sqrt(r323448);
double r323450 = r323445 * r323449;
double r323451 = r323450 / r323446;
double r323452 = b;
double r323453 = c;
double r323454 = r323452 - r323453;
double r323455 = 5.0;
double r323456 = 6.0;
double r323457 = r323455 / r323456;
double r323458 = r323447 + r323457;
double r323459 = 3.0;
double r323460 = r323446 * r323459;
double r323461 = r323444 / r323460;
double r323462 = r323458 - r323461;
double r323463 = r323454 * r323462;
double r323464 = r323451 - r323463;
double r323465 = r323444 * r323464;
double r323466 = exp(r323465);
double r323467 = r323443 * r323466;
double r323468 = r323442 + r323467;
double r323469 = r323442 / r323468;
return r323469;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r323470 = x;
double r323471 = y;
double r323472 = 2.0;
double r323473 = z;
double r323474 = t;
double r323475 = cbrt(r323474);
double r323476 = r323475 * r323475;
double r323477 = r323473 / r323476;
double r323478 = a;
double r323479 = r323474 + r323478;
double r323480 = sqrt(r323479);
double r323481 = r323480 / r323475;
double r323482 = r323477 * r323481;
double r323483 = b;
double r323484 = c;
double r323485 = r323483 - r323484;
double r323486 = 5.0;
double r323487 = 6.0;
double r323488 = r323486 / r323487;
double r323489 = r323478 + r323488;
double r323490 = 3.0;
double r323491 = r323474 * r323490;
double r323492 = r323472 / r323491;
double r323493 = r323489 - r323492;
double r323494 = r323485 * r323493;
double r323495 = r323482 - r323494;
double r323496 = r323472 * r323495;
double r323497 = exp(r323496);
double r323498 = r323471 * r323497;
double r323499 = r323470 + r323498;
double r323500 = r323470 / r323499;
return r323500;
}




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
Results
| Original | 4.0 |
|---|---|
| Target | 3.1 |
| Herbie | 2.7 |
Initial program 4.0
rmApplied add-cube-cbrt4.0
Applied times-frac2.7
Final simplification2.7
herbie shell --seed 1978988140
(FPCore (x y z t a b c)
:name "Numeric.SpecFunctions:invIncompleteBetaWorker from math-functions-0.1.5.2, I"
:precision binary64
:herbie-target
(if (< t -2.1183266448915811e-50) (/ x (+ x (* y (exp (* 2 (- (+ (* a c) (* 0.83333333333333337 c)) (* a b))))))) (if (< t 5.19658877065154709e-123) (/ x (+ x (* y (exp (* 2 (/ (- (* (* z (sqrt (+ t a))) (* (* 3 t) (- a (/ 5 6)))) (* (- (* (+ (/ 5 6) a) (* 3 t)) 2) (* (- a (/ 5 6)) (* (- b c) t)))) (* (* (* t t) 3) (- a (/ 5 6))))))))) (/ x (+ x (* y (exp (* 2 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5 6)) (/ 2 (* t 3))))))))))))
(/ x (+ x (* y (exp (* 2 (- (/ (* z (sqrt (+ t a))) t) (* (- b c) (- (+ a (/ 5 6)) (/ 2 (* t 3)))))))))))