\left(\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - \left(j \cdot 27\right) \cdot k
\begin{array}{l}
\mathbf{if}\;t \le -3.776984382821296984516260974198729562529 \cdot 10^{-79}:\\
\;\;\;\;\left(\left(c \cdot b + \left(\left(x \cdot \left(y \cdot z\right)\right) \cdot 18 - 4 \cdot a\right) \cdot t\right) - \left(x \cdot 4\right) \cdot i\right) - j \cdot \left(27 \cdot k\right)\\
\mathbf{elif}\;t \le 7.289027731463515002673382915959472142239 \cdot 10^{-83}:\\
\;\;\;\;\left(\left(c \cdot b + \left(\left(18 \cdot x\right) \cdot \left(y \cdot \left(t \cdot z\right)\right) - \left(4 \cdot a\right) \cdot t\right)\right) - \left(x \cdot 4\right) \cdot i\right) - \left(k \cdot j\right) \cdot 27\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\left(18 \cdot \left(t \cdot \left(x \cdot \left(y \cdot z\right)\right)\right) - \left(4 \cdot a\right) \cdot t\right) + c \cdot b\right) - \left(x \cdot 4\right) \cdot i\right) - j \cdot \left(27 \cdot k\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r39529321 = x;
double r39529322 = 18.0;
double r39529323 = r39529321 * r39529322;
double r39529324 = y;
double r39529325 = r39529323 * r39529324;
double r39529326 = z;
double r39529327 = r39529325 * r39529326;
double r39529328 = t;
double r39529329 = r39529327 * r39529328;
double r39529330 = a;
double r39529331 = 4.0;
double r39529332 = r39529330 * r39529331;
double r39529333 = r39529332 * r39529328;
double r39529334 = r39529329 - r39529333;
double r39529335 = b;
double r39529336 = c;
double r39529337 = r39529335 * r39529336;
double r39529338 = r39529334 + r39529337;
double r39529339 = r39529321 * r39529331;
double r39529340 = i;
double r39529341 = r39529339 * r39529340;
double r39529342 = r39529338 - r39529341;
double r39529343 = j;
double r39529344 = 27.0;
double r39529345 = r39529343 * r39529344;
double r39529346 = k;
double r39529347 = r39529345 * r39529346;
double r39529348 = r39529342 - r39529347;
return r39529348;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r39529349 = t;
double r39529350 = -3.776984382821297e-79;
bool r39529351 = r39529349 <= r39529350;
double r39529352 = c;
double r39529353 = b;
double r39529354 = r39529352 * r39529353;
double r39529355 = x;
double r39529356 = y;
double r39529357 = z;
double r39529358 = r39529356 * r39529357;
double r39529359 = r39529355 * r39529358;
double r39529360 = 18.0;
double r39529361 = r39529359 * r39529360;
double r39529362 = 4.0;
double r39529363 = a;
double r39529364 = r39529362 * r39529363;
double r39529365 = r39529361 - r39529364;
double r39529366 = r39529365 * r39529349;
double r39529367 = r39529354 + r39529366;
double r39529368 = r39529355 * r39529362;
double r39529369 = i;
double r39529370 = r39529368 * r39529369;
double r39529371 = r39529367 - r39529370;
double r39529372 = j;
double r39529373 = 27.0;
double r39529374 = k;
double r39529375 = r39529373 * r39529374;
double r39529376 = r39529372 * r39529375;
double r39529377 = r39529371 - r39529376;
double r39529378 = 7.289027731463515e-83;
bool r39529379 = r39529349 <= r39529378;
double r39529380 = r39529360 * r39529355;
double r39529381 = r39529349 * r39529357;
double r39529382 = r39529356 * r39529381;
double r39529383 = r39529380 * r39529382;
double r39529384 = r39529364 * r39529349;
double r39529385 = r39529383 - r39529384;
double r39529386 = r39529354 + r39529385;
double r39529387 = r39529386 - r39529370;
double r39529388 = r39529374 * r39529372;
double r39529389 = r39529388 * r39529373;
double r39529390 = r39529387 - r39529389;
double r39529391 = r39529349 * r39529359;
double r39529392 = r39529360 * r39529391;
double r39529393 = r39529392 - r39529384;
double r39529394 = r39529393 + r39529354;
double r39529395 = r39529394 - r39529370;
double r39529396 = r39529395 - r39529376;
double r39529397 = r39529379 ? r39529390 : r39529396;
double r39529398 = r39529351 ? r39529377 : r39529397;
return r39529398;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus i




Bits error versus j




Bits error versus k
Results
| Original | 5.9 |
|---|---|
| Target | 1.7 |
| Herbie | 2.2 |
if t < -3.776984382821297e-79Initial program 3.0
rmApplied associate-*l*8.2
rmApplied associate-*l*9.4
rmApplied associate-*l*9.3
Taylor expanded around inf 3.0
Simplified3.0
if -3.776984382821297e-79 < t < 7.289027731463515e-83Initial program 9.0
rmApplied associate-*l*4.6
rmApplied associate-*l*1.3
rmApplied associate-*l*1.3
Taylor expanded around 0 1.2
if 7.289027731463515e-83 < t Initial program 3.0
rmApplied associate-*l*7.1
rmApplied associate-*l*8.8
rmApplied associate-*l*8.9
Taylor expanded around inf 3.0
Final simplification2.2
herbie shell --seed 2019179
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, E"
:herbie-target
(if (< t -1.6210815397541398e-69) (- (- (* (* 18.0 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4.0)) (- (* (* k j) 27.0) (* c b))) (if (< t 165.68027943805222) (+ (- (* (* 18.0 y) (* x (* z t))) (* (+ (* a t) (* i x)) 4.0)) (- (* c b) (* 27.0 (* k j)))) (- (- (* (* 18.0 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4.0)) (- (* (* k j) 27.0) (* c b)))))
(- (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) (* (* j 27.0) k)))