Linear.Projection:infinitePerspective from linear-1.19.1.3, A

Time bar (total: 1.3s)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze196.0ms (14.6%)

Memory
2.1MiB live, 272.9MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.8%0.2%0%0%0%0
0%0%99.8%0.2%0%0%0%1
0%0%99.8%0.2%0%0%0%2
0%0%99.8%0.2%0%0%0%3
0%0%99.8%0.2%0%0%0%4
25%25%74.9%0.2%0%0%0%5
25%25%74.9%0.2%0%0%0%6
25%25%74.9%0.2%0%0%0%7
37.5%37.4%62.4%0.2%0%0%0%8
37.5%37.4%62.4%0.2%0%0%0%9
37.5%37.4%62.4%0.2%0%0%0%10
37.5%37.4%62.4%0.2%0%0%0%11
48.4%48.3%51.5%0.2%0%0%0%12
Compiler

Compiled 13 to 12 computations (7.7% saved)

sample826.0ms (61.3%)

Memory
-6.3MiB live, 1 296.2MiB allocated
Samples
534.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 325.0ms
ival-mult: 197.0ms (60.6% of total)
ival-div: 68.0ms (20.9% of total)
ival-sub: 44.0ms (13.5% of total)
ival-true: 7.0ms (2.2% of total)
exact: 5.0ms (1.5% of total)
ival-assert: 4.0ms (1.2% of total)
Bogosity

explain115.0ms (8.6%)

Memory
1.2MiB live, 156.7MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
220-1(-4.3872892856927375e-86 -5.476889012231802e-103 -1.7866299213380103e-217 6.381162978736803e-122)(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
40-0-(-.f64 (*.f64 y z) (*.f64 t z))
00-0-(*.f64 x #s(literal 2 binary64))
00-0-t
00-0-z
00-0-(*.f64 t z)
00-0-y
00-0-#s(literal 2 binary64)
00-0-(*.f64 y z)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
/.f64(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))n/o150
(*.f64 t z)overflow31
(*.f64 y z)overflow32
(-.f64 (*.f64 y z) (*.f64 t z))overflow54
/.f64(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))n/u60
(*.f64 t z)underflow23
(*.f64 y z)underflow25
(-.f64 (*.f64 y z) (*.f64 t z))underflow11
-.f64(-.f64 (*.f64 y z) (*.f64 t z))nan-rescue40
(*.f64 y z)overflow32
(*.f64 t z)overflow31
Confusion
Predicted +Predicted -
+253
-0228
Precision
1.0
Recall
0.8928571428571429
Confusion?
Predicted +Predicted MaybePredicted -
+2503
-00228
Precision?
1.0
Recall?
0.8928571428571429
Freqs
test
numberfreq
0231
125
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
39.0ms512×0valid
Compiler

Compiled 111 to 44 computations (60.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 20.0ms
ival-mult: 12.0ms (61.1% of total)
ival-div: 4.0ms (20.4% of total)
ival-sub: 3.0ms (15.3% of total)
ival-true: 1.0ms (5.1% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess4.0ms (0.3%)

Memory
7.1MiB live, 7.1MiB allocated
Algorithm
egg-herbie
Calls
Call 1
Inputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Outputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Compiler

Compiled 11 to 10 computations (9.1% saved)

eval0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated
Compiler

Compiled 0 to 4 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
89.3%
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Compiler

Compiled 11 to 10 computations (9.1% saved)

simplify0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated
Algorithm
egg-herbie
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 y z)
cost-diff0
(-.f64 (*.f64 y z) (*.f64 t z))
cost-diff0
(*.f64 x #s(literal 2 binary64))
cost-diff0
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Calls
Call 1
Inputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(*.f64 x #s(literal 2 binary64))
x
#s(literal 2 binary64)
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t
Outputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(*.f64 x #s(literal 2 binary64))
x
#s(literal 2 binary64)
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t

localize25.0ms (1.8%)

Memory
-3.1MiB live, 34.5MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 x #s(literal 2 binary64))
accuracy0.0
(*.f64 t z)
accuracy0.8085937500000001
(-.f64 (*.f64 y z) (*.f64 t z))
accuracy5.275132891805921
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Samples
19.0ms256×0valid
Compiler

Compiled 66 to 22 computations (66.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 8.0ms
ival-mult: 5.0ms (60% of total)
ival-div: 2.0ms (24% of total)
ival-sub: 1.0ms (12% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series16.0ms (1.2%)

Memory
23.4MiB live, 23.4MiB allocated
Counts
5 → 35
Calls
Call 1
Inputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(*.f64 x #s(literal 2 binary64))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
(*.f64 t z)
Outputs
(* 2 (/ x (- (* y z) (* t z))))
(* 2 x)
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* -1 (* t z))
(- (* y z) (* t z))
(* y z)
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* z (- y t))
(* t z)
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Calls

12 calls:

TimeVariablePointExpression
3.0ms
z
@-inf
((/ (* x 2) (- (* y z) (* t z))) (* x 2) (- (* y z) (* t z)) (* y z) (* t z))
2.0ms
y
@0
((/ (* x 2) (- (* y z) (* t z))) (* x 2) (- (* y z) (* t z)) (* y z) (* t z))
2.0ms
x
@inf
((/ (* x 2) (- (* y z) (* t z))) (* x 2) (- (* y z) (* t z)) (* y z) (* t z))
2.0ms
x
@0
((/ (* x 2) (- (* y z) (* t z))) (* x 2) (- (* y z) (* t z)) (* y z) (* t z))
1.0ms
x
@-inf
((/ (* x 2) (- (* y z) (* t z))) (* x 2) (- (* y z) (* t z)) (* y z) (* t z))

simplify1.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated
Algorithm
egg-herbie
Counts
35 → 5
Calls
Call 1
Inputs
(* 2 (/ x (- (* y z) (* t z))))
(* 2 x)
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* -1 (* t z))
(- (* y z) (* t z))
(* y z)
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* z (- y t))
(* t z)
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Outputs
(* 2 (/ x (- (* y z) (* t z))))
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(* 2 x)
(*.f64 x #s(literal 2 binary64))
(* -2 (/ x (* t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(*.f64 y z)
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(*.f64 t z)

rewrite0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated
Counts
5 → 5
Calls
Call 1
Inputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(*.f64 x #s(literal 2 binary64))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
(*.f64 t z)
Outputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
(*.f64 x #s(literal 2 binary64))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
(*.f64 t z)

eval1.0ms (0.1%)

Memory
1.9MiB live, 1.9MiB allocated
Compiler

Compiled 142 to 22 computations (84.5% saved)

prune4.0ms (0.3%)

Memory
-34.2MiB live, 3.5MiB allocated
Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New7310
Fresh000
Picked011
Done000
Total7411
Accuracy
89.4%
Counts
11 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
89.3%
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
2.5%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
2.8%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
3.1%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Compiler

Compiled 60 to 48 computations (20% saved)

simplify0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated
Algorithm
egg-herbie
Localize:

Found 8 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 t z)
cost-diff0
(*.f64 y z)
cost-diff0
(-.f64 (*.f64 y z) (*.f64 t z))
cost-diff0
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
cost-diff0
(*.f64 y z)
cost-diff0
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
cost-diff0
(*.f64 t z)
cost-diff0
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(*.f64 t z)
t
z
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(*.f64 y z)
y
z
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t
Outputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(*.f64 t z)
t
z
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(*.f64 y z)
y
z
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t

localize27.0ms (2%)

Memory
4.8MiB live, 42.1MiB allocated
Localize:

Found 8 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 y z)
accuracy0.0
(*.f64 t z)
accuracy0.8085937500000001
(-.f64 (*.f64 y z) (*.f64 t z))
accuracy62.35287258027612
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
accuracy0.0
(*.f64 y z)
accuracy62.20236363777688
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
accuracy0.0
(*.f64 t z)
accuracy62.02972137489145
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Samples
18.0ms256×0valid
Compiler

Compiled 136 to 28 computations (79.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 8.0ms
ival-mult: 5.0ms (59.5% of total)
ival-div: 2.0ms (23.8% of total)
ival-sub: 1.0ms (11.9% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series7.0ms (0.5%)

Memory
14.1MiB live, 14.1MiB allocated
Counts
6 → 34
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(*.f64 t z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(*.f64 y z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
Outputs
(* 2 (/ x (- (* y z) (* t z))))
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* y z)
(* -1 (* t z))
(- (* y z) (* t z))
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* t z)
(* z (- y t))
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Calls

12 calls:

TimeVariablePointExpression
1.0ms
z
@-inf
((/ (* x 2) (- (* y z) (* t z))) (* t z) (/ (* x 2) (- (* y z) (* t z))) (* y z) (/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)))
1.0ms
z
@inf
((/ (* x 2) (- (* y z) (* t z))) (* t z) (/ (* x 2) (- (* y z) (* t z))) (* y z) (/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)))
1.0ms
x
@0
((/ (* x 2) (- (* y z) (* t z))) (* t z) (/ (* x 2) (- (* y z) (* t z))) (* y z) (/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)))
1.0ms
x
@inf
((/ (* x 2) (- (* y z) (* t z))) (* t z) (/ (* x 2) (- (* y z) (* t z))) (* y z) (/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)))
1.0ms
x
@-inf
((/ (* x 2) (- (* y z) (* t z))) (* t z) (/ (* x 2) (- (* y z) (* t z))) (* y z) (/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)))

simplify1.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated
Algorithm
egg-herbie
Counts
34 → 6
Calls
Call 1
Inputs
(* 2 (/ x (- (* y z) (* t z))))
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* y z)
(* -1 (* t z))
(- (* y z) (* t z))
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* t z)
(* z (- y t))
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Outputs
(* 2 (/ x (- (* y z) (* t z))))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(* -2 (/ x (* t z)))
(*.f64 t z)
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(*.f64 y z)
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(* y z)
(-.f64 (*.f64 y z) (*.f64 t z))

rewrite0.0ms (0%)

Memory
0.8MiB live, 0.9MiB allocated
Counts
6 → 6
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(*.f64 t z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(*.f64 y z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
Outputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
(*.f64 t z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
(*.f64 y z)
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))

eval1.0ms (0.1%)

Memory
2.9MiB live, 2.9MiB allocated
Compiler

Compiled 271 to 23 computations (91.5% saved)

prune3.0ms (0.2%)

Memory
5.1MiB live, 5.1MiB allocated
Pruning

5 alts after pruning (1 fresh and 4 done)

PrunedKeptTotal
New12113
Fresh000
Picked033
Done011
Total12517
Accuracy
89.4%
Counts
17 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
89.3%
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
2.5%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
2.5%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
2.8%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
3.1%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Compiler

Compiled 87 to 64 computations (26.4% saved)

simplify0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated
Algorithm
egg-herbie
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(-.f64 (*.f64 y z) (*.f64 t z))
cost-diff0
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
cost-diff0
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
cost-diff0
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t
Outputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
(*.f64 y z)
y
z
(*.f64 t z)
t

localize30.0ms (2.2%)

Memory
0.2MiB live, 39.8MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.8085937500000001
(-.f64 (*.f64 y z) (*.f64 t z))
accuracy0.8085937500000001
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
accuracy29.9130496612292
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
accuracy62.35287258027612
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
Samples
23.0ms256×0valid
Compiler

Compiled 108 to 28 computations (74.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 8.0ms
ival-mult: 5.0ms (60.5% of total)
ival-div: 2.0ms (24.2% of total)
ival-sub: 1.0ms (12.1% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series11.0ms (0.8%)

Memory
-25.2MiB live, 12.4MiB allocated
Counts
4 → 33
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
Outputs
(* 2 (/ x (- (* y z) (* t z))))
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* -1 (* t z))
(- (* y z) (* t z))
(* y z)
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* z (- y t))
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Calls

12 calls:

TimeVariablePointExpression
5.0ms
t
@inf
((/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)) (* y z) (- (* y z) (* t z)))
1.0ms
z
@-inf
((/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)) (* y z) (- (* y z) (* t z)))
1.0ms
z
@inf
((/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)) (* y z) (- (* y z) (* t z)))
1.0ms
x
@0
((/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)) (* y z) (- (* y z) (* t z)))
1.0ms
x
@inf
((/ (* x 2) (- (* y z) (* t z))) (- (* y z) (* t z)) (* y z) (- (* y z) (* t z)))

simplify1.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated
Algorithm
egg-herbie
Counts
33 → 4
Calls
Call 1
Inputs
(* 2 (/ x (- (* y z) (* t z))))
(* -2 (/ x (* t z)))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* y (+ (* -2 (/ x (* (pow t 3) z))) (* -2 (/ (* x y) (* (pow t 4) z))))))))
(* -1 (* t z))
(- (* y z) (* t z))
(* y z)
(* 2 (/ x (* y z)))
(/ (+ (* 2 (/ x z)) (* 2 (/ (* t x) (* y z)))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))))) y)
(/ (+ (* 2 (/ x z)) (+ (* 2 (/ (* t x) (* y z))) (+ (* 2 (/ (* (pow t 2) x) (* (pow y 2) z))) (* 2 (/ (* (pow t 3) x) (* (pow y 3) z)))))) y)
(* y (+ z (* -1 (/ (* t z) y))))
(* -1 (/ (+ (* -2 (/ x z)) (* -2 (/ (* t x) (* y z)))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* 2 (/ (* t x) z)) (* 2 (/ (* (pow t 2) x) (* y z)))) y))) y))
(* -1 (/ (+ (* -2 (/ x z)) (* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* (pow t 2) x) z)) (* -2 (/ (* (pow t 3) x) (* y z)))) y)) (* 2 (/ (* t x) z))) y))) y))
(* -1 (* y (+ (* -1 z) (/ (* t z) y))))
(* 2 (/ x (* z (- y t))))
(* z (- y t))
(* -2 (/ x (* z (- (* -1 y) (* -1 t)))))
(* -1 (* z (- (* -1 y) (* -1 t))))
(+ (* 2 (/ x (* y z))) (* 2 (/ (* t x) (* (pow y 2) z))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* 2 (/ (* t x) (* (pow y 3) z))))))
(+ (* 2 (/ x (* y z))) (* t (+ (* 2 (/ x (* (pow y 2) z))) (* t (+ (* 2 (/ x (* (pow y 3) z))) (* 2 (/ (* t x) (* (pow y 4) z))))))))
(+ (* -1 (* t z)) (* y z))
(/ (+ (* -2 (/ x z)) (* -2 (/ (* x y) (* t z)))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))))) t)
(/ (+ (* -2 (/ x z)) (+ (* -2 (/ (* x y) (* t z))) (+ (* -2 (/ (* x (pow y 2)) (* (pow t 2) z))) (* -2 (/ (* x (pow y 3)) (* (pow t 3) z)))))) t)
(* t (- (/ (* y z) t) z))
(* -1 (/ (+ (* 2 (/ x z)) (* 2 (/ (* x y) (* t z)))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -2 (/ (* x (pow y 2)) (* t z)))) t)) (* 2 (/ x z))) t))
(* -1 (/ (+ (* -1 (/ (+ (* -2 (/ (* x y) z)) (* -1 (/ (+ (* 2 (/ (* x (pow y 2)) z)) (* 2 (/ (* x (pow y 3)) (* t z)))) t))) t)) (* 2 (/ x z))) t))
(* -1 (* t (- (* -1 (/ (* y z) t)) (* -1 z))))
Outputs
(* 2 (/ x (- (* y z) (* t z))))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(* -2 (/ x (* t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
(+ (* -2 (/ x (* t z))) (* -2 (/ (* x y) (* (pow t 2) z))))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(+ (* -2 (/ x (* t z))) (* y (+ (* -2 (/ x (* (pow t 2) z))) (* -2 (/ (* x y) (* (pow t 3) z))))))
(-.f64 (*.f64 y z) (*.f64 t z))

rewrite0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated
Counts
4 → 4
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))
Outputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z))
#s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z)))
(-.f64 (*.f64 y z) (*.f64 t z))

eval1.0ms (0.1%)

Memory
1.7MiB live, 1.7MiB allocated
Compiler

Compiled 189 to 19 computations (89.9% saved)

prune3.0ms (0.2%)

Memory
5.6MiB live, 5.6MiB allocated
Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New707
Fresh000
Picked011
Done044
Total7512
Accuracy
89.4%
Counts
12 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
89.3%
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
2.5%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
2.5%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
2.8%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
3.1%
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Compiler

Compiled 174 to 86 computations (50.6% saved)

regimes19.0ms (1.4%)

Memory
-3.8MiB live, 34.6MiB allocated
Counts
5 → 1
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Outputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
Calls

7 calls:

5.0ms
x
2.0ms
(*.f64 x #s(literal 2 binary64))
2.0ms
z
2.0ms
(-.f64 (*.f64 y z) (*.f64 t z))
2.0ms
y
Results
AccuracySegmentsBranch
89.3%1x
89.3%1y
89.3%1z
89.3%1t
89.3%1(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
89.3%1(*.f64 x #s(literal 2 binary64))
89.3%1(-.f64 (*.f64 y z) (*.f64 t z))
Compiler

Compiled 25 to 39 computations (-56% saved)

regimes14.0ms (1.1%)

Memory
31.1MiB live, 31.1MiB allocated
Accuracy

Total -0.9b remaining (-1.4%)

Threshold costs -0.9b (-1.4%)

Counts
4 → 1
Calls
Call 1
Inputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 y z))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 (*.f64 y z) (*.f64 t z)))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (-.f64 #s(approx (* y z) (-.f64 (*.f64 y z) (*.f64 t z))) (*.f64 t z)))
Outputs
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Calls

7 calls:

2.0ms
y
2.0ms
(*.f64 x #s(literal 2 binary64))
2.0ms
z
2.0ms
t
2.0ms
x
Results
AccuracySegmentsBranch
3.1%1z
3.1%1t
3.1%1(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
3.1%1(-.f64 (*.f64 y z) (*.f64 t z))
3.1%1x
3.1%1y
3.1%1(*.f64 x #s(literal 2 binary64))
Compiler

Compiled 25 to 39 computations (-56% saved)

simplify5.0ms (0.4%)

Memory
-29.0MiB live, 10.2MiB allocated
Algorithm
egg-herbie
Calls
Call 1
Inputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))
Outputs
(/.f64 (*.f64 x #s(literal 2 binary64)) (-.f64 (*.f64 y z) (*.f64 t z)))
#s(approx (/ (* x 2) (- (* y z) (* t z))) (*.f64 t z))

soundness0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated
Stop Event
done
Compiler

Compiled 26 to 17 computations (34.6% saved)

preprocess35.0ms (2.6%)

Memory
3.8MiB live, 56.2MiB allocated
Compiler

Compiled 184 to 100 computations (45.7% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...