\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)
\begin{array}{l}
\mathbf{if}\;x \le -7.615026889800153126326834238619769676443 \cdot 10^{-85}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + \left(t \cdot \left(j \cdot c\right) + \left(-i \cdot \left(j \cdot y\right)\right)\right)\\
\mathbf{elif}\;x \le 1.841813406452417059844069174980175504475 \cdot 10^{-51}:\\
\;\;\;\;\left(\left(y \cdot \left(z \cdot x\right) + \left(-a \cdot \left(x \cdot t\right)\right)\right) - b \cdot \left(c \cdot z - i \cdot a\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \left(y \cdot z - t \cdot a\right) - \left(z \cdot \left(b \cdot c\right) + b \cdot \left(-i \cdot a\right)\right)\right) + j \cdot \left(c \cdot t - i \cdot y\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r497329 = x;
double r497330 = y;
double r497331 = z;
double r497332 = r497330 * r497331;
double r497333 = t;
double r497334 = a;
double r497335 = r497333 * r497334;
double r497336 = r497332 - r497335;
double r497337 = r497329 * r497336;
double r497338 = b;
double r497339 = c;
double r497340 = r497339 * r497331;
double r497341 = i;
double r497342 = r497341 * r497334;
double r497343 = r497340 - r497342;
double r497344 = r497338 * r497343;
double r497345 = r497337 - r497344;
double r497346 = j;
double r497347 = r497339 * r497333;
double r497348 = r497341 * r497330;
double r497349 = r497347 - r497348;
double r497350 = r497346 * r497349;
double r497351 = r497345 + r497350;
return r497351;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j) {
double r497352 = x;
double r497353 = -7.615026889800153e-85;
bool r497354 = r497352 <= r497353;
double r497355 = y;
double r497356 = z;
double r497357 = r497355 * r497356;
double r497358 = t;
double r497359 = a;
double r497360 = r497358 * r497359;
double r497361 = r497357 - r497360;
double r497362 = r497352 * r497361;
double r497363 = b;
double r497364 = c;
double r497365 = r497364 * r497356;
double r497366 = i;
double r497367 = r497366 * r497359;
double r497368 = r497365 - r497367;
double r497369 = r497363 * r497368;
double r497370 = r497362 - r497369;
double r497371 = j;
double r497372 = r497371 * r497364;
double r497373 = r497358 * r497372;
double r497374 = r497371 * r497355;
double r497375 = r497366 * r497374;
double r497376 = -r497375;
double r497377 = r497373 + r497376;
double r497378 = r497370 + r497377;
double r497379 = 1.841813406452417e-51;
bool r497380 = r497352 <= r497379;
double r497381 = r497356 * r497352;
double r497382 = r497355 * r497381;
double r497383 = r497352 * r497358;
double r497384 = r497359 * r497383;
double r497385 = -r497384;
double r497386 = r497382 + r497385;
double r497387 = r497386 - r497369;
double r497388 = r497364 * r497358;
double r497389 = r497366 * r497355;
double r497390 = r497388 - r497389;
double r497391 = r497371 * r497390;
double r497392 = r497387 + r497391;
double r497393 = r497363 * r497364;
double r497394 = r497356 * r497393;
double r497395 = -r497367;
double r497396 = r497363 * r497395;
double r497397 = r497394 + r497396;
double r497398 = r497362 - r497397;
double r497399 = r497398 + r497391;
double r497400 = r497380 ? r497392 : r497399;
double r497401 = r497354 ? r497378 : r497400;
return r497401;
}




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
Results
| Original | 11.7 |
|---|---|
| Target | 15.8 |
| Herbie | 9.1 |
if x < -7.615026889800153e-85Initial program 8.5
rmApplied sub-neg8.5
Applied distribute-lft-in8.5
Simplified9.2
Simplified9.1
if -7.615026889800153e-85 < x < 1.841813406452417e-51Initial program 15.5
rmApplied sub-neg15.5
Applied distribute-lft-in15.5
Simplified15.5
Simplified12.3
rmApplied associate-*l*9.5
if 1.841813406452417e-51 < x Initial program 8.1
rmApplied sub-neg8.1
Applied distribute-lft-in8.1
Simplified8.4
Final simplification9.1
herbie shell --seed 2019306
(FPCore (x y z t a b c i j)
:name "Linear.Matrix:det33 from linear-1.19.1.3"
:precision binary64
:herbie-target
(if (< t -8.1209789191959122e-33) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t -4.7125538182184851e-169) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2) (pow (* i y) 2))) (+ (* c t) (* i y)))) (if (< t -7.63353334603158369e-308) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j))) (if (< t 1.0535888557455487e-139) (+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (/ (* j (- (pow (* c t) 2) (pow (* i y) 2))) (+ (* c t) (* i y)))) (- (* x (- (* z y) (* a t))) (- (* b (- (* z c) (* a i))) (* (- (* c t) (* y i)) j)))))))
(+ (- (* x (- (* y z) (* t a))) (* b (- (* c z) (* i a)))) (* j (- (* c t) (* i y)))))