\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}\frac{\left(-t1\right) \cdot \frac{v}{t1 + u}}{t1 + u}double f(double u, double v, double t1) {
double r24643 = t1;
double r24644 = -r24643;
double r24645 = v;
double r24646 = r24644 * r24645;
double r24647 = u;
double r24648 = r24643 + r24647;
double r24649 = r24648 * r24648;
double r24650 = r24646 / r24649;
return r24650;
}
double f(double u, double v, double t1) {
double r24651 = t1;
double r24652 = -r24651;
double r24653 = v;
double r24654 = u;
double r24655 = r24651 + r24654;
double r24656 = r24653 / r24655;
double r24657 = r24652 * r24656;
double r24658 = r24657 / r24655;
return r24658;
}



Bits error versus u



Bits error versus v



Bits error versus t1
Results
Initial program 18.4
rmApplied times-frac1.4
rmApplied associate-*r/1.3
Simplified1.4
Final simplification1.4
herbie shell --seed 2019353 +o rules:numerics
(FPCore (u v t1)
:name "Rosa's DopplerBench"
:precision binary64
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))