x + \frac{\left(y - x\right) \cdot \left(z - t\right)}{a - t}\begin{array}{l}
\mathbf{if}\;a \le -1.017349515652042311145981409869525810825 \cdot 10^{-103}:\\
\;\;\;\;x + \left(y - x\right) \cdot \left(\left(z - t\right) \cdot \frac{1}{a - t}\right)\\
\mathbf{elif}\;a \le -1.05656481426195461736762491417520109376 \cdot 10^{-182}:\\
\;\;\;\;\left(y + \frac{x \cdot z}{t}\right) - \frac{z \cdot y}{t}\\
\mathbf{elif}\;a \le -5.244444911381475218279391153195092082915 \cdot 10^{-267}:\\
\;\;\;\;x + \frac{y - x}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{z - t}{\sqrt[3]{a - t}}\\
\mathbf{elif}\;a \le 1.146658007406096389473970469097263702452 \cdot 10^{-6}:\\
\;\;\;\;\left(y + \frac{x \cdot z}{t}\right) - \frac{z \cdot y}{t}\\
\mathbf{else}:\\
\;\;\;\;x + \left(y - x\right) \cdot \left(\frac{1}{\frac{a - t}{z}} - \frac{t}{a - t}\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r490221 = x;
double r490222 = y;
double r490223 = r490222 - r490221;
double r490224 = z;
double r490225 = t;
double r490226 = r490224 - r490225;
double r490227 = r490223 * r490226;
double r490228 = a;
double r490229 = r490228 - r490225;
double r490230 = r490227 / r490229;
double r490231 = r490221 + r490230;
return r490231;
}
double f(double x, double y, double z, double t, double a) {
double r490232 = a;
double r490233 = -1.0173495156520423e-103;
bool r490234 = r490232 <= r490233;
double r490235 = x;
double r490236 = y;
double r490237 = r490236 - r490235;
double r490238 = z;
double r490239 = t;
double r490240 = r490238 - r490239;
double r490241 = 1.0;
double r490242 = r490232 - r490239;
double r490243 = r490241 / r490242;
double r490244 = r490240 * r490243;
double r490245 = r490237 * r490244;
double r490246 = r490235 + r490245;
double r490247 = -1.0565648142619546e-182;
bool r490248 = r490232 <= r490247;
double r490249 = r490235 * r490238;
double r490250 = r490249 / r490239;
double r490251 = r490236 + r490250;
double r490252 = r490238 * r490236;
double r490253 = r490252 / r490239;
double r490254 = r490251 - r490253;
double r490255 = -5.244444911381475e-267;
bool r490256 = r490232 <= r490255;
double r490257 = cbrt(r490242);
double r490258 = r490257 * r490257;
double r490259 = r490237 / r490258;
double r490260 = r490240 / r490257;
double r490261 = r490259 * r490260;
double r490262 = r490235 + r490261;
double r490263 = 1.1466580074060964e-06;
bool r490264 = r490232 <= r490263;
double r490265 = r490242 / r490238;
double r490266 = r490241 / r490265;
double r490267 = r490239 / r490242;
double r490268 = r490266 - r490267;
double r490269 = r490237 * r490268;
double r490270 = r490235 + r490269;
double r490271 = r490264 ? r490254 : r490270;
double r490272 = r490256 ? r490262 : r490271;
double r490273 = r490248 ? r490254 : r490272;
double r490274 = r490234 ? r490246 : r490273;
return r490274;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.3 |
|---|---|
| Target | 9.1 |
| Herbie | 12.6 |
if a < -1.0173495156520423e-103Initial program 22.3
rmApplied *-un-lft-identity22.3
Applied times-frac8.6
Simplified8.6
rmApplied div-inv8.7
if -1.0173495156520423e-103 < a < -1.0565648142619546e-182 or -5.244444911381475e-267 < a < 1.1466580074060964e-06Initial program 27.9
Taylor expanded around inf 20.3
if -1.0565648142619546e-182 < a < -5.244444911381475e-267Initial program 28.3
rmApplied add-cube-cbrt29.0
Applied times-frac22.2
if 1.1466580074060964e-06 < a Initial program 22.1
rmApplied *-un-lft-identity22.1
Applied times-frac6.7
Simplified6.7
rmApplied div-sub6.7
rmApplied clear-num6.7
Final simplification12.6
herbie shell --seed 2019297
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:linMap from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< a -1.6153062845442575e-142) (+ x (* (/ (- y x) 1) (/ (- z t) (- a t)))) (if (< a 3.7744031700831742e-182) (- y (* (/ z t) (- y x))) (+ x (* (/ (- y x) 1) (/ (- z t) (- a t))))))
(+ x (/ (* (- y x) (- z t)) (- a t))))