x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -7.423345970921716 \cdot 10^{+250}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{t}, z, y\right) - y \cdot \frac{z}{t}\\
\mathbf{elif}\;t \le 1.6895069144640092 \cdot 10^{+105}:\\
\;\;\;\;\mathsf{fma}\left(\frac{1}{a - t} \cdot \left(z - t\right), y - x, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{t}, z, y\right) - y \cdot \frac{z}{t}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r28240452 = x;
double r28240453 = y;
double r28240454 = r28240453 - r28240452;
double r28240455 = z;
double r28240456 = t;
double r28240457 = r28240455 - r28240456;
double r28240458 = r28240454 * r28240457;
double r28240459 = a;
double r28240460 = r28240459 - r28240456;
double r28240461 = r28240458 / r28240460;
double r28240462 = r28240452 + r28240461;
return r28240462;
}
double f(double x, double y, double z, double t, double a) {
double r28240463 = t;
double r28240464 = -7.423345970921716e+250;
bool r28240465 = r28240463 <= r28240464;
double r28240466 = x;
double r28240467 = r28240466 / r28240463;
double r28240468 = z;
double r28240469 = y;
double r28240470 = fma(r28240467, r28240468, r28240469);
double r28240471 = r28240468 / r28240463;
double r28240472 = r28240469 * r28240471;
double r28240473 = r28240470 - r28240472;
double r28240474 = 1.6895069144640092e+105;
bool r28240475 = r28240463 <= r28240474;
double r28240476 = 1.0;
double r28240477 = a;
double r28240478 = r28240477 - r28240463;
double r28240479 = r28240476 / r28240478;
double r28240480 = r28240468 - r28240463;
double r28240481 = r28240479 * r28240480;
double r28240482 = r28240469 - r28240466;
double r28240483 = fma(r28240481, r28240482, r28240466);
double r28240484 = r28240475 ? r28240483 : r28240473;
double r28240485 = r28240465 ? r28240473 : r28240484;
return r28240485;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 23.9 |
|---|---|
| Target | 9.2 |
| Herbie | 10.5 |
if t < -7.423345970921716e+250 or 1.6895069144640092e+105 < t Initial program 45.0
Simplified22.0
Taylor expanded around inf 25.1
Simplified16.4
if -7.423345970921716e+250 < t < 1.6895069144640092e+105Initial program 17.2
Simplified8.6
rmApplied clear-num8.7
rmApplied div-inv8.7
Applied add-cube-cbrt8.7
Applied times-frac8.7
Simplified8.7
Simplified8.7
Final simplification10.5
herbie shell --seed 2019168 +o rules:numerics
(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))))