\left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(a - 0.5\right) \cdot \log t
\log \left(x + y\right) + \left(\left(\log z - t\right) + \left(\left(a - 0.5\right) \cdot \left(2 \cdot \log \left(\sqrt[3]{t}\right)\right) + \left(\left(a - 0.5\right) \cdot \left(\log \left(\sqrt[3]{\sqrt[3]{t}}\right) \cdot 2\right) + \left(a - 0.5\right) \cdot \log \left(\sqrt[3]{\sqrt[3]{t}}\right)\right)\right)\right)double f(double x, double y, double z, double t, double a) {
double r405771 = x;
double r405772 = y;
double r405773 = r405771 + r405772;
double r405774 = log(r405773);
double r405775 = z;
double r405776 = log(r405775);
double r405777 = r405774 + r405776;
double r405778 = t;
double r405779 = r405777 - r405778;
double r405780 = a;
double r405781 = 0.5;
double r405782 = r405780 - r405781;
double r405783 = log(r405778);
double r405784 = r405782 * r405783;
double r405785 = r405779 + r405784;
return r405785;
}
double f(double x, double y, double z, double t, double a) {
double r405786 = x;
double r405787 = y;
double r405788 = r405786 + r405787;
double r405789 = log(r405788);
double r405790 = z;
double r405791 = log(r405790);
double r405792 = t;
double r405793 = r405791 - r405792;
double r405794 = a;
double r405795 = 0.5;
double r405796 = r405794 - r405795;
double r405797 = 2.0;
double r405798 = cbrt(r405792);
double r405799 = log(r405798);
double r405800 = r405797 * r405799;
double r405801 = r405796 * r405800;
double r405802 = cbrt(r405798);
double r405803 = log(r405802);
double r405804 = r405803 * r405797;
double r405805 = r405796 * r405804;
double r405806 = r405796 * r405803;
double r405807 = r405805 + r405806;
double r405808 = r405801 + r405807;
double r405809 = r405793 + r405808;
double r405810 = r405789 + r405809;
return r405810;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 0.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 0.3
rmApplied associate--l+0.3
Applied associate-+l+0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Simplified0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2020047
(FPCore (x y z t a)
:name "Numeric.SpecFunctions:logGammaL from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(+ (log (+ x y)) (+ (- (log z) t) (* (- a 0.5) (log t))))
(+ (- (+ (log (+ x y)) (log z)) t) (* (- a 0.5) (log t))))