\frac{\left(-t1\right) \cdot v}{\left(t1 + u\right) \cdot \left(t1 + u\right)}\frac{v \cdot \left(\frac{-1}{t1 + u} \cdot t1\right)}{t1 + u}double f(double u, double v, double t1) {
double r31063 = t1;
double r31064 = -r31063;
double r31065 = v;
double r31066 = r31064 * r31065;
double r31067 = u;
double r31068 = r31063 + r31067;
double r31069 = r31068 * r31068;
double r31070 = r31066 / r31069;
return r31070;
}
double f(double u, double v, double t1) {
double r31071 = v;
double r31072 = -1.0;
double r31073 = t1;
double r31074 = u;
double r31075 = r31073 + r31074;
double r31076 = r31072 / r31075;
double r31077 = r31076 * r31073;
double r31078 = r31071 * r31077;
double r31079 = r31078 / r31075;
return r31079;
}



Bits error versus u



Bits error versus v



Bits error versus t1
Results
Initial program 18.2
rmApplied times-frac1.5
rmApplied *-un-lft-identity1.5
Applied distribute-lft-neg-in1.5
Applied associate-/l*1.7
rmApplied div-inv1.8
Applied associate-/r*1.6
Simplified1.6
rmApplied associate-*r/1.3
Simplified1.4
Final simplification1.4
herbie shell --seed 2020033
(FPCore (u v t1)
:name "Rosa's DopplerBench"
:precision binary64
(/ (* (- t1) v) (* (+ t1 u) (+ t1 u))))