Diagrams.Backend.Rasterific:rasterificRadialGradient from diagrams-rasterific-1.3.1.3

Time bar (total: 1.1s)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

analyze43.0ms (3.8%)

Memory
-15.7MiB live, 67.5MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
50%49.9%49.9%0.1%0%0%0%4
50%49.9%49.9%0.1%0%0%0%5
50%49.9%49.9%0.1%0%0%0%6
75%74.9%25%0.1%0%0%0%7
75%74.9%25%0.1%0%0%0%8
75%74.9%25%0.1%0%0%0%9
87.5%87.4%12.5%0.1%0%0%0%10
87.5%87.4%12.5%0.1%0%0%0%11
87.5%87.4%12.5%0.1%0%0%0%12
Compiler

Compiled 11 to 9 computations (18.2% saved)

sample657.0ms (58.5%)

Memory
35.3MiB live, 1 138.9MiB allocated
Samples
410.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 206.0ms
ival-div: 61.0ms (29.6% of total)
ival-mult: 54.0ms (26.2% of total)
ival-sub: 46.0ms (22.4% of total)
ival-add: 37.0ms (18% of total)
ival-true: 6.0ms (2.9% of total)
ival-assert: 3.0ms (1.5% of total)
Bogosity

explain81.0ms (7.2%)

Memory
1.9MiB live, 159.7MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
310-0-(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
00-0-(+.f64 x (*.f64 y (-.f64 z x)))
00-0-y
00-0-(*.f64 y (-.f64 z x))
00-0-(-.f64 z x)
00-0-z
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
/.f64(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)o/n310
(+.f64 x (*.f64 y (-.f64 z x)))overflow41
(*.f64 y (-.f64 z x))overflow41
Confusion
Predicted +Predicted -
+310
-0225
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+3100
-00225
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
0225
131
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
36.0ms512×0valid
Compiler

Compiled 94 to 32 computations (66% saved)

Precisions
Click to see histograms. Total time spent on operations: 21.0ms
ival-sub: 10.0ms (46.5% of total)
ival-add: 4.0ms (18.6% of total)
ival-div: 3.0ms (14% of total)
ival-mult: 3.0ms (14% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess3.0ms (0.3%)

Memory
7.5MiB live, 7.5MiB allocated
Algorithm
egg-herbie
Calls
Call 1
Inputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Outputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Compiler

Compiled 9 to 7 computations (22.2% saved)

eval0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Compiler

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.0MiB live, 1.0MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.7%
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Compiler

Compiled 9 to 7 computations (22.2% saved)

simplify0.0ms (0%)

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

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(-.f64 z x)
cost-diff0
(*.f64 y (-.f64 z x))
cost-diff0
(+.f64 x (*.f64 y (-.f64 z x)))
cost-diff0
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Calls
Call 1
Inputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+.f64 x (*.f64 y (-.f64 z x)))
x
(*.f64 y (-.f64 z x))
y
(-.f64 z x)
z
Outputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+.f64 x (*.f64 y (-.f64 z x)))
x
(*.f64 y (-.f64 z x))
y
(-.f64 z x)
z

localize23.0ms (2.1%)

Memory
1.1MiB live, 39.2MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(-.f64 z x)
accuracy0.01171875
(+.f64 x (*.f64 y (-.f64 z x)))
accuracy0.01171875
(*.f64 y (-.f64 z x))
accuracy7.270333656883035
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Samples
18.0ms256×0valid
Compiler

Compiled 56 to 16 computations (71.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-div: 2.0ms (32.8% of total)
ival-mult: 2.0ms (32.8% of total)
ival-sub: 1.0ms (16.4% of total)
ival-add: 1.0ms (16.4% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series10.0ms (0.9%)

Memory
-22.4MiB live, 16.5MiB allocated
Counts
4 → 43
Calls
Call 1
Inputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
Outputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Calls

9 calls:

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

simplify0.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated
Algorithm
egg-herbie
Counts
43 → 4
Calls
Call 1
Inputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Outputs
y
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(+.f64 x (*.f64 y (-.f64 z x)))
(* y z)
(*.f64 y (-.f64 z x))
(+ (* x (+ 1 (* -1 y))) (* y z))
(-.f64 z x)

rewrite0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated
Counts
4 → 4
Calls
Call 1
Inputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
Outputs
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)

eval1.0ms (0.1%)

Memory
1.9MiB live, 1.9MiB allocated
Compiler

Compiled 100 to 17 computations (83% saved)

prune2.0ms (0.1%)

Memory
4.6MiB live, 4.6MiB allocated
Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New538
Fresh000
Picked011
Done000
Total549
Accuracy
88.7%
Counts
9 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.7%
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
3.6%
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
52.3%
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
5.8%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
Compiler

Compiled 54 to 37 computations (31.5% saved)

simplify1.0ms (0.1%)

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

Found 11 expressions of interest:

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

localize30.0ms (2.7%)

Memory
-57.1MiB live, 64.2MiB allocated
Localize:

Found 11 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(-.f64 z x)
accuracy7.270333656883035
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
accuracy62.06936906002636
#s(approx (+ x (* y (- z x))) (-.f64 z x))
accuracy0.0
(-.f64 z x)
accuracy0.01171875
(*.f64 y (-.f64 z x))
accuracy7.270333656883035
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
accuracy24.0971302302053
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
accuracy0.0
(-.f64 z x)
accuracy0.01171875
(+.f64 x (*.f64 y (-.f64 z x)))
accuracy0.01171875
(*.f64 y (-.f64 z x))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
Samples
17.0ms256×0valid
Compiler

Compiled 180 to 24 computations (86.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 7.0ms
ival-sub: 3.0ms (40.4% of total)
ival-div: 2.0ms (26.9% of total)
ival-mult: 2.0ms (26.9% of total)
ival-add: 1.0ms (13.5% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.4%)

Memory
10.0MiB live, 10.0MiB allocated
Counts
8 → 43
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
#s(approx (+ x (* y (- z x))) (-.f64 z x))
Outputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Calls

9 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (* y (- z x)) (- z x) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))))
1.0ms
y
@inf
((/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (* y (- z x)) (- z x) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))))
1.0ms
z
@-inf
((/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (* y (- z x)) (- z x) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))))
0.0ms
x
@-inf
((/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (* y (- z x)) (- z x) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))))
0.0ms
x
@inf
((/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (* y (- z x)) (- z x) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))) (/ (+ x (* y (- z x))) z) (+ x (* y (- z x))))

simplify1.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated
Algorithm
egg-herbie
Counts
43 → 8
Calls
Call 1
Inputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Outputs
y
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(+.f64 x (*.f64 y (-.f64 z x)))
(* y z)
(*.f64 y (-.f64 z x))
(+ (* x (+ 1 (* -1 y))) (* y z))
(-.f64 z x)
(+ (* -1 (* x y)) (* y z))
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
z
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(+ z (* -1 x))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
(/ (* x (+ 1 (* -1 y))) z)
#s(approx (+ x (* y (- z x))) (-.f64 z x))

rewrite0.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated
Counts
8 → 8
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
#s(approx (+ x (* y (- z x))) (-.f64 z x))
Outputs
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
(+.f64 x (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
#s(approx (+ x (* y (- z x))) (-.f64 z x))

eval2.0ms (0.2%)

Memory
4.8MiB live, 4.8MiB allocated
Compiler

Compiled 469 to 39 computations (91.7% saved)

prune4.0ms (0.3%)

Memory
8.6MiB live, 8.6MiB allocated
Pruning

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New17421
Fresh000
Picked033
Done011
Total17825
Accuracy
98.8%
Counts
25 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.7%
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
3.6%
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
52.3%
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
5.8%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
53.8%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
6.9%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
3.1%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
6.0%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
Compiler

Compiled 160 to 86 computations (46.3% saved)

simplify1.0ms (0.1%)

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

Found 15 expressions of interest:

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

localize33.0ms (2.9%)

Memory
-15.6MiB live, 61.8MiB allocated
Localize:

Found 15 expressions of interest:

NewMetricScoreProgram
accuracy7.270333656883035
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
accuracy61.99468254712575
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
accuracy62.06936906002636
#s(approx (+ x (* y (- z x))) (-.f64 z x))
accuracy0.01171875
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
accuracy24.0971302302053
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
accuracy62.06936906002636
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
accuracy0.0
(-.f64 z x)
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
accuracy62.06936906002636
#s(approx (+ x (* y (- z x))) (-.f64 z x))
accuracy0.0
(-.f64 z x)
accuracy0.01171875
(*.f64 y (-.f64 z x))
accuracy24.0971302302053
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
Samples
20.0ms256×0valid
Compiler

Compiled 452 to 31 computations (93.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-sub: 2.0ms (31.2% of total)
ival-div: 2.0ms (31.2% of total)
ival-mult: 2.0ms (31.2% of total)
ival-add: 1.0ms (15.6% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series6.0ms (0.5%)

Memory
12.1MiB live, 12.1MiB allocated
Counts
15 → 43
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (+ x (* y (- z x))) (-.f64 z x))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
(+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
Outputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Calls

9 calls:

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

simplify1.0ms (0.1%)

Memory
1.8MiB live, 1.8MiB allocated
Algorithm
egg-herbie
Counts
43 → 15
Calls
Call 1
Inputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Outputs
y
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(* y z)
(*.f64 y (-.f64 z x))
(+ (* x (+ 1 (* -1 y))) (* y z))
(-.f64 z x)
(+ (* -1 (* x y)) (* y z))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
z
#s(approx (+ x (* y (- z x))) (-.f64 z x))
(+ z (* -1 x))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
(/ (* x (+ 1 (* -1 y))) z)
(+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
(* x (+ 1 (* -1 y)))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(* -1 (* x y))
(+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(* x (+ (* -1 y) (/ (* y z) x)))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
(* -1 x)
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
(* x (- (/ z x) 1))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)

rewrite1.0ms (0.1%)

Memory
2.9MiB live, 2.9MiB allocated
Counts
15 → 15
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (+ x (* y (- z x))) (-.f64 z x))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
(+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
Outputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(*.f64 y (-.f64 z x))
(-.f64 z x)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (+ x (* y (- z x))) (-.f64 z x))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
(+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)

eval7.0ms (0.6%)

Memory
-27.8MiB live, 10.9MiB allocated
Compiler

Compiled 1 820 to 117 computations (93.6% saved)

prune7.0ms (0.6%)

Memory
16.6MiB live, 16.6MiB allocated
Pruning

10 alts after pruning (3 fresh and 7 done)

PrunedKeptTotal
New45348
Fresh000
Picked134
Done044
Total461056
Accuracy
100.0%
Counts
56 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.7%
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
3.6%
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
52.3%
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
5.8%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
6.9%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
7.0%
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
3.1%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
6.0%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
64.0%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
7.9%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
Compiler

Compiled 250 to 117 computations (53.2% saved)

simplify1.0ms (0.1%)

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

Found 12 expressions of interest:

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

localize34.0ms (3.1%)

Memory
-14.7MiB live, 65.5MiB allocated
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
accuracy0.01171875
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
accuracy24.0971302302053
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
accuracy60.12952445026238
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
accuracy62.06936906002636
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
accuracy24.0971302302053
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
accuracy61.99468254712575
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
accuracy62.06936906002636
#s(approx (+ x (* y (- z x))) (-.f64 z x))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
accuracy60.27889921837889
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
accuracy61.99468254712575
#s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))
accuracy62.06936906002636
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
Samples
21.0ms256×0valid
Compiler

Compiled 652 to 34 computations (94.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-div: 2.0ms (31.2% of total)
ival-mult: 2.0ms (31.2% of total)
ival-sub: 1.0ms (15.6% of total)
ival-add: 1.0ms (15.6% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series6.0ms (0.5%)

Memory
11.0MiB live, 11.0MiB allocated
Counts
14 → 43
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))))
(*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))
#s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
#s(approx (+ x (* y (- z x))) (-.f64 z x))
Outputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Calls

9 calls:

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

simplify1.0ms (0.1%)

Memory
1.2MiB live, 1.2MiB allocated
Algorithm
egg-herbie
Counts
43 → 14
Calls
Call 1
Inputs
y
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
(* y z)
(+ (* x (+ 1 (* -1 y))) (* y z))
(+ (* -1 (* x y)) (* y z))
z
(+ z (* -1 x))
(/ (* x (+ 1 (* -1 y))) z)
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
(* x (+ 1 (* -1 y)))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
(* -1 (* x y))
(* x (+ (* -1 y) (/ (* y z) x)))
(* -1 x)
(* x (- (/ z x) 1))
(* -1 (/ (* x (- y 1)) z))
(* -1 (* x (- (+ (* -1 (/ y x)) (/ y z)) (/ 1 z))))
(* -1 (* x (- y 1)))
(* -1 (* x (- (+ y (* -1 (/ (* y z) x))) 1)))
(* -1 (* x (+ y (* -1 (/ (* y z) x)))))
(* -1 (* x (+ 1 (* -1 (/ z x)))))
(/ x z)
(+ (* y (- 1 (/ x z))) (/ x z))
x
(+ x (* y (- z x)))
(* y (- z x))
(/ (* y (- z x)) z)
(* y (- (+ 1 (/ x (* y z))) (/ x z)))
(* y (- (+ z (/ x y)) x))
(* -1 (* y (+ (* -1 (/ x (* y z))) (* -1 (/ (- z x) z)))))
(* -1 (* y (+ (* -1 (- z x)) (* -1 (/ x y)))))
(/ (+ x (* -1 (* x y))) z)
(/ (+ x (+ (* -1 (* x y)) (* y z))) z)
(+ x (* -1 (* x y)))
(+ x (+ (* -1 (* x y)) (* y z)))
(- z x)
(+ y (+ (* -1 (/ (* x y) z)) (/ x z)))
(* z (+ y (+ (* -1 (/ (* x y) z)) (/ x z))))
(* z (+ y (* -1 (/ (* x y) z))))
(* z (+ 1 (* -1 (/ x z))))
(* -1 (* z (+ (* -1 y) (* -1 (/ (+ x (* -1 (* x y))) z)))))
(* -1 (* z (+ (* -1 y) (/ (* x y) z))))
(* -1 (* z (- (/ x z) 1)))
Outputs
y
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
(+ y (* x (+ (* -1 (/ y z)) (/ 1 z))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))))
(* y z)
(*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))
(+ (* x (+ 1 (* -1 y))) (* y z))
#s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))
(+ (* -1 (* x y)) (* y z))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
z
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(+ z (* -1 x))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
(/ (* x (+ 1 (* -1 y))) z)
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
(* x (+ (* -1 (/ y z)) (+ (/ 1 z) (/ y x))))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(* x (+ 1 (* -1 y)))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
(* x (+ 1 (+ (* -1 y) (/ (* y z) x))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
(* -1 (* x y))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
(* x (+ (* -1 y) (/ (* y z) x)))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
(* -1 x)
#s(approx (+ x (* y (- z x))) (-.f64 z x))

rewrite1.0ms (0.1%)

Memory
1.5MiB live, 1.5MiB allocated
Counts
14 → 14
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))))
(*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))
#s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
#s(approx (+ x (* y (- z x))) (-.f64 z x))
Outputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))))
(*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))
#s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
#s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))
(*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))
#s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))
#s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
#s(approx (+ x (* y (- z x))) (-.f64 z x))

eval3.0ms (0.3%)

Memory
5.6MiB live, 5.6MiB allocated
Compiler

Compiled 1 279 to 55 computations (95.7% saved)

prune7.0ms (0.6%)

Memory
13.0MiB live, 13.0MiB allocated
Pruning

10 alts after pruning (0 fresh and 10 done)

PrunedKeptTotal
New29029
Fresh000
Picked033
Done077
Total291039
Accuracy
100.0%
Counts
39 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
88.7%
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
3.6%
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
52.3%
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
5.8%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
6.9%
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
7.0%
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
3.1%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
6.0%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
64.0%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
7.9%
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
Compiler

Compiled 531 to 150 computations (71.8% saved)

regimes19.0ms (1.7%)

Memory
-5.0MiB live, 33.0MiB allocated
Counts
11 → 3
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Outputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
Calls

4 calls:

6.0ms
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
4.0ms
x
4.0ms
z
4.0ms
y
Results
AccuracySegmentsBranch
88.7%1x
99.9%3y
88.7%1z
97.5%3(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Compiler

Compiled 12 to 16 computations (-33.3% saved)

regimes18.0ms (1.6%)

Memory
-2.5MiB live, 35.6MiB allocated
Counts
10 → 1
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))))
(/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(/.f64 #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))) z)
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))))))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
Outputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
Calls

4 calls:

4.0ms
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
4.0ms
x
4.0ms
y
4.0ms
z
Results
AccuracySegmentsBranch
64.0%1x
64.0%1z
64.0%1(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
64.0%1y
Compiler

Compiled 12 to 16 computations (-33.3% saved)

regimes14.0ms (1.3%)

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

4 calls:

6.0ms
x
3.0ms
z
3.0ms
y
2.0ms
(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Results
AccuracySegmentsBranch
7.0%1y
7.0%1x
8.7%2z
7.0%1(/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z)
Compiler

Compiled 12 to 16 computations (-33.3% saved)

regimes7.0ms (0.7%)

Memory
17.0MiB live, 17.0MiB allocated
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x))))
Outputs
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
Calls

4 calls:

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

Compiled 12 to 16 computations (-33.3% saved)

regimes7.0ms (0.6%)

Memory
-24.4MiB live, 13.4MiB allocated
Accuracy

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

4 calls:

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

Compiled 12 to 16 computations (-33.3% saved)

bsearch28.0ms (2.5%)

Memory
4.0MiB live, 41.7MiB allocated
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
12.0ms
1366.6090057511512
2876523899073.1973
11.0ms
-4.9027456607257244e+20
-287342376700898780.0
Samples
13.0ms272×0valid
Compiler

Compiled 794 to 404 computations (49.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 7.0ms
ival-sub: 2.0ms (30.7% of total)
ival-div: 2.0ms (30.7% of total)
ival-mult: 2.0ms (30.7% of total)
ival-add: 1.0ms (15.4% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch13.0ms (1.2%)

Memory
22.8MiB live, 22.8MiB allocated
Algorithm
binary-search
Stop Event
narrow-enough
Steps
TimeLeftRight
12.0ms
-3.152807776208703e-291
-1.1455566469033274e-298
Samples
7.0ms144×0valid
Compiler

Compiled 426 to 247 computations (42% saved)

Precisions
Click to see histograms. Total time spent on operations: 3.0ms
ival-sub: 1.0ms (28.9% of total)
ival-div: 1.0ms (28.9% of total)
ival-add: 1.0ms (28.9% of total)
ival-mult: 1.0ms (28.9% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

simplify5.0ms (0.5%)

Memory
11.5MiB live, 11.5MiB allocated
Algorithm
egg-herbie
Calls
Call 1
Inputs
(if (<=.f64 y #s(literal -12500000000000000000 binary64)) #s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))) (if (<=.f64 y #s(literal 60000000 binary64)) (/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z) #s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(if (<=.f64 z #s(literal -2709713197585745/23562723457267347065789548996709904988477547858392600710143027597506337283178622239730365539602600561360255566462503270175052892578043215543382498428777152430442793326983968886135484527574528048424954488695685876133154086235991294800548739224807307629474678136450095282906365419648413375507379824836506306113175552 binary64)) #s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x)))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))
Outputs
(if (<=.f64 y #s(literal -12500000000000000000 binary64)) #s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z))))) (if (<=.f64 y #s(literal 60000000 binary64)) (/.f64 (+.f64 x (*.f64 y (-.f64 z x))) z) #s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y #s(approx (- z x) (/.f64 #s(approx (+ x (* y (- z x))) (-.f64 z x)) z)))))
(if (<=.f64 z #s(literal -2709713197585745/23562723457267347065789548996709904988477547858392600710143027597506337283178622239730365539602600561360255566462503270175052892578043215543382498428777152430442793326983968886135484527574528048424954488695685876133154086235991294800548739224807307629474678136450095282906365419648413375507379824836506306113175552 binary64)) #s(approx (/ (+ x (* y (- z x))) z) (*.f64 y #s(approx (- z x) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x)))))) #s(approx (/ (+ x (* y (- z x))) z) (+.f64 x (*.f64 y (-.f64 z x)))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (*.f64 y (-.f64 z x))))
#s(approx (/ (+ x (* y (- z x))) z) #s(approx (+ x (* y (- z x))) (-.f64 z x)))

soundness5.0ms (0.4%)

Memory
-33.1MiB live, 4.9MiB allocated
Stop Event
done
Compiler

Compiled 222 to 33 computations (85.1% saved)

preprocess36.0ms (3.2%)

Memory
28.1MiB live, 70.4MiB allocated
Compiler

Compiled 484 to 96 computations (80.2% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...