double code(double x, double y, double z, double t, double a) {
return ((double) (x + ((double) (y * ((double) (((double) (z - t)) / ((double) (z - a))))))));
}
double code(double x, double y, double z, double t, double a) {
double VAR;
if (((((double) (((double) (z - t)) / ((double) (z - a)))) <= 5.522657576300667e-29) || !(((double) (((double) (z - t)) / ((double) (z - a)))) <= 1.1772774244599477e+63))) {
VAR = ((double) (x + ((double) (((double) (z - t)) * ((double) (y / ((double) (z - a))))))));
} else {
VAR = ((double) (x + ((double) (y * ((double) cbrt(((double) pow(((double) (((double) (z - t)) / ((double) (z - a)))), 3.0))))))));
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 1.2 |
|---|---|
| Target | 1.1 |
| Herbie | 1.2 |
if (/ (- z t) (- z a)) < 5.52265757630066731e-29 or 1.17727742445994768e63 < (/ (- z t) (- z a)) Initial program 2.1
rmApplied add-cube-cbrt2.5
Applied associate-*l*2.5
Simplified1.5
rmApplied pow11.5
Applied pow11.5
Applied pow-prod-down1.5
Applied pow11.5
Applied pow11.5
Applied pow-prod-down1.5
Applied pow-prod-down1.5
Simplified2.1
if 5.52265757630066731e-29 < (/ (- z t) (- z a)) < 1.17727742445994768e63Initial program 0.0
rmApplied add-cbrt-cube24.6
Applied add-cbrt-cube46.8
Applied cbrt-undiv46.8
Simplified0.1
Final simplification1.2
herbie shell --seed 2020180
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisLine from plot-0.2.3.4, A"
:precision binary64
:herbie-target
(+ x (/ y (/ (- z a) (- z t))))
(+ x (* y (/ (- z t) (- z a)))))