Linear.Quaternion:$c/ from linear-1.19.1.3, C

Time bar (total: 3.4s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage

analyze0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
100%99.9%0%0.1%0%0%0%1
Compiler

Compiled 17 to 11 computations (35.3% saved)

sample1.6s (45.5%)

Memory
35.7MiB live, 2 388.3MiB allocated; 616ms collecting garbage
Samples
626.0ms2 495×1valid
438.0ms5 701×0valid
13.0ms60×2valid
Precisions
Click to see histograms. Total time spent on operations: 682.0ms
ival-mult: 333.0ms (48.8% of total)
adjust: 166.0ms (24.3% of total)
ival-sub: 106.0ms (15.5% of total)
ival-add: 68.0ms (10% of total)
ival-true: 6.0ms (0.9% of total)
ival-assert: 3.0ms (0.4% of total)
Bogosity

explain137.0ms (4%)

Memory
26.9MiB live, 304.8MiB allocated; 33ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
941(2.168614828377123e-245 7.679488631138716e-133 -1.1215105965101721e-191)0-(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
180-0-(-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z))
140-0-(+.f64 (*.f64 x y) (*.f64 y y))
00-0-z
00-0-(*.f64 x y)
00-0-y
00-0-(*.f64 y y)
00-0-(*.f64 y z)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
-.f64(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))nan-rescue560
(-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z))overflow82
(+.f64 (*.f64 x y) (*.f64 y y))overflow77
(*.f64 y z)overflow37
(*.f64 y y)overflow61
(*.f64 x y)overflow44
(*.f64 y y)overflow61
-.f64(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))cancellation390
-.f64(-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z))nan-rescue180
(+.f64 (*.f64 x y) (*.f64 y y))overflow77
(*.f64 y y)overflow61
(*.f64 x y)overflow44
(*.f64 y z)overflow37
+.f64(+.f64 (*.f64 x y) (*.f64 y y))nan-rescue140
(*.f64 x y)overflow44
(*.f64 y y)overflow61
Confusion
Predicted +Predicted -
+1010
-1154
Precision
0.9901960784313726
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+10100
-10154
Precision?
0.9901960784313726
Recall?
1.0
Freqs
test
numberfreq
0154
180
219
33
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
28.0ms350×0valid
24.0ms162×1valid
Compiler

Compiled 109 to 31 computations (71.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 33.0ms
ival-mult: 13.0ms (40% of total)
ival-sub: 8.0ms (24.6% of total)
adjust: 6.0ms (18.5% of total)
ival-add: 5.0ms (15.4% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)

preprocess249.0ms (7.3%)

Memory
21.2MiB live, 309.9MiB allocated; 113ms collecting garbage
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
040121
115292
258182
3194163
4516847
0915
01513
13311
21129
33267
49675
526975
086295
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Outputs
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
(*.f64 (-.f64 x z) y)
Symmetry

(negabs y)

Compiler

Compiled 15 to 9 computations (40% saved)

eval0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage
Compiler

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.0MiB live, 1.0MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
61.7%
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Compiler

Compiled 15 to 9 computations (40% saved)

series11.0ms (0.3%)

Memory
-22.9MiB live, 24.1MiB allocated; 2ms collecting garbage
Counts
9 → 30
Calls
Call 1
Inputs
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
(-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z))
(+.f64 (*.f64 x y) (*.f64 y y))
(*.f64 x y)
x
y
(*.f64 y y)
(*.f64 y z)
z
Outputs
(* -1 (* y z))
(- (* x y) (* y z))
(- (pow y 2) (* y z))
(- (+ (* x y) (pow y 2)) (* y z))
(pow y 2)
(+ (* x y) (pow y 2))
(* x y)
x
(* x (+ y (* -1 (/ (* y z) x))))
(* x (- (+ y (/ (pow y 2) x)) (/ (* y z) x)))
(* x (+ y (/ (pow y 2) x)))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (pow y 2) (* y z)) x)))))
(* -1 (* x (+ (* -1 y) (* -1 (/ (pow y 2) x)))))
(* y (- x z))
(* y (- (+ x y) z))
(* y (+ x y))
y
(* y z)
(* (pow y 2) (- (+ 1 (/ x y)) (/ z y)))
(* (pow y 2) (+ 1 (/ x y)))
(* -1 (* y (- (* -1 x) (* -1 z))))
(* (pow y 2) (+ 1 (* -1 (/ (- (* -1 x) (* -1 z)) y))))
(+ (* -1 (* y z)) (* x y))
(+ (* -1 (* y z)) (+ (* x y) (pow y 2)))
z
(* z (- (/ (* x y) z) y))
(* z (- (+ (/ (* x y) z) (/ (pow y 2) z)) y))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (- (* -1 (/ (+ (* x y) (pow y 2)) z)) (* -1 y))))
Calls

9 calls:

TimeVariablePointExpression
2.0ms
x
@inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (- (+ (* x y) (* y y)) (* y z)) (+ (* x y) (* y y)) (* x y) x y (* y y) (* y z) z)
2.0ms
y
@inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (- (+ (* x y) (* y y)) (* y z)) (+ (* x y) (* y y)) (* x y) x y (* y y) (* y z) z)
1.0ms
y
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (- (+ (* x y) (* y y)) (* y z)) (+ (* x y) (* y y)) (* x y) x y (* y y) (* y z) z)
1.0ms
x
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (- (+ (* x y) (* y y)) (* y z)) (+ (* x y) (* y y)) (* x y) x y (* y y) (* y z) z)
1.0ms
x
@0
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (- (+ (* x y) (* y y)) (* y z)) (+ (* x y) (* y y)) (* x y) x y (* y y) (* y z) z)

simplify156.0ms (4.6%)

Memory
22.7MiB live, 208.9MiB allocated; 18ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
075205
1242181
2812177
32905177
46551177
08130174
Stop Event
iter limit
node limit
Counts
30 → 27
Calls
Call 1
Inputs
(* -1 (* y z))
(- (* x y) (* y z))
(- (pow y 2) (* y z))
(- (+ (* x y) (pow y 2)) (* y z))
(pow y 2)
(+ (* x y) (pow y 2))
(* x y)
x
(* x (+ y (* -1 (/ (* y z) x))))
(* x (- (+ y (/ (pow y 2) x)) (/ (* y z) x)))
(* x (+ y (/ (pow y 2) x)))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (pow y 2) (* y z)) x)))))
(* -1 (* x (+ (* -1 y) (* -1 (/ (pow y 2) x)))))
(* y (- x z))
(* y (- (+ x y) z))
(* y (+ x y))
y
(* y z)
(* (pow y 2) (- (+ 1 (/ x y)) (/ z y)))
(* (pow y 2) (+ 1 (/ x y)))
(* -1 (* y (- (* -1 x) (* -1 z))))
(* (pow y 2) (+ 1 (* -1 (/ (- (* -1 x) (* -1 z)) y))))
(+ (* -1 (* y z)) (* x y))
(+ (* -1 (* y z)) (+ (* x y) (pow y 2)))
z
(* z (- (/ (* x y) z) y))
(* z (- (+ (/ (* x y) z) (/ (pow y 2) z)) y))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (- (* -1 (/ (+ (* x y) (pow y 2)) z)) (* -1 y))))
Outputs
(* -1 (* y z))
(*.f64 (neg.f64 z) y)
(- (* x y) (* y z))
(*.f64 (-.f64 x z) y)
(- (pow y 2) (* y z))
(*.f64 (-.f64 y z) y)
(- (+ (* x y) (pow y 2)) (* y z))
(*.f64 (-.f64 (+.f64 y x) z) y)
(pow y 2)
(*.f64 y y)
(+ (* x y) (pow y 2))
(*.f64 (+.f64 y x) y)
(* x y)
(*.f64 y x)
x
(* x (+ y (* -1 (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(* x (- (+ y (/ (pow y 2) x)) (/ (* y z) x)))
(*.f64 (-.f64 (+.f64 y x) z) y)
(* x (+ y (/ (pow y 2) x)))
(*.f64 (+.f64 y x) y)
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(* -1 (* x (+ (* -1 y) (* -1 (/ (- (pow y 2) (* y z)) x)))))
(*.f64 (-.f64 (+.f64 y x) z) y)
(* -1 (* x (+ (* -1 y) (* -1 (/ (pow y 2) x)))))
(*.f64 (+.f64 y x) y)
(* y (- x z))
(*.f64 (-.f64 x z) y)
(* y (- (+ x y) z))
(*.f64 (-.f64 (+.f64 y x) z) y)
(* y (+ x y))
(*.f64 (+.f64 y x) y)
y
(* y z)
(*.f64 z y)
(* (pow y 2) (- (+ 1 (/ x y)) (/ z y)))
(*.f64 (fma.f64 (/.f64 (-.f64 x z) y) y y) y)
(* (pow y 2) (+ 1 (/ x y)))
(*.f64 (fma.f64 (/.f64 x y) y y) y)
(* -1 (* y (- (* -1 x) (* -1 z))))
(*.f64 (-.f64 x z) y)
(* (pow y 2) (+ 1 (* -1 (/ (- (* -1 x) (* -1 z)) y))))
(*.f64 (fma.f64 (/.f64 (-.f64 x z) y) y y) y)
(+ (* -1 (* y z)) (* x y))
(*.f64 (-.f64 x z) y)
(+ (* -1 (* y z)) (+ (* x y) (pow y 2)))
(*.f64 (-.f64 (+.f64 y x) z) y)
z
(* z (- (/ (* x y) z) y))
(*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(* z (- (+ (/ (* x y) z) (/ (pow y 2) z)) y))
(*.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (/.f64 (+.f64 y x) z))) z)
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(* -1 (* z (- (* -1 (/ (+ (* x y) (pow y 2)) z)) (* -1 y))))
(*.f64 (*.f64 y (+.f64 #s(literal -1 binary64) (/.f64 (+.f64 y x) z))) z)

rewrite112.0ms (3.3%)

Memory
-23.0MiB live, 72.6MiB allocated; 37ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0945
01539
17035
070435
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
9 → 144
Calls
Call 1
Inputs
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
(-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z))
(+.f64 (*.f64 x y) (*.f64 y y))
(*.f64 x y)
x
y
(*.f64 y y)
(*.f64 y z)
z
Outputs
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (*.f64 (*.f64 y (+.f64 z y)) (*.f64 y (+.f64 z y)))) (fma.f64 (+.f64 y x) y (*.f64 y (+.f64 z y))))
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 3 binary64)) (pow.f64 (*.f64 y (+.f64 z y)) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (fma.f64 (*.f64 y (+.f64 z y)) (*.f64 y (+.f64 z y)) (*.f64 (*.f64 (+.f64 y x) y) (*.f64 y (+.f64 z y))))))
(/.f64 (+.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 y) y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)) (-.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 (neg.f64 y) y)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)) (pow.f64 y #s(literal 4 binary64)))) (neg.f64 (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 3 binary64)) (pow.f64 y #s(literal 6 binary64)))) (neg.f64 (fma.f64 (*.f64 y y) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y)) (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)) (pow.f64 y #s(literal 4 binary64))) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y)))
(/.f64 (-.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 3 binary64)) (pow.f64 y #s(literal 6 binary64))) (fma.f64 (*.f64 y y) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y)) (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64))))
(fma.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 (neg.f64 (neg.f64 y)) (neg.f64 (neg.f64 y)) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 (fabs.f64 (fabs.f64 y)) (fabs.f64 (fabs.f64 y)) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 (+.f64 y x) y (-.f64 (*.f64 (neg.f64 y) z) (*.f64 y y)))
(fma.f64 (+.f64 y x) y (fma.f64 (neg.f64 y) z (*.f64 (neg.f64 y) y)))
(fma.f64 (neg.f64 y) (neg.f64 y) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 (neg.f64 y) y (*.f64 y (-.f64 (+.f64 y x) z)))
(fma.f64 (fabs.f64 y) (fabs.f64 y) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 y (-.f64 x (neg.f64 y)) (-.f64 (*.f64 (neg.f64 y) z) (*.f64 y y)))
(fma.f64 y (-.f64 x (neg.f64 y)) (fma.f64 (neg.f64 y) z (*.f64 (neg.f64 y) y)))
(fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 (neg.f64 (neg.f64 y)) (neg.f64 y)))
(fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 (neg.f64 (fabs.f64 y)) (fabs.f64 y)))
(fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 (neg.f64 y) y))
(fma.f64 y (+.f64 y x) (-.f64 (*.f64 (neg.f64 y) z) (*.f64 y y)))
(fma.f64 y (+.f64 y x) (fma.f64 (neg.f64 y) z (*.f64 (neg.f64 y) y)))
(fma.f64 y (neg.f64 y) (*.f64 y (-.f64 (+.f64 y x) z)))
(fma.f64 y y (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(fma.f64 y x (-.f64 (*.f64 y (-.f64 y z)) (*.f64 y y)))
(fma.f64 y x (-.f64 (*.f64 y y) (*.f64 y (+.f64 z y))))
(fma.f64 y x (fma.f64 y (-.f64 y z) (*.f64 (neg.f64 y) y)))
(fma.f64 x y (-.f64 (*.f64 y (-.f64 y z)) (*.f64 y y)))
(fma.f64 x y (-.f64 (*.f64 y y) (*.f64 y (+.f64 z y))))
(fma.f64 x y (fma.f64 y (-.f64 y z) (*.f64 (neg.f64 y) y)))
(-.f64 (/.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y))) (/.f64 (pow.f64 y #s(literal 4 binary64)) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y))))
(-.f64 (/.f64 (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 3 binary64)) (fma.f64 (*.f64 y y) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y)) (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 6 binary64)) (fma.f64 (*.f64 y y) (fma.f64 y (-.f64 (+.f64 y x) z) (*.f64 y y)) (pow.f64 (*.f64 y (-.f64 (+.f64 y x) z)) #s(literal 2 binary64)))))
(-.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 (neg.f64 (neg.f64 y)) y))
(-.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 y y))
(-.f64 (*.f64 (+.f64 y x) y) (*.f64 y (+.f64 z y)))
(-.f64 (*.f64 y x) (fma.f64 (neg.f64 y) y (*.f64 y (+.f64 z y))))
(+.f64 (*.f64 (neg.f64 y) y) (*.f64 y (-.f64 (+.f64 y x) z)))
(+.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 (neg.f64 (neg.f64 y)) (neg.f64 y)))
(+.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 (neg.f64 (fabs.f64 y)) (fabs.f64 y)))
(+.f64 (*.f64 y (-.f64 (+.f64 y x) z)) (*.f64 (neg.f64 y) y))
(+.f64 (*.f64 (+.f64 y x) y) (-.f64 (*.f64 (neg.f64 y) z) (*.f64 y y)))
(+.f64 (*.f64 (+.f64 y x) y) (fma.f64 (neg.f64 y) z (*.f64 (neg.f64 y) y)))
(+.f64 (*.f64 y y) (-.f64 (*.f64 y x) (*.f64 y (+.f64 z y))))
(+.f64 (*.f64 y x) (-.f64 (*.f64 y (-.f64 y z)) (*.f64 y y)))
(+.f64 (*.f64 y x) (-.f64 (*.f64 y y) (*.f64 y (+.f64 z y))))
(+.f64 (*.f64 y x) (fma.f64 y (-.f64 y z) (*.f64 (neg.f64 y) y)))
(*.f64 y (-.f64 (+.f64 y x) z))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 y (-.f64 y z)) (*.f64 y (-.f64 y z)))) (-.f64 (*.f64 y x) (*.f64 y (-.f64 y z))))
(/.f64 (+.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 y) z) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 (*.f64 (+.f64 y x) y) (*.f64 (neg.f64 y) z)))))
(/.f64 (+.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 y (-.f64 y z)) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 y (-.f64 y z)) (*.f64 y (-.f64 y z))) (*.f64 (*.f64 y x) (*.f64 y (-.f64 y z))))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (pow.f64 (*.f64 z y) #s(literal 2 binary64)))) (neg.f64 (*.f64 y (+.f64 (+.f64 y x) z))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 z y) (*.f64 y (+.f64 (+.f64 y x) z)) (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (pow.f64 (*.f64 z y) #s(literal 2 binary64))) (*.f64 y (+.f64 (+.f64 y x) z)))
(/.f64 (-.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 3 binary64)) (pow.f64 (*.f64 z y) #s(literal 3 binary64))) (fma.f64 (*.f64 z y) (*.f64 y (+.f64 (+.f64 y x) z)) (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64))))
(fma.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 (neg.f64 (neg.f64 y)) (neg.f64 (neg.f64 y)) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (neg.f64 (neg.f64 y)) (neg.f64 (neg.f64 y)) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 (fabs.f64 (fabs.f64 y)) (fabs.f64 (fabs.f64 y)) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (fabs.f64 (fabs.f64 y)) (fabs.f64 (fabs.f64 y)) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 (+.f64 y x) y (*.f64 (neg.f64 z) y))
(fma.f64 (+.f64 y x) y (*.f64 (neg.f64 y) z))
(fma.f64 (neg.f64 y) (neg.f64 y) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (neg.f64 y) (neg.f64 y) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 (neg.f64 y) z (*.f64 (+.f64 y x) y))
(fma.f64 (fabs.f64 y) (fabs.f64 y) (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 (fabs.f64 y) (fabs.f64 y) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 z (neg.f64 y) (*.f64 (+.f64 y x) y))
(fma.f64 y (-.f64 x (neg.f64 y)) (*.f64 (neg.f64 z) y))
(fma.f64 y (-.f64 x (neg.f64 y)) (*.f64 (neg.f64 y) z))
(fma.f64 y (-.f64 y z) (*.f64 y x))
(fma.f64 y (+.f64 y x) (*.f64 (neg.f64 z) y))
(fma.f64 y (+.f64 y x) (*.f64 (neg.f64 y) z))
(fma.f64 y y (-.f64 (*.f64 y x) (*.f64 z y)))
(fma.f64 y y (fma.f64 y x (*.f64 (neg.f64 y) z)))
(fma.f64 y x (*.f64 y (-.f64 y z)))
(fma.f64 x y (*.f64 y (-.f64 y z)))
(-.f64 (/.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)) (*.f64 y (+.f64 (+.f64 y x) z))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 y (+.f64 (+.f64 y x) z))))
(-.f64 (/.f64 (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (*.f64 y (+.f64 (+.f64 y x) z)) (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 z y) #s(literal 3 binary64)) (fma.f64 (*.f64 z y) (*.f64 y (+.f64 (+.f64 y x) z)) (pow.f64 (*.f64 (+.f64 y x) y) #s(literal 2 binary64)))))
(-.f64 (*.f64 (+.f64 y x) y) (*.f64 (neg.f64 (neg.f64 y)) z))
(-.f64 (*.f64 (+.f64 y x) y) (*.f64 z y))
(-.f64 (*.f64 y x) (fma.f64 (neg.f64 y) y (*.f64 z y)))
(-.f64 (*.f64 y x) (-.f64 (*.f64 (neg.f64 y) y) (*.f64 (neg.f64 y) z)))
(+.f64 (*.f64 y (-.f64 y z)) (*.f64 y x))
(+.f64 (*.f64 (neg.f64 y) z) (*.f64 (+.f64 y x) y))
(+.f64 (*.f64 (+.f64 y x) y) (*.f64 (neg.f64 z) y))
(+.f64 (*.f64 (+.f64 y x) y) (*.f64 (neg.f64 y) z))
(+.f64 (*.f64 y y) (-.f64 (*.f64 y x) (*.f64 z y)))
(+.f64 (*.f64 y y) (fma.f64 y x (*.f64 (neg.f64 y) z)))
(+.f64 (*.f64 y x) (*.f64 y (-.f64 y z)))
(*.f64 (+.f64 y x) y)
(*.f64 y (-.f64 x (neg.f64 y)))
(*.f64 y (+.f64 y x))
(/.f64 (-.f64 (pow.f64 y #s(literal 4 binary64)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))) (-.f64 (*.f64 y y) (*.f64 y x)))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 y) y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (+.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (*.f64 y x) (*.f64 (neg.f64 y) y)))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 y #s(literal 4 binary64)))) (neg.f64 (*.f64 y (-.f64 x y))))
(/.f64 (neg.f64 (+.f64 (pow.f64 y #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 y y) (-.f64 (*.f64 y y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (pow.f64 y #s(literal 4 binary64))) (*.f64 y (-.f64 x y)))
(/.f64 (+.f64 (pow.f64 y #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (+.f64 (pow.f64 y #s(literal 4 binary64)) (-.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 y x) y) y))))
(/.f64 (+.f64 (pow.f64 y #s(literal 6 binary64)) (pow.f64 (*.f64 y x) #s(literal 3 binary64))) (fma.f64 (*.f64 y y) (-.f64 (*.f64 y y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64))))
(fma.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)) (*.f64 y x))
(fma.f64 (neg.f64 (neg.f64 y)) (neg.f64 (neg.f64 y)) (*.f64 y x))
(fma.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)) (*.f64 y x))
(fma.f64 (fabs.f64 (fabs.f64 y)) (fabs.f64 (fabs.f64 y)) (*.f64 y x))
(fma.f64 (neg.f64 y) (neg.f64 y) (*.f64 y x))
(fma.f64 (fabs.f64 y) (fabs.f64 y) (*.f64 y x))
(fma.f64 y y (*.f64 y x))
(fma.f64 y x (*.f64 (neg.f64 (neg.f64 y)) y))
(fma.f64 y x (*.f64 y y))
(fma.f64 x y (*.f64 (neg.f64 (neg.f64 y)) y))
(fma.f64 x y (*.f64 y y))
(-.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 2 binary64)) (*.f64 y (-.f64 x y))) (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 y (-.f64 x y))))
(-.f64 (*.f64 y y) (*.f64 (neg.f64 y) x))
(-.f64 (*.f64 y y) (*.f64 (neg.f64 x) y))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 (neg.f64 y)) (neg.f64 y)))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 (fabs.f64 y)) (fabs.f64 y)))
(-.f64 (*.f64 y x) (*.f64 (neg.f64 y) y))
(+.f64 (/.f64 (pow.f64 (*.f64 y x) #s(literal 3 binary64)) (fma.f64 (*.f64 y y) (-.f64 (*.f64 y y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))) (/.f64 (pow.f64 y #s(literal 6 binary64)) (fma.f64 (*.f64 y y) (-.f64 (*.f64 y y) (*.f64 y x)) (pow.f64 (*.f64 y x) #s(literal 2 binary64)))))
(+.f64 (*.f64 y y) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (neg.f64 (neg.f64 y)) y))
(+.f64 (*.f64 y x) (*.f64 y y))
(*.f64 y x)
(*.f64 x y)
x
y
(*.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)))
(*.f64 (neg.f64 (neg.f64 y)) (neg.f64 (neg.f64 y)))
(*.f64 (neg.f64 (fabs.f64 y)) (neg.f64 (fabs.f64 y)))
(*.f64 (fabs.f64 (fabs.f64 y)) (fabs.f64 (fabs.f64 y)))
(*.f64 (neg.f64 y) (neg.f64 y))
(*.f64 (fabs.f64 y) (fabs.f64 y))
(*.f64 y y)
(pow.f64 (neg.f64 y) #s(literal 2 binary64))
(pow.f64 (fabs.f64 y) #s(literal 2 binary64))
(pow.f64 y #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 y) y))
(fabs.f64 (*.f64 y y))
(exp.f64 (*.f64 (log.f64 y) #s(literal 2 binary64)))
(*.f64 z y)
(*.f64 y z)
z

eval33.0ms (1%)

Memory
-5.6MiB live, 38.2MiB allocated; 18ms collecting garbage
Compiler

Compiled 3 251 to 481 computations (85.2% saved)

prune3.0ms (0.1%)

Memory
12.8MiB live, 12.8MiB allocated; 0ms collecting garbage
Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New1713174
Fresh000
Picked101
Done000
Total1723175
Accuracy
100.0%
Counts
175 → 3
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
88.2%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z))))
55.1%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
Compiler

Compiled 66 to 39 computations (40.9% saved)

series21.0ms (0.6%)

Memory
-5.6MiB live, 38.2MiB allocated; 11ms collecting garbage
Counts
15 → 30
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
(*.f64 (neg.f64 z) y)
(neg.f64 z)
z
y
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z))))
(*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(*.f64 z y)
(+.f64 #s(literal -1 binary64) (/.f64 x z))
#s(literal -1 binary64)
(/.f64 x z)
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
(*.f64 (-.f64 x z) y)
(-.f64 x z)
Outputs
(* -1 (* y z))
(- (* x y) (* y z))
(+ (* -1 (* y z)) (* x y))
-1
(- (/ x z) 1)
(/ x z)
x
(* -1 z)
(- x z)
(* x y)
(* x (+ y (* -1 (/ (* y z) x))))
(* x (- (/ 1 z) (/ 1 x)))
(* x (+ 1 (* -1 (/ z x))))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(* -1 (* x (- (/ z x) 1)))
(* y (- x z))
y
(* y (* z (- (/ x z) 1)))
(* y z)
(* -1 (* y (- (* -1 x) (* -1 z))))
z
(/ (+ x (* -1 z)) z)
(+ x (* -1 z))
(* z (- (/ (* x y) z) y))
(* z (+ (* -1 y) (/ (* x y) z)))
(* z (- (/ x z) 1))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
(* -1 (* z (+ 1 (* -1 (/ x z)))))
Calls

9 calls:

TimeVariablePointExpression
6.0ms
z
@inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (neg z) y) (neg z) z y (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* z y) (+ -1 (/ x z))) (* z y) (+ -1 (/ x z)) -1 (/ x z) x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (- x z) y) (- x z))
3.0ms
x
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (neg z) y) (neg z) z y (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* z y) (+ -1 (/ x z))) (* z y) (+ -1 (/ x z)) -1 (/ x z) x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (- x z) y) (- x z))
2.0ms
y
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (neg z) y) (neg z) z y (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* z y) (+ -1 (/ x z))) (* z y) (+ -1 (/ x z)) -1 (/ x z) x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (- x z) y) (- x z))
2.0ms
z
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (neg z) y) (neg z) z y (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* z y) (+ -1 (/ x z))) (* z y) (+ -1 (/ x z)) -1 (/ x z) x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (- x z) y) (- x z))
2.0ms
y
@0
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (neg z) y) (neg z) z y (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* z y) (+ -1 (/ x z))) (* z y) (+ -1 (/ x z)) -1 (/ x z) x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (- x z) y) (- x z))

simplify360.0ms (10.6%)

Memory
-40.3MiB live, 197.4MiB allocated; 174ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
061143
1191121
2581121
31742121
46163121
08208121
Stop Event
iter limit
node limit
Counts
30 → 27
Calls
Call 1
Inputs
(* -1 (* y z))
(- (* x y) (* y z))
(+ (* -1 (* y z)) (* x y))
-1
(- (/ x z) 1)
(/ x z)
x
(* -1 z)
(- x z)
(* x y)
(* x (+ y (* -1 (/ (* y z) x))))
(* x (- (/ 1 z) (/ 1 x)))
(* x (+ 1 (* -1 (/ z x))))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(* -1 (* x (- (/ z x) 1)))
(* y (- x z))
y
(* y (* z (- (/ x z) 1)))
(* y z)
(* -1 (* y (- (* -1 x) (* -1 z))))
z
(/ (+ x (* -1 z)) z)
(+ x (* -1 z))
(* z (- (/ (* x y) z) y))
(* z (+ (* -1 y) (/ (* x y) z)))
(* z (- (/ x z) 1))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
(* -1 (* z (+ 1 (* -1 (/ x z)))))
Outputs
(* -1 (* y z))
(*.f64 (neg.f64 y) z)
(- (* x y) (* y z))
(*.f64 (-.f64 x z) y)
(+ (* -1 (* y z)) (* x y))
(*.f64 (-.f64 x z) y)
-1
#s(literal -1 binary64)
(- (/ x z) 1)
(/.f64 (-.f64 x z) z)
(/ x z)
(/.f64 x z)
x
(* -1 z)
(neg.f64 z)
(- x z)
(-.f64 x z)
(* x y)
(*.f64 y x)
(* x (+ y (* -1 (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(* x (- (/ 1 z) (/ 1 x)))
(*.f64 (/.f64 (/.f64 (-.f64 x z) x) z) x)
(* x (+ 1 (* -1 (/ z x))))
(-.f64 x z)
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(*.f64 (/.f64 (-.f64 (/.f64 z x) #s(literal 1 binary64)) z) (neg.f64 x))
(* -1 (* x (- (/ z x) 1)))
(-.f64 x z)
(* y (- x z))
(*.f64 (-.f64 x z) y)
y
(* y (* z (- (/ x z) 1)))
(*.f64 (-.f64 x z) y)
(* y z)
(*.f64 z y)
(* -1 (* y (- (* -1 x) (* -1 z))))
(*.f64 (-.f64 x z) y)
z
(/ (+ x (* -1 z)) z)
(/.f64 (-.f64 x z) z)
(+ x (* -1 z))
(-.f64 x z)
(* z (- (/ (* x y) z) y))
(*.f64 (-.f64 x z) y)
(* z (+ (* -1 y) (/ (* x y) z)))
(*.f64 (-.f64 x z) y)
(* z (- (/ x z) 1))
(-.f64 x z)
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(*.f64 (-.f64 x z) y)
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
(*.f64 (-.f64 x z) y)
(* -1 (* z (+ 1 (* -1 (/ x z)))))
(-.f64 x z)

rewrite55.0ms (1.6%)

Memory
32.4MiB live, 74.1MiB allocated; 10ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
021104
02998
113092
0109092
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
15 → 81
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
(*.f64 (neg.f64 z) y)
(neg.f64 z)
z
y
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z))))
(*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(*.f64 z y)
(+.f64 #s(literal -1 binary64) (/.f64 x z))
#s(literal -1 binary64)
(/.f64 x z)
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
(*.f64 (-.f64 x z) y)
(-.f64 x z)
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
(*.f64 (*.f64 #s(literal -1 binary64) z) y)
(*.f64 (*.f64 #s(literal -1 binary64) y) z)
(*.f64 (neg.f64 y) z)
(*.f64 #s(literal -1 binary64) (*.f64 z y))
(*.f64 (*.f64 z y) #s(literal -1 binary64))
(*.f64 (neg.f64 z) y)
(*.f64 z (*.f64 y #s(literal -1 binary64)))
(*.f64 z (neg.f64 y))
(*.f64 y (*.f64 z #s(literal -1 binary64)))
(*.f64 y (neg.f64 z))
(neg.f64 (*.f64 z y))
(neg.f64 z)
z
y
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) z) y))
(*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) z) y)
(*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z)
(*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) (*.f64 z y))
(*.f64 (*.f64 z y) (+.f64 (/.f64 x z) #s(literal -1 binary64)))
(*.f64 z (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y))
(*.f64 y (*.f64 z (+.f64 (/.f64 x z) #s(literal -1 binary64))))
(/.f64 (*.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (/.f64 x z) #s(literal 2 binary64))) (*.f64 z y)) (-.f64 #s(literal -1 binary64) (/.f64 x z)))
(/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (*.f64 z y)) (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64)))
(/.f64 (*.f64 (*.f64 z y) (-.f64 #s(literal 1 binary64) (pow.f64 (/.f64 x z) #s(literal 2 binary64)))) (-.f64 #s(literal -1 binary64) (/.f64 x z)))
(/.f64 (*.f64 (*.f64 z y) (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (*.f64 (*.f64 (*.f64 (/.f64 x z) z) y) (*.f64 (*.f64 (/.f64 x z) z) y))) (-.f64 (*.f64 (neg.f64 z) y) (*.f64 (*.f64 (/.f64 x z) z) y)))
(/.f64 (+.f64 (pow.f64 (*.f64 (neg.f64 z) y) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 (/.f64 x z) z) y) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 z y) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 (*.f64 (/.f64 x z) z) y) (*.f64 (*.f64 (/.f64 x z) z) y)) (*.f64 (*.f64 (neg.f64 z) y) (*.f64 (*.f64 (/.f64 x z) z) y)))))
(fma.f64 (*.f64 #s(literal -1 binary64) z) y (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 (*.f64 (/.f64 x z) z) y (*.f64 (neg.f64 z) y))
(fma.f64 (*.f64 (/.f64 x z) y) z (*.f64 (neg.f64 z) y))
(fma.f64 (*.f64 #s(literal -1 binary64) y) z (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 (neg.f64 y) z (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 (/.f64 x z) (*.f64 z y) (*.f64 (neg.f64 z) y))
(fma.f64 #s(literal -1 binary64) (*.f64 z y) (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 (*.f64 z y) (/.f64 x z) (*.f64 (neg.f64 z) y))
(fma.f64 (*.f64 z y) #s(literal -1 binary64) (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 (neg.f64 z) y (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 z (*.f64 y (/.f64 x z)) (*.f64 (neg.f64 z) y))
(fma.f64 z (*.f64 y #s(literal -1 binary64)) (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 z (neg.f64 y) (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 y (*.f64 z #s(literal -1 binary64)) (*.f64 (*.f64 (/.f64 x z) z) y))
(fma.f64 y (*.f64 z (/.f64 x z)) (*.f64 (neg.f64 z) y))
(fma.f64 y (neg.f64 z) (*.f64 (*.f64 (/.f64 x z) z) y))
(-.f64 (*.f64 (neg.f64 z) y) (*.f64 (neg.f64 (/.f64 x z)) (*.f64 z y)))
(-.f64 (*.f64 (neg.f64 z) y) (*.f64 (*.f64 (neg.f64 z) y) (/.f64 x z)))
(+.f64 (*.f64 (*.f64 (/.f64 x z) z) y) (*.f64 (neg.f64 z) y))
(+.f64 (*.f64 (neg.f64 z) y) (*.f64 (*.f64 (/.f64 x z) z) y))
(*.f64 z y)
(*.f64 y z)
(/.f64 (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64)) (-.f64 (/.f64 x z) #s(literal -1 binary64)))
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (/.f64 x z) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal -1 binary64) (/.f64 x z))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64))))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (/.f64 x z) #s(literal 2 binary64))) (-.f64 #s(literal -1 binary64) (/.f64 x z)))
(/.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (neg.f64 (/.f64 x z)))))
(/.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64)))
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z))) (/.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) (-.f64 #s(literal -1 binary64) (/.f64 x z))))
(+.f64 (/.f64 #s(literal -1 binary64) (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64))) (/.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) (fma.f64 (/.f64 x z) (-.f64 (/.f64 x z) #s(literal -1 binary64)) #s(literal 1 binary64))))
(+.f64 (/.f64 x z) #s(literal -1 binary64))
(+.f64 #s(literal -1 binary64) (/.f64 x z))
#s(literal -1 binary64)
(/.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 z)))
(/.f64 (neg.f64 x) (neg.f64 z))
(/.f64 x z)
(neg.f64 (/.f64 (neg.f64 x) z))
(neg.f64 (/.f64 x (neg.f64 z)))
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
(*.f64 (-.f64 x z) y)
(*.f64 y (-.f64 x z))
(/.f64 (*.f64 (*.f64 (+.f64 z x) (-.f64 x z)) y) (+.f64 z x))
(/.f64 (*.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) y) (fma.f64 z (+.f64 z x) (*.f64 x x)))
(/.f64 (*.f64 y (*.f64 (+.f64 z x) (-.f64 x z))) (+.f64 z x))
(/.f64 (*.f64 y (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (fma.f64 z (+.f64 z x) (*.f64 x x)))
(/.f64 (neg.f64 (*.f64 (+.f64 z x) (-.f64 x z))) (neg.f64 (+.f64 z x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64)))) (neg.f64 (fma.f64 z (+.f64 z x) (*.f64 x x))))
(/.f64 (*.f64 (+.f64 z x) (-.f64 x z)) (+.f64 z x))
(/.f64 (-.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 z #s(literal 3 binary64))) (fma.f64 z (+.f64 z x) (*.f64 x x)))
(-.f64 (/.f64 (*.f64 x x) (+.f64 z x)) (/.f64 (*.f64 z z) (+.f64 z x)))
(-.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 z (+.f64 z x) (*.f64 x x))) (/.f64 (pow.f64 z #s(literal 3 binary64)) (fma.f64 z (+.f64 z x) (*.f64 x x))))
(-.f64 x z)

eval63.0ms (1.9%)

Memory
-43.7MiB live, 17.6MiB allocated; 11ms collecting garbage
Compiler

Compiled 2 744 to 296 computations (89.2% saved)

prune5.0ms (0.2%)

Memory
6.4MiB live, 6.4MiB allocated; 0ms collecting garbage
Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New96298
Fresh000
Picked123
Done000
Total974101
Accuracy
100.0%
Counts
101 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
89.8%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z))
55.1%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
52.2%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Compiler

Compiled 85 to 50 computations (41.2% saved)

series11.0ms (0.3%)

Memory
9.9MiB live, 9.9MiB allocated; 0ms collecting garbage
Counts
11 → 29
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
(*.f64 y x)
y
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z))
(*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z)
(*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y)
(+.f64 (/.f64 x z) #s(literal -1 binary64))
(/.f64 x z)
z
#s(literal -1 binary64)
Outputs
(* -1 (* y z))
(- (* x y) (* y z))
(* x y)
x
(+ (* -1 (* y z)) (* x y))
(* -1 y)
(+ (* -1 y) (/ (* x y) z))
-1
(- (/ x z) 1)
(/ x z)
(* x (+ y (* -1 (/ (* y z) x))))
(/ (* x y) z)
(* x (+ (* -1 (/ y x)) (/ y z)))
(* x (- (/ 1 z) (/ 1 x)))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (+ (* -1 (/ y z)) (/ y x))))
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(* y (- x z))
y
(* y (* z (- (/ x z) 1)))
(* y (- (/ x z) 1))
(* -1 (* y (- (* -1 x) (* -1 z))))
(/ (+ (* -1 (* y z)) (* x y)) z)
(/ (+ x (* -1 z)) z)
z
(* z (- (/ (* x y) z) y))
(* z (+ (* -1 y) (/ (* x y) z)))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
Calls

9 calls:

TimeVariablePointExpression
2.0ms
y
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* y x) y x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* (+ (/ x z) -1) y) z) (* (+ (/ x z) -1) y) (+ (/ x z) -1) (/ x z) z -1)
2.0ms
x
@-inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* y x) y x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* (+ (/ x z) -1) y) z) (* (+ (/ x z) -1) y) (+ (/ x z) -1) (/ x z) z -1)
1.0ms
y
@inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* y x) y x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* (+ (/ x z) -1) y) z) (* (+ (/ x z) -1) y) (+ (/ x z) -1) (/ x z) z -1)
1.0ms
x
@inf
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* y x) y x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* (+ (/ x z) -1) y) z) (* (+ (/ x z) -1) y) (+ (/ x z) -1) (/ x z) z -1)
1.0ms
y
@0
((- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* y x) y x (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (* (* (+ (/ x z) -1) y) z) (* (+ (/ x z) -1) y) (+ (/ x z) -1) (/ x z) z -1)

simplify218.0ms (6.4%)

Memory
-7.9MiB live, 176.4MiB allocated; 44ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
061166
1187139
2538139
31607139
45771139
08244139
Stop Event
iter limit
node limit
Counts
29 → 26
Calls
Call 1
Inputs
(* -1 (* y z))
(- (* x y) (* y z))
(* x y)
x
(+ (* -1 (* y z)) (* x y))
(* -1 y)
(+ (* -1 y) (/ (* x y) z))
-1
(- (/ x z) 1)
(/ x z)
(* x (+ y (* -1 (/ (* y z) x))))
(/ (* x y) z)
(* x (+ (* -1 (/ y x)) (/ y z)))
(* x (- (/ 1 z) (/ 1 x)))
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x (+ (* -1 (/ y z)) (/ y x))))
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(* y (- x z))
y
(* y (* z (- (/ x z) 1)))
(* y (- (/ x z) 1))
(* -1 (* y (- (* -1 x) (* -1 z))))
(/ (+ (* -1 (* y z)) (* x y)) z)
(/ (+ x (* -1 z)) z)
z
(* z (- (/ (* x y) z) y))
(* z (+ (* -1 y) (/ (* x y) z)))
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
Outputs
(* -1 (* y z))
(*.f64 (neg.f64 z) y)
(- (* x y) (* y z))
(*.f64 (-.f64 x z) y)
(* x y)
(*.f64 y x)
x
(+ (* -1 (* y z)) (* x y))
(*.f64 (-.f64 x z) y)
(* -1 y)
(neg.f64 y)
(+ (* -1 y) (/ (* x y) z))
(*.f64 (-.f64 (/.f64 x z) #s(literal 1 binary64)) y)
-1
#s(literal -1 binary64)
(- (/ x z) 1)
(-.f64 (/.f64 x z) #s(literal 1 binary64))
(/ x z)
(/.f64 x z)
(* x (+ y (* -1 (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(/ (* x y) z)
(*.f64 (/.f64 y z) x)
(* x (+ (* -1 (/ y x)) (/ y z)))
(*.f64 (-.f64 (/.f64 x z) #s(literal 1 binary64)) y)
(* x (- (/ 1 z) (/ 1 x)))
(*.f64 (-.f64 (/.f64 #s(literal -1 binary64) x) (/.f64 #s(literal -1 binary64) z)) x)
(* -1 (* x (+ (* -1 y) (/ (* y z) x))))
(*.f64 (-.f64 x z) y)
(* -1 (* x (+ (* -1 (/ y z)) (/ y x))))
(*.f64 (-.f64 (/.f64 x z) #s(literal 1 binary64)) y)
(* -1 (* x (- (/ 1 x) (/ 1 z))))
(*.f64 (-.f64 (/.f64 #s(literal -1 binary64) x) (/.f64 #s(literal -1 binary64) z)) x)
(* y (- x z))
(*.f64 (-.f64 x z) y)
y
(* y (* z (- (/ x z) 1)))
(*.f64 (-.f64 x z) y)
(* y (- (/ x z) 1))
(*.f64 (-.f64 (/.f64 x z) #s(literal 1 binary64)) y)
(* -1 (* y (- (* -1 x) (* -1 z))))
(*.f64 (-.f64 x z) y)
(/ (+ (* -1 (* y z)) (* x y)) z)
(*.f64 (-.f64 (/.f64 x z) #s(literal 1 binary64)) y)
(/ (+ x (* -1 z)) z)
(-.f64 (/.f64 x z) #s(literal 1 binary64))
z
(* z (- (/ (* x y) z) y))
(*.f64 (-.f64 x z) y)
(* z (+ (* -1 y) (/ (* x y) z)))
(*.f64 (-.f64 x z) y)
(* -1 (* z (- (* -1 (/ (* x y) z)) (* -1 y))))
(*.f64 (-.f64 x z) y)
(* -1 (* z (+ y (* -1 (/ (* x y) z)))))
(*.f64 (-.f64 x z) y)

rewrite49.0ms (1.4%)

Memory
41.1MiB live, 84.2MiB allocated; 9ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01775
02271
19767
089767
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
11 → 46
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
(*.f64 y x)
y
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z))
(*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z)
(*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y)
(+.f64 (/.f64 x z) #s(literal -1 binary64))
(/.f64 x z)
z
#s(literal -1 binary64)
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
(*.f64 y x)
(*.f64 x y)
y
x
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) y) z))
(*.f64 (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) z) y)
(*.f64 (*.f64 z (+.f64 #s(literal -1 binary64) (/.f64 x z))) y)
(*.f64 (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) y) z)
(*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) (*.f64 z y))
(*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(*.f64 z (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) y))
(*.f64 y (*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) z))
(/.f64 (*.f64 (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 z y)) (-.f64 (/.f64 x z) #s(literal -1 binary64)))
(/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (*.f64 z y)) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64))))
(*.f64 (+.f64 #s(literal -1 binary64) (/.f64 x z)) y)
(*.f64 y (+.f64 #s(literal -1 binary64) (/.f64 x z)))
(/.f64 (*.f64 (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64)) y) (-.f64 (/.f64 x z) #s(literal -1 binary64)))
(/.f64 (*.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) y) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64))))
(/.f64 (*.f64 y (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64))) (-.f64 (/.f64 x z) #s(literal -1 binary64)))
(/.f64 (*.f64 y (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64))) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64))))
(fma.f64 #s(literal -1 binary64) y (*.f64 (/.f64 x z) y))
(fma.f64 (/.f64 x z) y (*.f64 #s(literal -1 binary64) y))
(fma.f64 y #s(literal -1 binary64) (*.f64 y (/.f64 x z)))
(fma.f64 y (/.f64 x z) (*.f64 y #s(literal -1 binary64)))
(+.f64 (*.f64 #s(literal -1 binary64) y) (*.f64 (/.f64 x z) y))
(+.f64 (*.f64 (/.f64 x z) y) (*.f64 #s(literal -1 binary64) y))
(+.f64 (*.f64 y #s(literal -1 binary64)) (*.f64 y (/.f64 x z)))
(+.f64 (*.f64 y (/.f64 x z)) (*.f64 y #s(literal -1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (/.f64 x z) #s(literal 2 binary64))) (-.f64 #s(literal -1 binary64) (/.f64 x z)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (-.f64 (/.f64 x z) #s(literal -1 binary64))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64)))))
(/.f64 (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) #s(literal 1 binary64)) (-.f64 (/.f64 x z) #s(literal -1 binary64)))
(/.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) (*.f64 #s(literal -1 binary64) (/.f64 x z)))))
(/.f64 (+.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64))))
(-.f64 (/.f64 (pow.f64 (/.f64 x z) #s(literal 2 binary64)) (-.f64 (/.f64 x z) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 (/.f64 x z) #s(literal -1 binary64))))
(+.f64 (/.f64 (pow.f64 (/.f64 x z) #s(literal 3 binary64)) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64)))) (/.f64 #s(literal -1 binary64) (fma.f64 #s(literal -1 binary64) (-.f64 #s(literal -1 binary64) (/.f64 x z)) (pow.f64 (/.f64 x z) #s(literal 2 binary64)))))
(+.f64 #s(literal -1 binary64) (/.f64 x z))
(+.f64 (/.f64 x z) #s(literal -1 binary64))
(/.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 z)))
(/.f64 (neg.f64 x) (neg.f64 z))
(/.f64 x z)
(neg.f64 (/.f64 (neg.f64 x) z))
(neg.f64 (/.f64 x (neg.f64 z)))
z
#s(literal -1 binary64)

eval29.0ms (0.9%)

Memory
-30.2MiB live, 13.5MiB allocated; 6ms collecting garbage
Compiler

Compiled 1 711 to 221 computations (87.1% saved)

prune5.0ms (0.1%)

Memory
12.3MiB live, 12.3MiB allocated; 0ms collecting garbage
Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New60060
Fresh000
Picked022
Done022
Total60464
Accuracy
100.0%
Counts
64 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
89.8%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z))
55.1%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
52.2%
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Compiler

Compiled 210 to 83 computations (60.5% saved)

regimes10.0ms (0.3%)

Memory
23.3MiB live, 23.3MiB allocated; 0ms collecting garbage
Counts
6 → 1
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 z y) (+.f64 #s(literal -1 binary64) (/.f64 x z))))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (*.f64 (+.f64 (/.f64 x z) #s(literal -1 binary64)) y) z))
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
Calls

4 calls:

2.0ms
x
2.0ms
z
2.0ms
y
2.0ms
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Results
AccuracySegmentsBranch
100.0%1(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
100.0%1x
100.0%1y
100.0%1z
Compiler

Compiled 18 to 18 computations (0% saved)

regimes8.0ms (0.2%)

Memory
-28.7MiB live, 17.3MiB allocated; 4ms collecting garbage
Counts
2 → 3
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Calls

4 calls:

4.0ms
z
1.0ms
y
1.0ms
x
1.0ms
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Results
AccuracySegmentsBranch
58.9%2(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
82.0%3x
63.2%3y
78.0%3z
Compiler

Compiled 18 to 18 computations (0% saved)

regimes4.0ms (0.1%)

Memory
11.8MiB live, 11.8MiB allocated; 0ms collecting garbage
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Calls

4 calls:

1.0ms
z
1.0ms
x
1.0ms
y
1.0ms
(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
Results
AccuracySegmentsBranch
52.2%1(-.f64 (-.f64 (+.f64 (*.f64 x y) (*.f64 y y)) (*.f64 y z)) (*.f64 y y))
52.2%1y
52.2%1z
52.2%1x
Compiler

Compiled 18 to 18 computations (0% saved)

bsearch50.0ms (1.5%)

Memory
-30.6MiB live, 75.7MiB allocated; 16ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
18.0ms
3.826568385050954e+69
3.396175046774753e+72
28.0ms
-8.462327958300833e+45
-2.8887642352591435e+38
Samples
21.0ms187×0valid
14.0ms85×1valid
Compiler

Compiled 681 to 440 computations (35.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 25.0ms
ival-mult: 17.0ms (67% of total)
ival-sub: 3.0ms (11.8% of total)
adjust: 3.0ms (11.8% of total)
ival-add: 2.0ms (7.9% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)

simplify44.0ms (1.3%)

Memory
26.9MiB live, 26.9MiB allocated; 0ms collecting garbage
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
02380
15272
213664
335456
4100748
5274048
Stop Event
node limit
Calls
Call 1
Inputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
(if (<=.f64 x #s(literal -7500000000000000530070976223910043844608 binary64)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x)) (if (<=.f64 x #s(literal 3899999999999999899748716671491802402430903410044139721836239060467712 binary64)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))
Outputs
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (-.f64 x z) y))
(if (<=.f64 x #s(literal -7500000000000000530070976223910043844608 binary64)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x)) (if (<=.f64 x #s(literal 3899999999999999899748716671491802402430903410044139721836239060467712 binary64)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))))
(if (or (<=.f64 x #s(literal -7500000000000000530070976223910043844608 binary64)) (not (<=.f64 x #s(literal 3899999999999999899748716671491802402430903410044139721836239060467712 binary64)))) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x)) #s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 (neg.f64 z) y)))
#s(approx (- (- (+ (* x y) (* y y)) (* y z)) (* y y)) (*.f64 y x))

derivations180.0ms (5.3%)

Memory
-22.0MiB live, 118.0MiB allocated; 57ms collecting garbage
Stop Event
done
Compiler

Compiled 88 to 24 computations (72.7% saved)

preprocess43.0ms (1.2%)

Memory
17.2MiB live, 61.1MiB allocated; 7ms collecting garbage
Remove

(negabs y)

Compiler

Compiled 258 to 100 computations (61.2% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated; 0ms collecting garbage

Profiling

Loading profile data...