x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t}\begin{array}{l}
\mathbf{if}\;x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t} \le -1.3435650229451346 \cdot 10^{-276}:\\
\;\;\;\;\frac{y - x}{\frac{a}{z - t} - \frac{1}{\frac{z - t}{t}}} + x\\
\mathbf{elif}\;x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t} \le 0.0:\\
\;\;\;\;\left(y + \frac{z \cdot x}{t}\right) - \frac{z \cdot y}{t}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{\frac{a}{z - t} - \frac{t}{z - t}}{y - x}} + x\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r33819530 = x;
double r33819531 = y;
double r33819532 = r33819531 - r33819530;
double r33819533 = z;
double r33819534 = t;
double r33819535 = r33819533 - r33819534;
double r33819536 = r33819532 * r33819535;
double r33819537 = a;
double r33819538 = r33819537 - r33819534;
double r33819539 = r33819536 / r33819538;
double r33819540 = r33819530 + r33819539;
return r33819540;
}
double f(double x, double y, double z, double t, double a) {
double r33819541 = x;
double r33819542 = y;
double r33819543 = r33819542 - r33819541;
double r33819544 = z;
double r33819545 = t;
double r33819546 = r33819544 - r33819545;
double r33819547 = r33819543 * r33819546;
double r33819548 = a;
double r33819549 = r33819548 - r33819545;
double r33819550 = r33819547 / r33819549;
double r33819551 = r33819541 + r33819550;
double r33819552 = -1.3435650229451346e-276;
bool r33819553 = r33819551 <= r33819552;
double r33819554 = r33819548 / r33819546;
double r33819555 = 1.0;
double r33819556 = r33819546 / r33819545;
double r33819557 = r33819555 / r33819556;
double r33819558 = r33819554 - r33819557;
double r33819559 = r33819543 / r33819558;
double r33819560 = r33819559 + r33819541;
double r33819561 = 0.0;
bool r33819562 = r33819551 <= r33819561;
double r33819563 = r33819544 * r33819541;
double r33819564 = r33819563 / r33819545;
double r33819565 = r33819542 + r33819564;
double r33819566 = r33819544 * r33819542;
double r33819567 = r33819566 / r33819545;
double r33819568 = r33819565 - r33819567;
double r33819569 = r33819545 / r33819546;
double r33819570 = r33819554 - r33819569;
double r33819571 = r33819570 / r33819543;
double r33819572 = r33819555 / r33819571;
double r33819573 = r33819572 + r33819541;
double r33819574 = r33819562 ? r33819568 : r33819573;
double r33819575 = r33819553 ? r33819560 : r33819574;
return r33819575;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.0 |
|---|---|
| Target | 9.6 |
| Herbie | 8.7 |
if (+ x (/ (* (- y x) (- z t)) (- a t))) < -1.3435650229451346e-276Initial program 20.3
rmApplied associate-/l*7.6
rmApplied div-sub7.6
rmApplied clear-num7.6
if -1.3435650229451346e-276 < (+ x (/ (* (- y x) (- z t)) (- a t))) < 0.0Initial program 59.5
Taylor expanded around inf 19.8
if 0.0 < (+ x (/ (* (- y x) (- z t)) (- a t))) Initial program 21.2
rmApplied associate-/l*7.7
rmApplied div-sub7.7
rmApplied clear-num7.8
Final simplification8.7
herbie shell --seed 2019162
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:linMap from Chart-1.5.3"
:herbie-target
(if (< a -1.6153062845442575e-142) (+ x (* (/ (- y x) 1) (/ (- z t) (- a t)))) (if (< a 3.774403170083174e-182) (- y (* (/ z t) (- y x))) (+ x (* (/ (- y x) 1) (/ (- z t) (- a t))))))
(+ x (/ (* (- y x) (- z t)) (- a t))))