\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}\frac{\frac{v}{-1 - \frac{u}{t1}}}{u + t1}double code(double u, double v, double t1) {
return (((double) (((double) -(t1)) * v)) / ((double) (((double) (t1 + u)) * ((double) (t1 + u)))));
}
double code(double u, double v, double t1) {
return ((v / ((double) (-1.0 - (u / t1)))) / ((double) (u + t1)));
}



Bits error versus u



Bits error versus v



Bits error versus t1
Results
Initial program Error: 18.1 bits
SimplifiedError: 3.3 bits
rmApplied *-un-lft-identityError: 3.3 bits
Applied times-fracError: 1.5 bits
rmApplied associate-*l/Error: 1.3 bits
SimplifiedError: 1.3 bits
Final simplificationError: 1.3 bits
herbie shell --seed 2020200
(FPCore (u v t1)
:name "Rosa's DopplerBench"
:precision binary64
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))