\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}\left(\frac{-t1}{t1 + u} \cdot \frac{\sqrt[3]{v} \cdot \sqrt[3]{v}}{\sqrt[3]{t1 + u} \cdot \sqrt[3]{t1 + u}}\right) \cdot \frac{\sqrt[3]{v}}{\sqrt[3]{t1 + u}}double code(double u, double v, double t1) {
return ((double) (((double) (((double) -(t1)) * v)) / ((double) (((double) (t1 + u)) * ((double) (t1 + u))))));
}
double code(double u, double v, double t1) {
return ((double) (((double) (((double) (((double) -(t1)) / ((double) (t1 + u)))) * ((double) (((double) (((double) cbrt(v)) * ((double) cbrt(v)))) / ((double) (((double) cbrt(((double) (t1 + u)))) * ((double) cbrt(((double) (t1 + u)))))))))) * ((double) (((double) cbrt(v)) / ((double) cbrt(((double) (t1 + u))))))));
}



Bits error versus u



Bits error versus v



Bits error versus t1
Results
Initial program 18.2
rmApplied times-frac1.3
rmApplied add-cube-cbrt2.0
Applied add-cube-cbrt2.2
Applied times-frac2.2
Applied associate-*r*1.5
Final simplification1.5
herbie shell --seed 2020122
(FPCore (u v t1)
:name "Rosa's DopplerBench"
:precision binary64
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))