\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\left(\left(3 + \frac{2}{r \cdot r}\right) - {\left(\frac{\sqrt{\frac{1 - v}{0.125 \cdot \left(3 - 2 \cdot v\right)}}}{\left|w \cdot r\right|}\right)}^{\left(-2\right)}\right) - 4.5double f(double v, double w, double r) {
double r30240 = 3.0;
double r30241 = 2.0;
double r30242 = r;
double r30243 = r30242 * r30242;
double r30244 = r30241 / r30243;
double r30245 = r30240 + r30244;
double r30246 = 0.125;
double r30247 = v;
double r30248 = r30241 * r30247;
double r30249 = r30240 - r30248;
double r30250 = r30246 * r30249;
double r30251 = w;
double r30252 = r30251 * r30251;
double r30253 = r30252 * r30242;
double r30254 = r30253 * r30242;
double r30255 = r30250 * r30254;
double r30256 = 1.0;
double r30257 = r30256 - r30247;
double r30258 = r30255 / r30257;
double r30259 = r30245 - r30258;
double r30260 = 4.5;
double r30261 = r30259 - r30260;
return r30261;
}
double f(double v, double w, double r) {
double r30262 = 3.0;
double r30263 = 2.0;
double r30264 = r;
double r30265 = r30264 * r30264;
double r30266 = r30263 / r30265;
double r30267 = r30262 + r30266;
double r30268 = 1.0;
double r30269 = v;
double r30270 = r30268 - r30269;
double r30271 = 0.125;
double r30272 = r30263 * r30269;
double r30273 = r30262 - r30272;
double r30274 = r30271 * r30273;
double r30275 = r30270 / r30274;
double r30276 = sqrt(r30275);
double r30277 = w;
double r30278 = r30277 * r30264;
double r30279 = fabs(r30278);
double r30280 = r30276 / r30279;
double r30281 = 2.0;
double r30282 = -r30281;
double r30283 = pow(r30280, r30282);
double r30284 = r30267 - r30283;
double r30285 = 4.5;
double r30286 = r30284 - r30285;
return r30286;
}



Bits error versus v



Bits error versus w



Bits error versus r
Results
Initial program 12.5
rmApplied add-sqr-sqrt12.5
Simplified12.5
Simplified6.7
rmApplied clear-num6.7
Simplified0.4
rmApplied add-sqr-sqrt0.5
Applied unpow-prod-down0.5
Applied add-sqr-sqrt0.6
Applied times-frac0.5
Simplified0.4
Simplified0.4
rmApplied pow10.4
Applied pow10.4
Applied pow-prod-up0.4
Applied pow-flip0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020081
(FPCore (v w r)
:name "Rosa's TurbineBenchmark"
:precision binary64
(- (- (+ 3 (/ 2 (* r r))) (/ (* (* 0.125 (- 3 (* 2 v))) (* (* (* w w) r) r)) (- 1 v))) 4.5))