\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}\frac{\left(-\sqrt[3]{t1}\right) \cdot \sqrt[3]{t1}}{\sqrt[3]{u + t1} \cdot \sqrt[3]{u + t1}} \cdot \left(\frac{\sqrt[3]{t1}}{\sqrt[3]{u + t1}} \cdot \frac{v}{u + t1}\right)double f(double u, double v, double t1) {
double r949047 = t1;
double r949048 = -r949047;
double r949049 = v;
double r949050 = r949048 * r949049;
double r949051 = u;
double r949052 = r949047 + r949051;
double r949053 = r949052 * r949052;
double r949054 = r949050 / r949053;
return r949054;
}
double f(double u, double v, double t1) {
double r949055 = t1;
double r949056 = cbrt(r949055);
double r949057 = -r949056;
double r949058 = r949057 * r949056;
double r949059 = u;
double r949060 = r949059 + r949055;
double r949061 = cbrt(r949060);
double r949062 = r949061 * r949061;
double r949063 = r949058 / r949062;
double r949064 = r949056 / r949061;
double r949065 = v;
double r949066 = r949065 / r949060;
double r949067 = r949064 * r949066;
double r949068 = r949063 * r949067;
return r949068;
}



Bits error versus u



Bits error versus v



Bits error versus t1
Results
Initial program 17.9
rmApplied times-frac1.4
rmApplied add-cube-cbrt2.1
Applied add-cube-cbrt1.7
Applied distribute-rgt-neg-in1.7
Applied times-frac1.7
Applied associate-*l*1.1
Final simplification1.1
herbie shell --seed 2019192 +o rules:numerics
(FPCore (u v t1)
:name "Rosa's DopplerBench"
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))