\left(\left(x \cdot y + \frac{z \cdot t}{16.0}\right) - \frac{a \cdot b}{4.0}\right) + c\mathsf{fma}\left(\frac{t}{16.0}, z, \mathsf{fma}\left(y, x, c\right) - \frac{b \cdot a}{4.0}\right)double f(double x, double y, double z, double t, double a, double b, double c) {
double r5899848 = x;
double r5899849 = y;
double r5899850 = r5899848 * r5899849;
double r5899851 = z;
double r5899852 = t;
double r5899853 = r5899851 * r5899852;
double r5899854 = 16.0;
double r5899855 = r5899853 / r5899854;
double r5899856 = r5899850 + r5899855;
double r5899857 = a;
double r5899858 = b;
double r5899859 = r5899857 * r5899858;
double r5899860 = 4.0;
double r5899861 = r5899859 / r5899860;
double r5899862 = r5899856 - r5899861;
double r5899863 = c;
double r5899864 = r5899862 + r5899863;
return r5899864;
}
double f(double x, double y, double z, double t, double a, double b, double c) {
double r5899865 = t;
double r5899866 = 16.0;
double r5899867 = r5899865 / r5899866;
double r5899868 = z;
double r5899869 = y;
double r5899870 = x;
double r5899871 = c;
double r5899872 = fma(r5899869, r5899870, r5899871);
double r5899873 = b;
double r5899874 = a;
double r5899875 = r5899873 * r5899874;
double r5899876 = 4.0;
double r5899877 = r5899875 / r5899876;
double r5899878 = r5899872 - r5899877;
double r5899879 = fma(r5899867, r5899868, r5899878);
return r5899879;
}



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
Initial program 0.1
Simplified0.0
Final simplification0.0
herbie shell --seed 2019162 +o rules:numerics
(FPCore (x y z t a b c)
:name "Diagrams.Solve.Polynomial:quartForm from diagrams-solve-0.1, C"
(+ (- (+ (* x y) (/ (* z t) 16.0)) (/ (* a b) 4.0)) c))