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.5335432679341662 \cdot 10^{-301}:\\
\;\;\;\;\frac{y - x}{\frac{a - t}{z - t}} + x\\
\mathbf{elif}\;x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t} \le 0.0:\\
\;\;\;\;\left(\frac{z \cdot x}{t} + y\right) - \frac{z \cdot y}{t}\\
\mathbf{else}:\\
\;\;\;\;\frac{y - x}{\frac{a - t}{z - t}} + x\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r32332349 = x;
double r32332350 = y;
double r32332351 = r32332350 - r32332349;
double r32332352 = z;
double r32332353 = t;
double r32332354 = r32332352 - r32332353;
double r32332355 = r32332351 * r32332354;
double r32332356 = a;
double r32332357 = r32332356 - r32332353;
double r32332358 = r32332355 / r32332357;
double r32332359 = r32332349 + r32332358;
return r32332359;
}
double f(double x, double y, double z, double t, double a) {
double r32332360 = x;
double r32332361 = y;
double r32332362 = r32332361 - r32332360;
double r32332363 = z;
double r32332364 = t;
double r32332365 = r32332363 - r32332364;
double r32332366 = r32332362 * r32332365;
double r32332367 = a;
double r32332368 = r32332367 - r32332364;
double r32332369 = r32332366 / r32332368;
double r32332370 = r32332360 + r32332369;
double r32332371 = -1.5335432679341662e-301;
bool r32332372 = r32332370 <= r32332371;
double r32332373 = r32332368 / r32332365;
double r32332374 = r32332362 / r32332373;
double r32332375 = r32332374 + r32332360;
double r32332376 = 0.0;
bool r32332377 = r32332370 <= r32332376;
double r32332378 = r32332363 * r32332360;
double r32332379 = r32332378 / r32332364;
double r32332380 = r32332379 + r32332361;
double r32332381 = r32332363 * r32332361;
double r32332382 = r32332381 / r32332364;
double r32332383 = r32332380 - r32332382;
double r32332384 = r32332377 ? r32332383 : r32332375;
double r32332385 = r32332372 ? r32332375 : r32332384;
return r32332385;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 23.9 |
|---|---|
| Target | 9.2 |
| Herbie | 8.2 |
if (+ x (/ (* (- y x) (- z t)) (- a t))) < -1.5335432679341662e-301 or 0.0 < (+ x (/ (* (- y x) (- z t)) (- a t))) Initial program 20.5
rmApplied associate-/l*7.3
if -1.5335432679341662e-301 < (+ x (/ (* (- y x) (- z t)) (- a t))) < 0.0Initial program 60.8
Taylor expanded around inf 17.6
Final simplification8.2
herbie shell --seed 2019168
(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))))