\left(\left(3 + \frac{2}{r \cdot r}\right) - \frac{\left(0.125 \cdot \left(3 - 2 \cdot v\right)\right) \cdot \left(\left(\left(w \cdot w\right) \cdot r\right) \cdot r\right)}{1 - v}\right) - 4.5\frac{\frac{2}{r}}{r} + \left(3 - \mathsf{fma}\left(\left(\frac{\sqrt{0.125}}{1 - v} \cdot \left(w \cdot r\right)\right) \cdot \frac{\sqrt{0.125}}{\frac{1}{w \cdot r}}, 3 - 2 \cdot v, 4.5\right)\right)double f(double v, double w, double r) {
double r1333085 = 3.0;
double r1333086 = 2.0;
double r1333087 = r;
double r1333088 = r1333087 * r1333087;
double r1333089 = r1333086 / r1333088;
double r1333090 = r1333085 + r1333089;
double r1333091 = 0.125;
double r1333092 = v;
double r1333093 = r1333086 * r1333092;
double r1333094 = r1333085 - r1333093;
double r1333095 = r1333091 * r1333094;
double r1333096 = w;
double r1333097 = r1333096 * r1333096;
double r1333098 = r1333097 * r1333087;
double r1333099 = r1333098 * r1333087;
double r1333100 = r1333095 * r1333099;
double r1333101 = 1.0;
double r1333102 = r1333101 - r1333092;
double r1333103 = r1333100 / r1333102;
double r1333104 = r1333090 - r1333103;
double r1333105 = 4.5;
double r1333106 = r1333104 - r1333105;
return r1333106;
}
double f(double v, double w, double r) {
double r1333107 = 2.0;
double r1333108 = r;
double r1333109 = r1333107 / r1333108;
double r1333110 = r1333109 / r1333108;
double r1333111 = 3.0;
double r1333112 = 0.125;
double r1333113 = sqrt(r1333112);
double r1333114 = 1.0;
double r1333115 = v;
double r1333116 = r1333114 - r1333115;
double r1333117 = r1333113 / r1333116;
double r1333118 = w;
double r1333119 = r1333118 * r1333108;
double r1333120 = r1333117 * r1333119;
double r1333121 = 1.0;
double r1333122 = r1333121 / r1333119;
double r1333123 = r1333113 / r1333122;
double r1333124 = r1333120 * r1333123;
double r1333125 = r1333107 * r1333115;
double r1333126 = r1333111 - r1333125;
double r1333127 = 4.5;
double r1333128 = fma(r1333124, r1333126, r1333127);
double r1333129 = r1333111 - r1333128;
double r1333130 = r1333110 + r1333129;
return r1333130;
}



Bits error versus v



Bits error versus w



Bits error versus r
Initial program 12.8
Simplified0.4
rmApplied associate-/r*0.4
rmApplied *-un-lft-identity0.4
Applied times-frac0.4
Applied *-un-lft-identity0.4
Applied times-frac0.4
Simplified0.4
rmApplied div-inv0.4
Applied add-sqr-sqrt0.6
Applied times-frac0.5
Applied associate-*r*0.5
Final simplification0.5
herbie shell --seed 2019169 +o rules:numerics
(FPCore (v w r)
:name "Rosa's TurbineBenchmark"
(- (- (+ 3.0 (/ 2.0 (* r r))) (/ (* (* 0.125 (- 3.0 (* 2.0 v))) (* (* (* w w) r) r)) (- 1.0 v))) 4.5))