x \cdot \log \left(\frac{x}{y}\right) - z\left(\log \left(\frac{\sqrt[3]{x}}{\sqrt[3]{y}}\right) \cdot x + x \cdot \left(\log \left(\sqrt[3]{x} \cdot \sqrt[3]{x}\right) - \log \left(\sqrt[3]{y} \cdot \sqrt[3]{y}\right)\right)\right) - zdouble f(double x, double y, double z) {
double r11516151 = x;
double r11516152 = y;
double r11516153 = r11516151 / r11516152;
double r11516154 = log(r11516153);
double r11516155 = r11516151 * r11516154;
double r11516156 = z;
double r11516157 = r11516155 - r11516156;
return r11516157;
}
double f(double x, double y, double z) {
double r11516158 = x;
double r11516159 = cbrt(r11516158);
double r11516160 = y;
double r11516161 = cbrt(r11516160);
double r11516162 = r11516159 / r11516161;
double r11516163 = log(r11516162);
double r11516164 = r11516163 * r11516158;
double r11516165 = r11516159 * r11516159;
double r11516166 = log(r11516165);
double r11516167 = r11516161 * r11516161;
double r11516168 = log(r11516167);
double r11516169 = r11516166 - r11516168;
double r11516170 = r11516158 * r11516169;
double r11516171 = r11516164 + r11516170;
double r11516172 = z;
double r11516173 = r11516171 - r11516172;
return r11516173;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 14.6 |
|---|---|
| Target | 7.5 |
| Herbie | 0.3 |
Initial program 14.6
rmApplied add-cube-cbrt14.6
Applied add-cube-cbrt14.6
Applied times-frac14.6
Applied log-prod3.3
Applied distribute-rgt-in3.3
Simplified3.3
rmApplied frac-times3.3
Applied log-div0.3
Final simplification0.3
herbie shell --seed 2019158
(FPCore (x y z)
:name "Numeric.SpecFunctions.Extra:bd0 from math-functions-0.1.5.2"
:herbie-target
(if (< y 7.595077799083773e-308) (- (* x (log (/ x y))) z) (- (* x (- (log x) (log y))) z))
(- (* x (log (/ x y))) z))