ab-angle->ABCF D

Time bar (total: 2.5s)

start0.0ms (0%)

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

analyze0.0ms (0%)

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

Compiled 10 to 8 computations (20% saved)

sample584.0ms (23.8%)

Memory
16.0MiB live, 572.6MiB allocated; 98ms collecting garbage
Samples
351.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 193.0ms
ival-mult: 149.0ms (77.2% of total)
ival-neg: 35.0ms (18.1% of total)
ival-true: 5.0ms (2.6% of total)
ival-assert: 3.0ms (1.6% of total)
adjust: 2.0ms (1% of total)
Bogosity

explain62.0ms (2.5%)

Memory
24.5MiB live, 77.7MiB allocated; 6ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
290-0-(*.f64 (*.f64 a a) b)
110-2(-1.4504866425740135e-242 -4.410132946500308e+171)(*.f64 (*.f64 (*.f64 a a) b) b)
00-0-(*.f64 a a)
00-0-(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
00-0-a
00-0-b
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
*.f64(*.f64 (*.f64 a a) b)n*o170
*.f64(*.f64 (*.f64 a a) b)n*u120
*.f64(*.f64 (*.f64 (*.f64 a a) b) b)n*o50
*.f64(*.f64 (*.f64 (*.f64 a a) b) b)n*u40
Confusion
Predicted +Predicted -
+380
-0218
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+3800
-00218
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
0218
138
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
26.0ms512×0valid
Compiler

Compiled 62 to 22 computations (64.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 12.0ms
ival-mult: 9.0ms (75.9% of total)
ival-neg: 2.0ms (16.9% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess27.0ms (1.1%)

Memory
-22.0MiB live, 23.9MiB allocated; 2ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01838
16038
224138
354238
478538
579038
068
0108
1248
2818
33038
47198
58448
08448
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Outputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
Symmetry

(abs b)

(abs a)

(sort a b)

Compiler

Compiled 8 to 6 computations (25% saved)

eval0.0ms (0%)

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

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
84.6%
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 8 to 6 computations (25% saved)

simplify10.0ms (0.4%)

Memory
8.3MiB live, 8.3MiB allocated; 0ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 a a)
cost-diff0
(*.f64 (*.f64 a a) b)
cost-diff0
(*.f64 (*.f64 (*.f64 a a) b) b)
cost-diff0
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0625
01025
12425
28125
330325
471925
584425
084425
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) b)
(*.f64 a a)
a
b
Outputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 a a) b)
(*.f64 b (*.f64 a a))
(*.f64 a a)
a
b

localize16.0ms (0.7%)

Memory
18.8MiB live, 18.8MiB allocated; 0ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 a a)
accuracy0.0
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
accuracy4.206596012782085
(*.f64 (*.f64 (*.f64 a a) b) b)
accuracy5.478763813825589
(*.f64 (*.f64 a a) b)
Samples
11.0ms256×0valid
Compiler

Compiled 27 to 8 computations (70.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-mult: 4.0ms (71.3% of total)
ival-neg: 1.0ms (17.8% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series6.0ms (0.3%)

Memory
7.6MiB live, 7.6MiB allocated; 0ms collecting garbage
Counts
4 → 4
Calls
Call 1
Inputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) b)
(*.f64 a a)
Outputs
(* -1 (* (pow a 2) (pow b 2)))
(* (pow a 2) (pow b 2))
(* (pow a 2) b)
(pow a 2)
Calls

6 calls:

TimeVariablePointExpression
1.0ms
a
@inf
((neg (* (* (* a a) b) b)) (* (* (* a a) b) b) (* (* a a) b) (* a a))
1.0ms
a
@0
((neg (* (* (* a a) b) b)) (* (* (* a a) b) b) (* (* a a) b) (* a a))
1.0ms
b
@0
((neg (* (* (* a a) b) b)) (* (* (* a a) b) b) (* (* a a) b) (* a a))
1.0ms
b
@-inf
((neg (* (* (* a a) b) b)) (* (* (* a a) b) b) (* (* a a) b) (* a a))
1.0ms
a
@-inf
((neg (* (* (* a a) b) b)) (* (* (* a a) b) b) (* (* a a) b) (* a a))

simplify171.0ms (6.9%)

Memory
-24.9MiB live, 117.8MiB allocated; 49ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0923
11923
26223
327123
491923
5132223
6406623
0836223
Stop Event
iter limit
node limit
Counts
4 → 4
Calls
Call 1
Inputs
(* -1 (* (pow a 2) (pow b 2)))
(* (pow a 2) (pow b 2))
(* (pow a 2) b)
(pow a 2)
Outputs
(* -1 (* (pow a 2) (pow b 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 a) b) b) a)
(* (pow a 2) (pow b 2))
(*.f64 (*.f64 (*.f64 b a) b) a)
(* (pow a 2) b)
(*.f64 (*.f64 a a) b)
(pow a 2)
(*.f64 a a)

rewrite41.0ms (1.6%)

Memory
9.5MiB live, 53.7MiB allocated; 6ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0623
01022
12622
29418
041418
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
4 → 112
Calls
Call 1
Inputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) b)
(*.f64 a a)
Outputs
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (*.f64 (neg.f64 b) (*.f64 (neg.f64 b) a)) (neg.f64 a))
(*.f64 (*.f64 (fabs.f64 b) (neg.f64 a)) (*.f64 (fabs.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 a) (fabs.f64 b)) (*.f64 (neg.f64 a) (fabs.f64 b)))
(*.f64 (*.f64 (neg.f64 a) (neg.f64 b)) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 a (fabs.f64 b)) (*.f64 a (fabs.f64 b)))
(*.f64 (neg.f64 (*.f64 (neg.f64 b) a)) (neg.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (neg.f64 (*.f64 (neg.f64 b) a)) (*.f64 (neg.f64 b) a))
(*.f64 (fabs.f64 (*.f64 (neg.f64 b) a)) (fabs.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (fabs.f64 (*.f64 b a)) (fabs.f64 (*.f64 b a)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (neg.f64 b) a) (neg.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (neg.f64 b) (*.f64 b (*.f64 a a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 (neg.f64 b) b)))
(*.f64 (neg.f64 a) (neg.f64 (*.f64 (*.f64 (neg.f64 b) a) b)))
(*.f64 (neg.f64 a) (*.f64 (*.f64 (neg.f64 b) a) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 b a) b))
(*.f64 (*.f64 b (*.f64 a a)) (neg.f64 b))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 b (*.f64 b (*.f64 a a)))
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 a (*.f64 (*.f64 (neg.f64 b) a) b))
(*.f64 a (*.f64 (*.f64 b a) b))
(pow.f64 (*.f64 (neg.f64 b) a) #s(literal 2 binary64))
(pow.f64 (*.f64 b a) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (*.f64 (neg.f64 b) (*.f64 (neg.f64 b) a)) (neg.f64 a))
(*.f64 (*.f64 (fabs.f64 b) (neg.f64 a)) (*.f64 (fabs.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 a) (fabs.f64 b)) (*.f64 (neg.f64 a) (fabs.f64 b)))
(*.f64 (*.f64 (neg.f64 a) (neg.f64 b)) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 a (fabs.f64 b)) (*.f64 a (fabs.f64 b)))
(*.f64 (neg.f64 (*.f64 (neg.f64 b) a)) (neg.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (neg.f64 (*.f64 (neg.f64 b) a)) (*.f64 (neg.f64 b) a))
(*.f64 (fabs.f64 (*.f64 (neg.f64 b) a)) (fabs.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (fabs.f64 (*.f64 b a)) (fabs.f64 (*.f64 b a)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (neg.f64 b) a) (neg.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (neg.f64 b) (*.f64 b (*.f64 a a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 (neg.f64 b) b)))
(*.f64 (neg.f64 a) (neg.f64 (*.f64 (*.f64 (neg.f64 b) a) b)))
(*.f64 (neg.f64 a) (*.f64 (*.f64 (neg.f64 b) a) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 b a) b))
(*.f64 (*.f64 b (*.f64 a a)) (neg.f64 b))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 b (*.f64 b (*.f64 a a)))
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 a (*.f64 (*.f64 (neg.f64 b) a) b))
(*.f64 a (*.f64 (*.f64 b a) b))
(pow.f64 (*.f64 (neg.f64 b) a) #s(literal 2 binary64))
(pow.f64 (*.f64 b a) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (neg.f64 a))
(*.f64 (neg.f64 (*.f64 (neg.f64 b) a)) (neg.f64 a))
(*.f64 (*.f64 (neg.f64 b) a) (neg.f64 a))
(*.f64 (*.f64 (neg.f64 b) a) a)
(*.f64 (*.f64 b a) (neg.f64 a))
(*.f64 (*.f64 b a) a)
(*.f64 (neg.f64 b) (*.f64 a a))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (neg.f64 a) (neg.f64 (*.f64 (neg.f64 b) a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 b) a))
(*.f64 (neg.f64 a) (*.f64 b a))
(*.f64 b (*.f64 a a))
(*.f64 (*.f64 a a) (neg.f64 b))
(*.f64 (*.f64 a a) b)
(*.f64 a (*.f64 (neg.f64 b) a))
(*.f64 a (*.f64 b a))
(neg.f64 (*.f64 b (*.f64 a a)))
(*.f64 (exp.f64 (log.f64 a)) (exp.f64 (log.f64 a)))
(*.f64 (neg.f64 a) (neg.f64 a))
(*.f64 (neg.f64 a) a)
(*.f64 a (neg.f64 a))
(*.f64 a a)
(pow.f64 (exp.f64 (log.f64 a)) #s(literal 2 binary64))
(pow.f64 (neg.f64 a) #s(literal 2 binary64))
(pow.f64 (*.f64 a a) #s(literal 1 binary64))
(pow.f64 a #s(literal 2 binary64))
(neg.f64 (*.f64 a a))
(sqrt.f64 (*.f64 (*.f64 a a) (*.f64 a a)))
(fabs.f64 (*.f64 a a))
(exp.f64 (*.f64 (log.f64 (neg.f64 a)) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 a) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))))

eval7.0ms (0.3%)

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

Compiled 717 to 199 computations (72.2% saved)

prune7.0ms (0.3%)

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

10 alts after pruning (9 fresh and 1 done)

PrunedKeptTotal
New67976
Fresh000
Picked011
Done000
Total671077
Accuracy
100.0%
Counts
77 → 10
Alt Table
Click to see full alt table
StatusAccuracyProgram
95.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
34.5%
(*.f64 (*.f64 (*.f64 b a) b) a)
78.7%
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
99.7%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
34.8%
(*.f64 (*.f64 b (*.f64 a a)) b)
34.4%
(*.f64 (*.f64 b b) (*.f64 a a))
34.6%
(*.f64 (*.f64 b a) (*.f64 b a))
83.8%
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 (neg.f64 b) b)))
93.4%
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
84.6%
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 148 to 106 computations (28.4% saved)

simplify17.0ms (0.7%)

Memory
-29.4MiB live, 15.1MiB allocated; 5ms collecting garbage
Localize:

Found 17 expressions of interest:

NewMetricScoreProgram
cost-diff0
(neg.f64 b)
cost-diff0
(*.f64 (neg.f64 b) a)
cost-diff0
(*.f64 (*.f64 (neg.f64 b) a) b)
cost-diff0
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
cost-diff0
(*.f64 b a)
cost-diff0
(*.f64 (*.f64 b a) a)
cost-diff0
(*.f64 (*.f64 (*.f64 b a) a) b)
cost-diff0
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
cost-diff0
(*.f64 a a)
cost-diff0
(*.f64 b (*.f64 a a))
cost-diff0
(*.f64 (*.f64 b (*.f64 a a)) b)
cost-diff0
(*.f64 b a)
cost-diff0
(*.f64 (*.f64 b a) (*.f64 b a))
cost-diff0
(*.f64 b a)
cost-diff0
(neg.f64 b)
cost-diff0
(*.f64 (neg.f64 b) a)
cost-diff0
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01595
02895
15995
214495
338195
475095
582695
082695
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(*.f64 b a)
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 b a)
b
a
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 b (*.f64 a a))
b
(*.f64 a a)
a
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (*.f64 b a) a) b)
(*.f64 (*.f64 b a) a)
(*.f64 b a)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (neg.f64 b) a) b)
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
Outputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (*.f64 (*.f64 b b) a) (neg.f64 a))
(*.f64 (neg.f64 b) a)
(*.f64 a (neg.f64 b))
(neg.f64 b)
b
a
(*.f64 b a)
(*.f64 a b)
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 b a)
(*.f64 a b)
b
a
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 b (*.f64 a a))
(*.f64 (*.f64 a a) b)
b
(*.f64 a a)
a
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (*.f64 b b) a) (neg.f64 a))
(*.f64 (*.f64 (*.f64 b a) a) b)
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 b a) a)
(*.f64 (*.f64 a a) b)
(*.f64 b a)
(*.f64 a b)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (*.f64 b b) a) (neg.f64 a))
(*.f64 (*.f64 (neg.f64 b) a) b)
(*.f64 (*.f64 a (neg.f64 b)) b)
(*.f64 (neg.f64 b) a)
(*.f64 a (neg.f64 b))
(neg.f64 b)
b
a

localize45.0ms (1.8%)

Memory
15.2MiB live, 59.7MiB allocated; 7ms collecting garbage
Localize:

Found 17 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 (neg.f64 b) a)
accuracy0.0
(neg.f64 b)
accuracy0.08984375
(*.f64 (*.f64 (neg.f64 b) a) b)
accuracy2.620707637787172
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
accuracy0.0
(*.f64 b a)
accuracy0.0
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
accuracy0.1015625
(*.f64 (*.f64 b a) a)
accuracy4.206596012782085
(*.f64 (*.f64 (*.f64 b a) a) b)
accuracy0.0
(*.f64 a a)
accuracy4.206596012782085
(*.f64 (*.f64 b (*.f64 a a)) b)
accuracy5.478763813825589
(*.f64 b (*.f64 a a))
accuracy0.0
(*.f64 b a)
accuracy0.174160009768442
(*.f64 (*.f64 b a) (*.f64 b a))
accuracy0.0
(*.f64 (neg.f64 b) a)
accuracy0.0
(*.f64 b a)
accuracy0.0
(neg.f64 b)
accuracy0.174160009768442
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
Samples
28.0ms256×0valid
Compiler

Compiled 97 to 17 computations (82.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 17.0ms
ival-mult: 15.0ms (87.3% of total)
ival-neg: 2.0ms (11.6% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series11.0ms (0.4%)

Memory
18.5MiB live, 18.5MiB allocated; 0ms collecting garbage
Counts
13 → 8
Calls
Call 1
Inputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 b a)
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 b (*.f64 a a))
(*.f64 a a)
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (*.f64 b a) a) b)
(*.f64 (*.f64 b a) a)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (neg.f64 b) a) b)
Outputs
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (* a b))
(* a b)
(* (pow a 2) (pow b 2))
(* (pow a 2) b)
(pow a 2)
(* -1 (* a (pow b 2)))
(* -1 b)
Calls

6 calls:

TimeVariablePointExpression
2.0ms
a
@0
((* (* (neg b) a) (* b a)) (* (neg b) a) (neg b) (* b a) (* (* b a) (* b a)) (* (* b (* a a)) b) (* b (* a a)) (* a a) (neg (* (* (* b a) a) b)) (* (* (* b a) a) b) (* (* b a) a) (* (* (* (neg b) a) b) a) (* (* (neg b) a) b))
2.0ms
b
@-inf
((* (* (neg b) a) (* b a)) (* (neg b) a) (neg b) (* b a) (* (* b a) (* b a)) (* (* b (* a a)) b) (* b (* a a)) (* a a) (neg (* (* (* b a) a) b)) (* (* (* b a) a) b) (* (* b a) a) (* (* (* (neg b) a) b) a) (* (* (neg b) a) b))
2.0ms
b
@inf
((* (* (neg b) a) (* b a)) (* (neg b) a) (neg b) (* b a) (* (* b a) (* b a)) (* (* b (* a a)) b) (* b (* a a)) (* a a) (neg (* (* (* b a) a) b)) (* (* (* b a) a) b) (* (* b a) a) (* (* (* (neg b) a) b) a) (* (* (neg b) a) b))
2.0ms
a
@inf
((* (* (neg b) a) (* b a)) (* (neg b) a) (neg b) (* b a) (* (* b a) (* b a)) (* (* b (* a a)) b) (* b (* a a)) (* a a) (neg (* (* (* b a) a) b)) (* (* (* b a) a) b) (* (* b a) a) (* (* (* (neg b) a) b) a) (* (* (neg b) a) b))
2.0ms
b
@0
((* (* (neg b) a) (* b a)) (* (neg b) a) (neg b) (* b a) (* (* b a) (* b a)) (* (* b (* a a)) b) (* b (* a a)) (* a a) (neg (* (* (* b a) a) b)) (* (* (* b a) a) b) (* (* b a) a) (* (* (* (neg b) a) b) a) (* (* (neg b) a) b))

simplify115.0ms (4.7%)

Memory
-21.2MiB live, 75.6MiB allocated; 22ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01438
13538
28738
324538
492438
5227338
6481438
0806338
Stop Event
iter limit
node limit
Counts
8 → 8
Calls
Call 1
Inputs
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (* a b))
(* a b)
(* (pow a 2) (pow b 2))
(* (pow a 2) b)
(pow a 2)
(* -1 (* a (pow b 2)))
(* -1 b)
Outputs
(* -1 (* (pow a 2) (pow b 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 a) a) b) b)
(* -1 (* a b))
(*.f64 (neg.f64 a) b)
(* a b)
(*.f64 a b)
(* (pow a 2) (pow b 2))
(*.f64 (*.f64 a b) (*.f64 a b))
(* (pow a 2) b)
(*.f64 (*.f64 a a) b)
(pow a 2)
(*.f64 a a)
(* -1 (* a (pow b 2)))
(*.f64 (*.f64 a b) (neg.f64 b))
(* -1 b)
(neg.f64 b)

rewrite48.0ms (2%)

Memory
-0.4MiB live, 44.6MiB allocated; 6ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01573
02876
16264
216658
061058
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
13 → 350
Calls
Call 1
Inputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 b a)
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 b (*.f64 a a))
(*.f64 a a)
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (*.f64 b a) a) b)
(*.f64 (*.f64 b a) a)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (neg.f64 b) a) b)
Outputs
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (neg.f64 (fabs.f64 b)) a)
(*.f64 (fabs.f64 b) (neg.f64 a))
(*.f64 (neg.f64 a) (fabs.f64 b))
(*.f64 (neg.f64 a) b)
(*.f64 a (neg.f64 (fabs.f64 b)))
(*.f64 a (neg.f64 b))
(*.f64 (neg.f64 b) a)
(*.f64 b (neg.f64 a))
(neg.f64 (*.f64 a b))
(neg.f64 b)
(*.f64 (pow.f64 (*.f64 a b) #s(literal 1/2 binary64)) (pow.f64 (*.f64 a b) #s(literal 1/2 binary64)))
(*.f64 (neg.f64 (neg.f64 b)) a)
(*.f64 (fabs.f64 (fabs.f64 b)) a)
(*.f64 (sqrt.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) (sqrt.f64 (neg.f64 a)))
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
(*.f64 (sqrt.f64 (*.f64 a (neg.f64 b))) (sqrt.f64 (*.f64 a (neg.f64 b))))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a b) b)) (sqrt.f64 a))
(*.f64 (sqrt.f64 a) (sqrt.f64 (*.f64 (*.f64 a b) b)))
(*.f64 (sqrt.f64 (neg.f64 b)) (sqrt.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a a) b)) (sqrt.f64 (neg.f64 b)))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a a) b)) (sqrt.f64 b))
(*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (pow.f64 b #s(literal 1 binary64)) a)
(*.f64 (fabs.f64 b) a)
(*.f64 (neg.f64 a) (neg.f64 b))
(*.f64 a (neg.f64 (neg.f64 b)))
(*.f64 a (fabs.f64 (fabs.f64 b)))
(*.f64 a (pow.f64 b #s(literal 1 binary64)))
(*.f64 a (fabs.f64 b))
(*.f64 a b)
(*.f64 (neg.f64 b) (neg.f64 a))
(*.f64 b a)
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (*.f64 a b) #s(literal 1 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 1 binary64))
(neg.f64 (*.f64 a (neg.f64 b)))
(sqrt.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(fabs.f64 (*.f64 a b))
(fabs.f64 (*.f64 a (neg.f64 b)))
(exp.f64 (/.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 1 binary64)))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (neg.f64 a) (*.f64 a b))
(*.f64 (neg.f64 a) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a a) (neg.f64 b))
(*.f64 (*.f64 a a) b)
(*.f64 (*.f64 a b) (neg.f64 a))
(*.f64 (*.f64 a b) a)
(*.f64 (*.f64 a (neg.f64 b)) (neg.f64 a))
(*.f64 (*.f64 a (neg.f64 b)) a)
(*.f64 a (*.f64 a b))
(*.f64 a (*.f64 a (neg.f64 b)))
(*.f64 (neg.f64 b) (*.f64 a a))
(*.f64 b (*.f64 a a))
(neg.f64 (*.f64 (*.f64 a a) b))
(*.f64 (exp.f64 (log.f64 a)) (exp.f64 (log.f64 a)))
(*.f64 (neg.f64 a) (neg.f64 a))
(*.f64 (neg.f64 a) a)
(*.f64 a (neg.f64 a))
(*.f64 a a)
(pow.f64 (exp.f64 (log.f64 a)) #s(literal 2 binary64))
(pow.f64 (neg.f64 a) #s(literal 2 binary64))
(pow.f64 (*.f64 a a) #s(literal 1 binary64))
(pow.f64 a #s(literal 2 binary64))
(neg.f64 (*.f64 a a))
(sqrt.f64 (*.f64 (*.f64 a a) (*.f64 a a)))
(fabs.f64 (*.f64 a a))
(exp.f64 (*.f64 (log.f64 (neg.f64 a)) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 a) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 a) #s(literal 2 binary64))))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (neg.f64 a) (*.f64 a b))
(*.f64 (neg.f64 a) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a a) (neg.f64 b))
(*.f64 (*.f64 a a) b)
(*.f64 (*.f64 a b) (neg.f64 a))
(*.f64 (*.f64 a b) a)
(*.f64 (*.f64 a (neg.f64 b)) (neg.f64 a))
(*.f64 (*.f64 a (neg.f64 b)) a)
(*.f64 a (*.f64 a b))
(*.f64 a (*.f64 a (neg.f64 b)))
(*.f64 (neg.f64 b) (*.f64 a a))
(*.f64 b (*.f64 a a))
(neg.f64 (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) (fabs.f64 b)) a)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (*.f64 (*.f64 a a) b))
(*.f64 (fabs.f64 (*.f64 (*.f64 a (neg.f64 b)) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a b) b)) a)
(*.f64 (fabs.f64 (*.f64 (*.f64 a a) b)) (fabs.f64 b))
(*.f64 (exp.f64 (log.f64 (*.f64 a b))) (exp.f64 (log.f64 (*.f64 a b))))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (fabs.f64 b) (fabs.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (fabs.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a b) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a b) b) a)
(*.f64 (neg.f64 a) (*.f64 (*.f64 a b) b))
(*.f64 (neg.f64 a) (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) (neg.f64 a))
(*.f64 (*.f64 (*.f64 a (neg.f64 b)) b) a)
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 (neg.f64 b)))
(*.f64 (*.f64 (*.f64 a a) b) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 a b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a b))
(*.f64 (*.f64 a (neg.f64 b)) (*.f64 a (neg.f64 b)))
(*.f64 a (fabs.f64 (*.f64 (*.f64 a b) b)))
(*.f64 a (*.f64 (*.f64 a b) b))
(*.f64 a (*.f64 (*.f64 a (neg.f64 b)) b))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 b (*.f64 (*.f64 a a) b))
(pow.f64 (exp.f64 (log.f64 (*.f64 a b))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (*.f64 a b) #s(literal 2 binary64))
(pow.f64 (*.f64 a (neg.f64 b)) #s(literal 2 binary64))
(neg.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)) (pow.f64 (*.f64 a b) #s(literal 2 binary64))))
(fabs.f64 (pow.f64 (*.f64 a b) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a (neg.f64 b))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 2 binary64))))
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (fabs.f64 b) (*.f64 a (neg.f64 b)))
(*.f64 (*.f64 b b) (neg.f64 a))
(*.f64 (neg.f64 a) (*.f64 b b))
(*.f64 (*.f64 a b) (neg.f64 b))
(*.f64 (*.f64 a (neg.f64 b)) b)
(*.f64 a (*.f64 (neg.f64 b) b))
(*.f64 (neg.f64 b) (*.f64 a b))
(*.f64 b (*.f64 a (neg.f64 b)))
(neg.f64 (*.f64 (*.f64 a b) b))

eval25.0ms (1%)

Memory
-6.2MiB live, 38.5MiB allocated; 8ms collecting garbage
Compiler

Compiled 2 386 to 461 computations (80.7% saved)

prune401.0ms (16.3%)

Memory
5.9MiB live, 115.9MiB allocated; 680ms collecting garbage
Pruning

11 alts after pruning (5 fresh and 6 done)

PrunedKeptTotal
New2353238
Fresh224
Picked055
Done011
Total23711248
Accuracy
100.0%
Counts
248 → 11
Alt Table
Click to see full alt table
StatusAccuracyProgram
83.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
95.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
34.5%
(*.f64 (*.f64 (*.f64 b a) b) a)
34.7%
(*.f64 (*.f64 (*.f64 a b) a) b)
99.6%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
99.7%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
34.8%
(*.f64 (*.f64 b (*.f64 a a)) b)
34.4%
(*.f64 (*.f64 b b) (*.f64 a a))
34.6%
(*.f64 (*.f64 b a) (*.f64 b a))
93.4%
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
84.6%
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 132 to 91 computations (31.1% saved)

simplify172.0ms (7%)

Memory
5.3MiB live, 97.1MiB allocated; 5ms collecting garbage
Localize:

Found 17 expressions of interest:

NewMetricScoreProgram
cost-diff0
(neg.f64 b)
cost-diff0
(*.f64 (neg.f64 b) b)
cost-diff0
(*.f64 (*.f64 (neg.f64 b) b) a)
cost-diff1
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
cost-diff0
(*.f64 b a)
cost-diff0
(*.f64 (*.f64 b a) b)
cost-diff1
(*.f64 (*.f64 (*.f64 b a) b) a)
cost-diff0
(*.f64 a b)
cost-diff0
(*.f64 (*.f64 a b) a)
cost-diff1
(*.f64 (*.f64 (*.f64 a b) a) b)
cost-diff0
(*.f64 a a)
cost-diff0
(*.f64 b b)
cost-diff1
(*.f64 (*.f64 b b) (*.f64 a a))
cost-diff0
(neg.f64 b)
cost-diff0
(*.f64 (neg.f64 b) a)
cost-diff1
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
cost-diff6
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
019109
03697
17997
223097
372492
4108392
5137692
6138092
7139092
8142292
9160592
10319992
11620592
0831092
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
(sqrt.f64 (*.f64 a b))
(*.f64 a b)
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 b b)
b
(*.f64 a a)
a
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 a b) a)
(*.f64 a b)
a
b
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 b a) b)
(*.f64 b a)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (neg.f64 b) b)
(neg.f64 b)
b
a
Outputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
(neg.f64 (pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64)))
(*.f64 (neg.f64 b) a)
(*.f64 a (neg.f64 b))
(neg.f64 b)
b
a
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
(*.f64 a b)
(sqrt.f64 (*.f64 a b))
(*.f64 a b)
(*.f64 (*.f64 b b) (*.f64 a a))
(pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64))
(*.f64 b b)
b
(*.f64 a a)
a
(*.f64 (*.f64 (*.f64 a b) a) b)
(pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64))
(*.f64 (*.f64 a b) a)
(*.f64 (*.f64 a a) b)
(*.f64 a b)
a
b
(*.f64 (*.f64 (*.f64 b a) b) a)
(pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64))
(*.f64 (*.f64 b a) b)
(*.f64 (*.f64 b b) a)
(*.f64 b a)
(*.f64 a b)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(neg.f64 (pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64)))
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (neg.f64 b) b)
(neg.f64 b)
b
a

localize60.0ms (2.4%)

Memory
8.9MiB live, 60.9MiB allocated; 5ms collecting garbage
Localize:

Found 17 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 (neg.f64 b) b)
accuracy0.0
(neg.f64 b)
accuracy2.620707637787172
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
accuracy7.629113824420289
(*.f64 (*.f64 (neg.f64 b) b) a)
accuracy0.0
(*.f64 b a)
accuracy0.08984375
(*.f64 (*.f64 b a) b)
accuracy2.620707637787172
(*.f64 (*.f64 (*.f64 b a) b) a)
accuracy0.0
(*.f64 a b)
accuracy0.1015625
(*.f64 (*.f64 a b) a)
accuracy4.206596012782085
(*.f64 (*.f64 (*.f64 a b) a) b)
accuracy0.0
(*.f64 b b)
accuracy0.0
(*.f64 a a)
accuracy13.393280482751242
(*.f64 (*.f64 b b) (*.f64 a a))
accuracy0.0
(neg.f64 b)
accuracy0.174160009768442
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
accuracy0.33107377930532605
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
accuracy15.92737144474589
(sqrt.f64 (*.f64 a b))
Samples
47.0ms256×0valid
Compiler

Compiled 111 to 21 computations (81.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 35.0ms
ival-mult: 23.0ms (65.6% of total)
ival-sqrt: 11.0ms (31.4% of total)
ival-neg: 1.0ms (2.9% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series26.0ms (1.1%)

Memory
-26.4MiB live, 19.7MiB allocated; 6ms collecting garbage
Counts
17 → 15
Calls
Call 1
Inputs
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 b b)
(*.f64 a a)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 a b) a)
(*.f64 a b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 b a) b)
(*.f64 b a)
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (neg.f64 b) b)
(sqrt.f64 (*.f64 a b))
Outputs
(* a b)
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (* a b))
(* (pow a 2) (pow b 2))
(pow a 2)
(* (pow a 2) b)
(* a (pow b 2))
(* -1 (* a (pow b 2)))
(sqrt (* a b))
(* -1 (* a (* b (pow (sqrt -1) 2))))
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(* -1 b)
(pow b 2)
(* -1 (pow b 2))
Calls

6 calls:

TimeVariablePointExpression
12.0ms
a
@inf
((* (sqrt (* a b)) (sqrt (* a b))) (* (* (neg b) a) (* (sqrt (* a b)) (sqrt (* a b)))) (* (neg b) a) (neg b) (* (* b b) (* a a)) (* b b) (* a a) (* (* (* a b) a) b) (* (* a b) a) (* a b) (* (* (* b a) b) a) (* (* b a) b) (* b a) (* (* (* (neg b) b) a) a) (* (* (neg b) b) a) (* (neg b) b) (sqrt (* a b)))
4.0ms
a
@-inf
((* (sqrt (* a b)) (sqrt (* a b))) (* (* (neg b) a) (* (sqrt (* a b)) (sqrt (* a b)))) (* (neg b) a) (neg b) (* (* b b) (* a a)) (* b b) (* a a) (* (* (* a b) a) b) (* (* a b) a) (* a b) (* (* (* b a) b) a) (* (* b a) b) (* b a) (* (* (* (neg b) b) a) a) (* (* (neg b) b) a) (* (neg b) b) (sqrt (* a b)))
3.0ms
b
@-inf
((* (sqrt (* a b)) (sqrt (* a b))) (* (* (neg b) a) (* (sqrt (* a b)) (sqrt (* a b)))) (* (neg b) a) (neg b) (* (* b b) (* a a)) (* b b) (* a a) (* (* (* a b) a) b) (* (* a b) a) (* a b) (* (* (* b a) b) a) (* (* b a) b) (* b a) (* (* (* (neg b) b) a) a) (* (* (neg b) b) a) (* (neg b) b) (sqrt (* a b)))
2.0ms
b
@inf
((* (sqrt (* a b)) (sqrt (* a b))) (* (* (neg b) a) (* (sqrt (* a b)) (sqrt (* a b)))) (* (neg b) a) (neg b) (* (* b b) (* a a)) (* b b) (* a a) (* (* (* a b) a) b) (* (* a b) a) (* a b) (* (* (* b a) b) a) (* (* b a) b) (* b a) (* (* (* (neg b) b) a) a) (* (* (neg b) b) a) (* (neg b) b) (sqrt (* a b)))
2.0ms
a
@0
((* (sqrt (* a b)) (sqrt (* a b))) (* (* (neg b) a) (* (sqrt (* a b)) (sqrt (* a b)))) (* (neg b) a) (neg b) (* (* b b) (* a a)) (* b b) (* a a) (* (* (* a b) a) b) (* (* a b) a) (* a b) (* (* (* b a) b) a) (* (* b a) b) (* b a) (* (* (* (neg b) b) a) a) (* (* (neg b) b) a) (* (neg b) b) (sqrt (* a b)))

simplify22.0ms (0.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
02569
16369
217769
062169
Stop Event
iter limit
iter limit
iter limit
unsound
Counts
15 → 15
Calls
Call 1
Inputs
(* a b)
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (* a b))
(* (pow a 2) (pow b 2))
(pow a 2)
(* (pow a 2) b)
(* a (pow b 2))
(* -1 (* a (pow b 2)))
(sqrt (* a b))
(* -1 (* a (* b (pow (sqrt -1) 2))))
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(* -1 b)
(pow b 2)
(* -1 (pow b 2))
Outputs
(* a b)
(*.f64 b a)
(* -1 (* (pow a 2) (pow b 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 a) a) b) b)
(* -1 (* a b))
(*.f64 (neg.f64 a) b)
(* (pow a 2) (pow b 2))
(*.f64 (*.f64 (*.f64 b b) a) a)
(pow a 2)
(*.f64 a a)
(* (pow a 2) b)
(*.f64 (*.f64 a a) b)
(* a (pow b 2))
(*.f64 (*.f64 b b) a)
(* -1 (* a (pow b 2)))
(*.f64 (*.f64 (neg.f64 b) b) a)
(sqrt (* a b))
(sqrt.f64 (*.f64 b a))
(* -1 (* a (* b (pow (sqrt -1) 2))))
(*.f64 b a)
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 a) a) b) b)
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(sqrt.f64 (*.f64 b a))
(* -1 b)
(neg.f64 b)
(pow b 2)
(*.f64 b b)
(* -1 (pow b 2))
(*.f64 (neg.f64 b) b)

rewrite50.0ms (2%)

Memory
-17.0MiB live, 28.8MiB allocated; 3ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01994
03682
18972
033172
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
17 → 294
Calls
Call 1
Inputs
(*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 b b)
(*.f64 a a)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 a b) a)
(*.f64 a b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 b a) b)
(*.f64 b a)
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (neg.f64 b) b)
(sqrt.f64 (*.f64 a b))
Outputs
(*.f64 (*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (sqrt.f64 a) (sqrt.f64 a)) (*.f64 (sqrt.f64 b) (sqrt.f64 b)))
(*.f64 (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a a) b)) (sqrt.f64 b))
(*.f64 (sqrt.f64 (*.f64 (*.f64 b b) a)) (sqrt.f64 a))
(*.f64 (pow.f64 (sqrt.f64 a) #s(literal 2 binary64)) (pow.f64 (sqrt.f64 b) #s(literal 2 binary64)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (fabs.f64 a) (fabs.f64 b))
(*.f64 (fabs.f64 b) (fabs.f64 a))
(*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 b a))))
(*.f64 (sqrt.f64 a) (sqrt.f64 (*.f64 (*.f64 b b) a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 (*.f64 b a)))
(*.f64 b a)
(*.f64 a b)
(pow.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 2 binary64))
(pow.f64 (*.f64 b a) #s(literal 1 binary64))
(neg.f64 (*.f64 (neg.f64 b) a))
(sqrt.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(fabs.f64 (*.f64 b a))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) (neg.f64 a)) (neg.f64 a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) (fabs.f64 a)) (fabs.f64 a))
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) a) b)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(*.f64 b (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 b (*.f64 a (*.f64 (neg.f64 b) a)))
(*.f64 a (*.f64 (*.f64 (neg.f64 b) b) a))
(neg.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(*.f64 (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (neg.f64 a) b)
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 b) a)
(*.f64 (sqrt.f64 (*.f64 b a)) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 b (neg.f64 a))
(*.f64 a (neg.f64 b))
(neg.f64 (*.f64 b a))
(neg.f64 b)
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) (neg.f64 b)) (neg.f64 b))
(*.f64 (*.f64 (*.f64 b b) (neg.f64 a)) (neg.f64 a))
(*.f64 (*.f64 (*.f64 b b) (fabs.f64 a)) (fabs.f64 a))
(*.f64 (*.f64 (*.f64 b a) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (*.f64 b a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 a) (fabs.f64 b)) (*.f64 (neg.f64 a) (fabs.f64 b)))
(*.f64 (*.f64 (neg.f64 a) (neg.f64 b)) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) (neg.f64 b)) (*.f64 (fabs.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) b) (*.f64 (fabs.f64 a) b))
(*.f64 (*.f64 a (fabs.f64 b)) (*.f64 a (fabs.f64 b)))
(*.f64 (*.f64 (fabs.f64 b) (neg.f64 a)) (*.f64 (fabs.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (neg.f64 b) (fabs.f64 a)) (*.f64 (neg.f64 b) (fabs.f64 a)))
(*.f64 (*.f64 b (fabs.f64 a)) (*.f64 b (fabs.f64 a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 b b)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 b a)))
(*.f64 (fabs.f64 a) (*.f64 (fabs.f64 a) (*.f64 b b)))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 b a)))
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 b (*.f64 (*.f64 a a) b))
(*.f64 a (*.f64 (*.f64 b b) a))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 4 binary64))
(pow.f64 (*.f64 b a) #s(literal 2 binary64))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) (pow.f64 (*.f64 b a) #s(literal 2 binary64))))
(*.f64 (pow.f64 b #s(literal 1 binary64)) (pow.f64 b #s(literal 1 binary64)))
(*.f64 (neg.f64 (fabs.f64 b)) (neg.f64 (fabs.f64 b)))
(*.f64 (neg.f64 (neg.f64 b)) (neg.f64 (neg.f64 b)))
(*.f64 (fabs.f64 (fabs.f64 b)) (fabs.f64 (fabs.f64 b)))
(*.f64 (fabs.f64 b) (fabs.f64 b))
(*.f64 (neg.f64 b) (neg.f64 b))
(*.f64 b b)
(pow.f64 (fabs.f64 b) #s(literal 2 binary64))
(pow.f64 (neg.f64 b) #s(literal 2 binary64))
(pow.f64 b #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 b) b))
(fabs.f64 (*.f64 b b))
(exp.f64 (*.f64 (log.f64 b) #s(literal 2 binary64)))
(*.f64 (pow.f64 a #s(literal 1 binary64)) (pow.f64 a #s(literal 1 binary64)))
(*.f64 (neg.f64 (neg.f64 a)) (neg.f64 (neg.f64 a)))
(*.f64 (neg.f64 (fabs.f64 a)) (neg.f64 (fabs.f64 a)))
(*.f64 (fabs.f64 (fabs.f64 a)) (fabs.f64 (fabs.f64 a)))
(*.f64 (neg.f64 a) (neg.f64 a))
(*.f64 (fabs.f64 a) (fabs.f64 a))
(*.f64 a a)
(pow.f64 (neg.f64 a) #s(literal 2 binary64))
(pow.f64 (fabs.f64 a) #s(literal 2 binary64))
(pow.f64 a #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 a) a))
(neg.f64 (*.f64 a (neg.f64 a)))
(fabs.f64 (*.f64 a a))
(exp.f64 (*.f64 (log.f64 a) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) (neg.f64 b)) (neg.f64 b))
(*.f64 (*.f64 (*.f64 b b) (neg.f64 a)) (neg.f64 a))
(*.f64 (*.f64 (*.f64 b b) (fabs.f64 a)) (fabs.f64 a))
(*.f64 (*.f64 (*.f64 b a) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (*.f64 b a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 a) (fabs.f64 b)) (*.f64 (neg.f64 a) (fabs.f64 b)))
(*.f64 (*.f64 (neg.f64 a) (neg.f64 b)) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) (neg.f64 b)) (*.f64 (fabs.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) b) (*.f64 (fabs.f64 a) b))
(*.f64 (*.f64 a (fabs.f64 b)) (*.f64 a (fabs.f64 b)))
(*.f64 (*.f64 (fabs.f64 b) (neg.f64 a)) (*.f64 (fabs.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (neg.f64 b) (fabs.f64 a)) (*.f64 (neg.f64 b) (fabs.f64 a)))
(*.f64 (*.f64 b (fabs.f64 a)) (*.f64 b (fabs.f64 a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 b b)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 b a)))
(*.f64 (fabs.f64 a) (*.f64 (fabs.f64 a) (*.f64 b b)))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 b a)))
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 b (*.f64 (*.f64 a a) b))
(*.f64 a (*.f64 (*.f64 b b) a))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 4 binary64))
(pow.f64 (*.f64 b a) #s(literal 2 binary64))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) (pow.f64 (*.f64 b a) #s(literal 2 binary64))))
(*.f64 (*.f64 a (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 a (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 b (fabs.f64 a)) (fabs.f64 a))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) a))
(*.f64 (*.f64 a a) b)
(*.f64 (*.f64 (neg.f64 b) a) (neg.f64 a))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (sqrt.f64 (*.f64 b a)) a))
(*.f64 (*.f64 b a) a)
(*.f64 b (*.f64 a a))
(*.f64 a (*.f64 b a))
(*.f64 (*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (sqrt.f64 a) (sqrt.f64 a)) (*.f64 (sqrt.f64 b) (sqrt.f64 b)))
(*.f64 (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a a) b)) (sqrt.f64 b))
(*.f64 (sqrt.f64 (*.f64 (*.f64 b b) a)) (sqrt.f64 a))
(*.f64 (pow.f64 (sqrt.f64 a) #s(literal 2 binary64)) (pow.f64 (sqrt.f64 b) #s(literal 2 binary64)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (fabs.f64 a) (fabs.f64 b))
(*.f64 (fabs.f64 b) (fabs.f64 a))
(*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 b a))))
(*.f64 (sqrt.f64 a) (sqrt.f64 (*.f64 (*.f64 b b) a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 (*.f64 b a)))
(*.f64 b a)
(*.f64 a b)
(pow.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 2 binary64))
(pow.f64 (*.f64 b a) #s(literal 1 binary64))
(neg.f64 (*.f64 (neg.f64 b) a))
(sqrt.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(fabs.f64 (*.f64 b a))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 a a) (fabs.f64 b)) (fabs.f64 b))
(*.f64 (*.f64 (*.f64 a a) (neg.f64 b)) (neg.f64 b))
(*.f64 (*.f64 (*.f64 b b) (neg.f64 a)) (neg.f64 a))
(*.f64 (*.f64 (*.f64 b b) (fabs.f64 a)) (fabs.f64 a))
(*.f64 (*.f64 (*.f64 b a) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (*.f64 b a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 a) (fabs.f64 b)) (*.f64 (neg.f64 a) (fabs.f64 b)))
(*.f64 (*.f64 (neg.f64 a) (neg.f64 b)) (*.f64 (neg.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) (neg.f64 b)) (*.f64 (fabs.f64 a) (neg.f64 b)))
(*.f64 (*.f64 (fabs.f64 a) b) (*.f64 (fabs.f64 a) b))
(*.f64 (*.f64 a (fabs.f64 b)) (*.f64 a (fabs.f64 b)))
(*.f64 (*.f64 (fabs.f64 b) (neg.f64 a)) (*.f64 (fabs.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 a)) (*.f64 (neg.f64 b) (neg.f64 a)))
(*.f64 (*.f64 (neg.f64 b) (fabs.f64 a)) (*.f64 (neg.f64 b) (fabs.f64 a)))
(*.f64 (*.f64 b (fabs.f64 a)) (*.f64 b (fabs.f64 a)))
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 b b)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 b a)))
(*.f64 (fabs.f64 a) (*.f64 (fabs.f64 a) (*.f64 b b)))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 (*.f64 a a) b) b)
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 b a)))
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 b (*.f64 (*.f64 a a) b))
(*.f64 a (*.f64 (*.f64 b b) a))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 4 binary64))
(pow.f64 (*.f64 b a) #s(literal 2 binary64))
(sqrt.f64 (*.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) (pow.f64 (*.f64 b a) #s(literal 2 binary64))))
(*.f64 (*.f64 b (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 b (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) b))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 b b) a)
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) a))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (sqrt.f64 (*.f64 b a)) b))
(*.f64 (*.f64 b a) b)
(*.f64 b (*.f64 b a))
(*.f64 a (*.f64 b b))
(*.f64 (*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (sqrt.f64 a) (sqrt.f64 a)) (*.f64 (sqrt.f64 b) (sqrt.f64 b)))
(*.f64 (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a a) b)) (sqrt.f64 b))
(*.f64 (sqrt.f64 (*.f64 (*.f64 b b) a)) (sqrt.f64 a))
(*.f64 (pow.f64 (sqrt.f64 a) #s(literal 2 binary64)) (pow.f64 (sqrt.f64 b) #s(literal 2 binary64)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (fabs.f64 a) (fabs.f64 b))
(*.f64 (fabs.f64 b) (fabs.f64 a))
(*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 (*.f64 a a) b)))
(*.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 b) (sqrt.f64 (*.f64 b a))))
(*.f64 (sqrt.f64 a) (sqrt.f64 (*.f64 (*.f64 b b) a)))
(*.f64 (sqrt.f64 (*.f64 b a)) (sqrt.f64 (*.f64 b a)))
(*.f64 b a)
(*.f64 a b)
(pow.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 2 binary64))
(pow.f64 (*.f64 b a) #s(literal 1 binary64))
(neg.f64 (*.f64 (neg.f64 b) a))
(sqrt.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(fabs.f64 (*.f64 b a))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 b a))) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) (neg.f64 a)) (neg.f64 a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) (fabs.f64 a)) (fabs.f64 a))
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) a) b)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 a a) (*.f64 (neg.f64 b) b))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (neg.f64 b) (*.f64 (*.f64 a a) b))
(*.f64 (sqrt.f64 (*.f64 b a)) (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(*.f64 b (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 b (*.f64 a (*.f64 (neg.f64 b) a)))
(*.f64 a (*.f64 (*.f64 (neg.f64 b) b) a))
(neg.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)))
(*.f64 (*.f64 (neg.f64 b) (neg.f64 (sqrt.f64 (*.f64 b a)))) (neg.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (*.f64 (neg.f64 b) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 b) b) a)
(*.f64 (*.f64 (neg.f64 b) a) b)
(*.f64 (neg.f64 b) (*.f64 b a))
(*.f64 (*.f64 b a) (neg.f64 b))
(*.f64 b (*.f64 (neg.f64 b) a))
(*.f64 a (*.f64 (neg.f64 b) b))
(neg.f64 (*.f64 (*.f64 b b) a))
(*.f64 (neg.f64 (fabs.f64 b)) (fabs.f64 b))
(*.f64 (neg.f64 (neg.f64 b)) (neg.f64 b))
(*.f64 (fabs.f64 b) (neg.f64 (fabs.f64 b)))
(*.f64 (neg.f64 b) (neg.f64 (neg.f64 b)))
(*.f64 (neg.f64 b) b)
(*.f64 b (neg.f64 b))
(neg.f64 (*.f64 b b))
(*.f64 (pow.f64 (*.f64 b a) #s(literal 1/4 binary64)) (pow.f64 (*.f64 b a) #s(literal 1/4 binary64)))
(*.f64 (fabs.f64 (sqrt.f64 a)) (fabs.f64 (sqrt.f64 b)))
(*.f64 (sqrt.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))) (sqrt.f64 (neg.f64 (sqrt.f64 (*.f64 b a)))))
(*.f64 (sqrt.f64 (sqrt.f64 (*.f64 b a))) (sqrt.f64 (sqrt.f64 (*.f64 b a))))
(*.f64 (pow.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) #s(literal 1/2 binary64)) (pow.f64 (neg.f64 (sqrt.f64 (*.f64 b a))) #s(literal 1/2 binary64)))
(*.f64 (pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 1/2 binary64)) (pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 1/2 binary64)))
(*.f64 (sqrt.f64 b) (sqrt.f64 a))
(*.f64 (sqrt.f64 a) (sqrt.f64 b))
(pow.f64 (pow.f64 (*.f64 b a) #s(literal 2 binary64)) #s(literal 1/4 binary64))
(pow.f64 (sqrt.f64 (*.f64 b a)) #s(literal 1 binary64))
(pow.f64 (*.f64 b a) #s(literal 1/2 binary64))
(sqrt.f64 (*.f64 b a))
(fabs.f64 (neg.f64 (sqrt.f64 (*.f64 b a))))
(fabs.f64 (sqrt.f64 (*.f64 b a)))
(exp.f64 (*.f64 (log.f64 (*.f64 b a)) #s(literal 1/2 binary64)))

eval17.0ms (0.7%)

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

Compiled 2 320 to 453 computations (80.5% saved)

prune19.0ms (0.8%)

Memory
-17.5MiB live, 25.9MiB allocated; 7ms collecting garbage
Pruning

13 alts after pruning (3 fresh and 10 done)

PrunedKeptTotal
New1903193
Fresh000
Picked145
Done066
Total19113204
Accuracy
100.0%
Counts
204 → 13
Alt Table
Click to see full alt table
StatusAccuracyProgram
98.0%
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
83.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
99.6%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
95.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
34.4%
(*.f64 (*.f64 (*.f64 b b) a) a)
34.7%
(*.f64 (*.f64 (*.f64 a b) a) b)
99.6%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
99.7%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
34.8%
(*.f64 (*.f64 b (*.f64 a a)) b)
34.4%
(*.f64 (*.f64 b b) (*.f64 a a))
34.6%
(*.f64 (*.f64 b a) (*.f64 b a))
93.4%
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
84.6%
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 118 to 81 computations (31.4% saved)

simplify178.0ms (7.2%)

Memory
-22.8MiB live, 78.3MiB allocated; 16ms collecting garbage
Localize:

Found 11 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 (neg.f64 b) a)
cost-diff0
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
cost-diff0
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
cost-diff2
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
cost-diff0
(neg.f64 b)
cost-diff0
(*.f64 (neg.f64 b) a)
cost-diff2
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
cost-diff5
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
cost-diff0
(*.f64 b b)
cost-diff0
(*.f64 (*.f64 b b) a)
cost-diff1
(*.f64 (*.f64 (*.f64 b b) a) a)
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
015110
028110
151104
215096
364894
4173494
5229194
6246694
7247694
8250894
9269194
10428794
11698294
0839194
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 b b) a)
(*.f64 b b)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(sqrt.f64 (*.f64 b a))
(*.f64 b a)
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(sqrt.f64 (*.f64 b a))
(*.f64 b a)
(sqrt.f64 a)
(sqrt.f64 b)
Outputs
(*.f64 (*.f64 (*.f64 b b) a) a)
(pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64))
(*.f64 (*.f64 b b) a)
(*.f64 a (*.f64 b b))
(*.f64 b b)
b
a
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(neg.f64 (pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 4 binary64)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(pow.f64 (neg.f64 (sqrt.f64 (*.f64 a b))) #s(literal 3 binary64))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(sqrt.f64 (*.f64 b a))
(sqrt.f64 (*.f64 a b))
(*.f64 b a)
(*.f64 a b)
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (neg.f64 (sqrt.f64 a)) (sqrt.f64 b)) (pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 3 binary64)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
(*.f64 (neg.f64 (sqrt.f64 a)) (pow.f64 (sqrt.f64 (*.f64 a b)) #s(literal 3 binary64)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(pow.f64 (neg.f64 (sqrt.f64 (*.f64 a b))) #s(literal 3 binary64))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
b
a
(sqrt.f64 (*.f64 b a))
(sqrt.f64 (*.f64 a b))
(*.f64 b a)
(*.f64 a b)
(sqrt.f64 a)
(sqrt.f64 b)

localize47.0ms (1.9%)

Memory
21.1MiB live, 64.6MiB allocated; 6ms collecting garbage
Localize:

Found 11 expressions of interest:

NewMetricScoreProgram
accuracy0.1875
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
accuracy1.079075435546331
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
accuracy1.1706614258788473
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
accuracy15.92737144474589
(sqrt.f64 (*.f64 b a))
accuracy0.0
(neg.f64 b)
accuracy0.11328125
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
accuracy0.1875
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
accuracy15.92737144474589
(sqrt.f64 (*.f64 b a))
accuracy0.0
(*.f64 b b)
accuracy2.620707637787172
(*.f64 (*.f64 (*.f64 b b) a) a)
accuracy7.629113824420289
(*.f64 (*.f64 b b) a)
Samples
36.0ms256×0valid
Compiler

Compiled 112 to 17 computations (84.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 25.0ms
ival-mult: 18.0ms (73.4% of total)
ival-sqrt: 5.0ms (20.4% of total)
ival-neg: 1.0ms (4.1% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series22.0ms (0.9%)

Memory
-11.8MiB live, 34.2MiB allocated; 3ms collecting garbage
Counts
10 → 13
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 b b) a)
(*.f64 b b)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
(sqrt.f64 (*.f64 b a))
Outputs
(* (pow a 2) (pow b 2))
(* a (pow b 2))
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (sqrt (* (pow a 3) (pow b 3))))
(* -1 (* a b))
(* -1 (* (pow a 2) (sqrt (pow b 3))))
(sqrt (* a b))
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(* (sqrt (* (pow a 3) (pow b 3))) (pow (sqrt -1) 2))
(* (* (pow a 2) (pow (sqrt -1) 2)) (sqrt (pow b 3)))
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(pow b 2)
(* -1 b)
Calls

6 calls:

TimeVariablePointExpression
6.0ms
b
@-inf
((* (* (* b b) a) a) (* (* b b) a) (* b b) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt (* b a))) (* (* (neg b) a) (sqrt (* b a))) (* (neg b) a) (neg b) (* (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt b)) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt (* b a)))
5.0ms
b
@inf
((* (* (* b b) a) a) (* (* b b) a) (* b b) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt (* b a))) (* (* (neg b) a) (sqrt (* b a))) (* (neg b) a) (neg b) (* (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt b)) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt (* b a)))
3.0ms
a
@-inf
((* (* (* b b) a) a) (* (* b b) a) (* b b) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt (* b a))) (* (* (neg b) a) (sqrt (* b a))) (* (neg b) a) (neg b) (* (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt b)) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt (* b a)))
3.0ms
a
@0
((* (* (* b b) a) a) (* (* b b) a) (* b b) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt (* b a))) (* (* (neg b) a) (sqrt (* b a))) (* (neg b) a) (neg b) (* (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt b)) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt (* b a)))
3.0ms
b
@0
((* (* (* b b) a) a) (* (* b b) a) (* b b) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt (* b a))) (* (* (neg b) a) (sqrt (* b a))) (* (neg b) a) (neg b) (* (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt b)) (* (* (* (neg b) a) (sqrt (* b a))) (sqrt a)) (sqrt (* b a)))

simplify26.0ms (1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
03177
17477
222377
087877
Stop Event
iter limit
iter limit
iter limit
unsound
Counts
13 → 13
Calls
Call 1
Inputs
(* (pow a 2) (pow b 2))
(* a (pow b 2))
(* -1 (* (pow a 2) (pow b 2)))
(* -1 (sqrt (* (pow a 3) (pow b 3))))
(* -1 (* a b))
(* -1 (* (pow a 2) (sqrt (pow b 3))))
(sqrt (* a b))
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(* (sqrt (* (pow a 3) (pow b 3))) (pow (sqrt -1) 2))
(* (* (pow a 2) (pow (sqrt -1) 2)) (sqrt (pow b 3)))
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(pow b 2)
(* -1 b)
Outputs
(* (pow a 2) (pow b 2))
(*.f64 (*.f64 (*.f64 a b) a) b)
(* a (pow b 2))
(*.f64 (*.f64 b b) a)
(* -1 (* (pow a 2) (pow b 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(* -1 (sqrt (* (pow a 3) (pow b 3))))
(neg.f64 (sqrt.f64 (pow.f64 (*.f64 a b) #s(literal 3 binary64))))
(* -1 (* a b))
(*.f64 (neg.f64 a) b)
(* -1 (* (pow a 2) (sqrt (pow b 3))))
(*.f64 (*.f64 (neg.f64 a) a) (sqrt.f64 (pow.f64 b #s(literal 3 binary64))))
(sqrt (* a b))
(sqrt.f64 (*.f64 a b))
(* (pow a 2) (* (pow b 2) (pow (sqrt -1) 2)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(* (sqrt (* (pow a 3) (pow b 3))) (pow (sqrt -1) 2))
(neg.f64 (sqrt.f64 (pow.f64 (*.f64 a b) #s(literal 3 binary64))))
(* (* (pow a 2) (pow (sqrt -1) 2)) (sqrt (pow b 3)))
(*.f64 (*.f64 (neg.f64 a) a) (sqrt.f64 (pow.f64 b #s(literal 3 binary64))))
(* -1 (* (sqrt (* a b)) (pow (sqrt -1) 2)))
(sqrt.f64 (*.f64 a b))
(pow b 2)
(*.f64 b b)
(* -1 b)
(neg.f64 b)

rewrite28.0ms (1.1%)

Memory
-31.9MiB live, 20.6MiB allocated; 6ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01575
02874
15861
019761
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
10 → 99
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 b b) a) a)
(*.f64 (*.f64 b b) a)
(*.f64 b b)
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a)))
(*.f64 (neg.f64 b) a)
(neg.f64 b)
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a))
(sqrt.f64 (*.f64 b a))
Outputs
(*.f64 (*.f64 (fabs.f64 b) a) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 a a) (*.f64 b b))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) (*.f64 a a)))
(*.f64 (*.f64 a b) (*.f64 a b))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (neg.f64 b) a))
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) (*.f64 a a)))
(*.f64 (*.f64 a (*.f64 b b)) a)
(*.f64 a (*.f64 a (*.f64 b b)))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 b (*.f64 b (*.f64 a a)))
(*.f64 b (*.f64 (*.f64 a b) a))
(*.f64 (*.f64 a (fabs.f64 b)) (fabs.f64 b))
(*.f64 (fabs.f64 b) (*.f64 (fabs.f64 b) a))
(*.f64 (*.f64 a b) b)
(*.f64 (*.f64 (neg.f64 b) a) (neg.f64 b))
(*.f64 (neg.f64 b) (*.f64 (neg.f64 b) a))
(*.f64 a (*.f64 b b))
(*.f64 (*.f64 b b) a)
(*.f64 b (*.f64 a b))
(*.f64 (pow.f64 b #s(literal 1 binary64)) (pow.f64 b #s(literal 1 binary64)))
(*.f64 (neg.f64 (fabs.f64 b)) (neg.f64 (fabs.f64 b)))
(*.f64 (neg.f64 (neg.f64 b)) (neg.f64 (neg.f64 b)))
(*.f64 (fabs.f64 (fabs.f64 b)) (fabs.f64 (fabs.f64 b)))
(*.f64 (fabs.f64 b) (fabs.f64 b))
(*.f64 (neg.f64 b) (neg.f64 b))
(*.f64 b b)
(pow.f64 (fabs.f64 b) #s(literal 2 binary64))
(pow.f64 (neg.f64 b) #s(literal 2 binary64))
(pow.f64 b #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 b) b))
(neg.f64 (*.f64 b (neg.f64 b)))
(fabs.f64 (*.f64 b b))
(exp.f64 (*.f64 (log.f64 b) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b)) (sqrt.f64 a))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (neg.f64 b)) (*.f64 (sqrt.f64 (*.f64 a b)) a))
(*.f64 (*.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a))) (sqrt.f64 a))
(*.f64 (*.f64 (sqrt.f64 b) (*.f64 (neg.f64 b) a)) (sqrt.f64 (*.f64 (*.f64 a b) a)))
(*.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b))
(*.f64 (sqrt.f64 a) (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b)))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 (*.f64 a b)))
(*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 a b) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (sqrt.f64 b)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 a b))
(*.f64 (neg.f64 b) (*.f64 a (*.f64 a b)))
(*.f64 (neg.f64 b) (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (sqrt.f64 (*.f64 a b))))
(*.f64 a (*.f64 (neg.f64 b) (*.f64 a b)))
(neg.f64 (*.f64 (*.f64 a (*.f64 b b)) a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 b)) (sqrt.f64 a))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (neg.f64 b)) a)
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (neg.f64 b))
(*.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 a) (*.f64 (neg.f64 b) a)))
(*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 a b)))
(*.f64 (neg.f64 b) (*.f64 (sqrt.f64 (*.f64 a b)) a))
(*.f64 a (*.f64 (neg.f64 b) (sqrt.f64 (*.f64 a b))))
(neg.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 a b)))
(neg.f64 (*.f64 (*.f64 a b) (sqrt.f64 (*.f64 a b))))
(neg.f64 (*.f64 b (*.f64 (sqrt.f64 (*.f64 a b)) a)))
(*.f64 (neg.f64 a) b)
(*.f64 (neg.f64 b) a)
(*.f64 a (neg.f64 b))
(*.f64 b (neg.f64 a))
(neg.f64 (*.f64 a b))
(neg.f64 b)
(*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b)) (sqrt.f64 a))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (neg.f64 b)) (*.f64 (sqrt.f64 (*.f64 a b)) a))
(*.f64 (*.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a))) (sqrt.f64 a))
(*.f64 (*.f64 (sqrt.f64 b) (*.f64 (neg.f64 b) a)) (sqrt.f64 (*.f64 (*.f64 a b) a)))
(*.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b))
(*.f64 (sqrt.f64 a) (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 b)))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 (*.f64 a b)))
(*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 a b) (*.f64 (neg.f64 b) a))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (sqrt.f64 b)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 a b))
(*.f64 (neg.f64 b) (*.f64 a (*.f64 a b)))
(*.f64 (neg.f64 b) (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (sqrt.f64 (*.f64 a b))))
(*.f64 a (*.f64 (neg.f64 b) (*.f64 a b)))
(neg.f64 (*.f64 (*.f64 a (*.f64 b b)) a))
(*.f64 (*.f64 (sqrt.f64 a) (*.f64 (neg.f64 b) a)) (sqrt.f64 (*.f64 a b)))
(*.f64 (*.f64 (sqrt.f64 a) (neg.f64 b)) (*.f64 (sqrt.f64 (*.f64 a b)) a))
(*.f64 (sqrt.f64 (*.f64 (*.f64 a b) a)) (*.f64 (neg.f64 b) a))
(*.f64 (sqrt.f64 a) (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (neg.f64 b) a)) (sqrt.f64 a))
(*.f64 (sqrt.f64 (*.f64 a b)) (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 a)))
(*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 (*.f64 a b) a)))
(*.f64 (neg.f64 b) (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (sqrt.f64 a)))
(*.f64 (neg.f64 b) (*.f64 a (sqrt.f64 (*.f64 (*.f64 a b) a))))
(*.f64 a (*.f64 (neg.f64 b) (sqrt.f64 (*.f64 (*.f64 a b) a))))
(neg.f64 (*.f64 (*.f64 a b) (sqrt.f64 (*.f64 (*.f64 a b) a))))
(*.f64 (pow.f64 (*.f64 a b) #s(literal 1/4 binary64)) (pow.f64 (*.f64 a b) #s(literal 1/4 binary64)))
(*.f64 (sqrt.f64 b) (sqrt.f64 a))
(*.f64 (sqrt.f64 a) (sqrt.f64 b))
(pow.f64 (*.f64 a b) #s(literal 1/2 binary64))
(sqrt.f64 (*.f64 a b))
(exp.f64 (*.f64 (log.f64 (*.f64 a b)) #s(literal 1/2 binary64)))

eval26.0ms (1.1%)

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

Compiled 1 691 to 308 computations (81.8% saved)

prune14.0ms (0.6%)

Memory
-24.0MiB live, 21.6MiB allocated; 3ms collecting garbage
Pruning

13 alts after pruning (3 fresh and 10 done)

PrunedKeptTotal
New1233126
Fresh000
Picked213
Done1910
Total12613139
Accuracy
100.0%
Counts
139 → 13
Alt Table
Click to see full alt table
StatusAccuracyProgram
97.2%
(*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (neg.f64 b)) (sqrt.f64 (*.f64 b a)))
83.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
99.6%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (*.f64 (sqrt.f64 b) (sqrt.f64 a)))
95.8%
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
34.4%
(*.f64 (*.f64 (*.f64 b b) a) a)
34.7%
(*.f64 (*.f64 (*.f64 a b) a) b)
95.4%
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (neg.f64 b)) (*.f64 (sqrt.f64 (*.f64 a b)) a))
99.7%
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
34.8%
(*.f64 (*.f64 b (*.f64 a a)) b)
34.4%
(*.f64 (*.f64 b b) (*.f64 a a))
34.6%
(*.f64 (*.f64 b a) (*.f64 b a))
93.4%
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
84.6%
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 304 to 134 computations (55.9% saved)

regimes23.0ms (1%)

Memory
31.2MiB live, 31.2MiB allocated; 0ms collecting garbage
Counts
19 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (*.f64 b b) a) a)
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (*.f64 (neg.f64 b) b) (*.f64 a a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) b) a)
(*.f64 (*.f64 (*.f64 (neg.f64 b) b) a) a)
(*.f64 (neg.f64 a) (*.f64 (neg.f64 a) (*.f64 (neg.f64 b) b)))
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 (sqrt.f64 (*.f64 a b)) (sqrt.f64 (*.f64 a b))))
(*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) (neg.f64 b)) (*.f64 (sqrt.f64 (*.f64 a b)) a))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (*.f64 (sqrt.f64 (*.f64 a b)) a) (neg.f64 b)) (sqrt.f64 (*.f64 b a)))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (*.f64 (sqrt.f64 b) (sqrt.f64 a)))
(*.f64 (*.f64 (*.f64 (*.f64 (neg.f64 b) a) (sqrt.f64 (*.f64 b a))) (sqrt.f64 a)) (sqrt.f64 b))
Outputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
Calls

5 calls:

5.0ms
b
5.0ms
a
4.0ms
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
4.0ms
(*.f64 a a)
4.0ms
(*.f64 (*.f64 (*.f64 a a) b) b)
Results
AccuracySegmentsBranch
99.7%1(*.f64 a a)
99.7%1(*.f64 (*.f64 (*.f64 a a) b) b)
99.7%1(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
99.7%1a
99.7%1b
Compiler

Compiled 20 to 18 computations (10% saved)

regimes16.0ms (0.6%)

Memory
-25.0MiB live, 20.0MiB allocated; 4ms collecting garbage
Counts
8 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (*.f64 b b) a) a)
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
Outputs
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
Calls

5 calls:

6.0ms
(*.f64 a a)
3.0ms
a
3.0ms
b
2.0ms
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
2.0ms
(*.f64 (*.f64 (*.f64 a a) b) b)
Results
AccuracySegmentsBranch
93.4%1(*.f64 a a)
93.4%1(*.f64 (*.f64 (*.f64 a a) b) b)
93.4%1(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
93.4%1a
93.4%1b
Compiler

Compiled 20 to 18 computations (10% saved)

regimes11.0ms (0.5%)

Memory
18.4MiB live, 18.4MiB allocated; 0ms collecting garbage
Counts
7 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (*.f64 b b) a) a)
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Outputs
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Calls

5 calls:

2.0ms
a
2.0ms
b
2.0ms
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
2.0ms
(*.f64 a a)
2.0ms
(*.f64 (*.f64 (*.f64 a a) b) b)
Results
AccuracySegmentsBranch
84.6%1(*.f64 a a)
84.6%1(*.f64 (*.f64 (*.f64 a a) b) b)
84.6%1(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
84.6%1a
84.6%1b
Compiler

Compiled 20 to 18 computations (10% saved)

regimes10.0ms (0.4%)

Memory
15.5MiB live, 15.5MiB allocated; 0ms collecting garbage
Counts
6 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 (*.f64 a b) a) b)
(*.f64 (*.f64 (*.f64 b a) b) a)
(*.f64 (*.f64 (*.f64 b b) a) a)
Outputs
(*.f64 (*.f64 b (*.f64 a a)) b)
Calls

5 calls:

2.0ms
a
2.0ms
b
2.0ms
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
2.0ms
(*.f64 a a)
2.0ms
(*.f64 (*.f64 (*.f64 a a) b) b)
Results
AccuracySegmentsBranch
34.8%1b
34.8%1a
34.8%1(*.f64 a a)
34.8%1(*.f64 (*.f64 (*.f64 a a) b) b)
34.8%1(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 20 to 18 computations (10% saved)

regimes6.0ms (0.2%)

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

Total -0.2b remaining (-0.4%)

Threshold costs -0.2b (-0.4%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 b a) (*.f64 b a))
(*.f64 (*.f64 b b) (*.f64 a a))
Outputs
(*.f64 (*.f64 b a) (*.f64 b a))
Calls

5 calls:

1.0ms
b
1.0ms
a
1.0ms
(*.f64 a a)
1.0ms
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
1.0ms
(*.f64 (*.f64 (*.f64 a a) b) b)
Results
AccuracySegmentsBranch
34.6%1(*.f64 (*.f64 (*.f64 a a) b) b)
34.6%1a
34.6%1(*.f64 a a)
34.6%1b
34.6%1(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
Compiler

Compiled 20 to 18 computations (10% saved)

simplify29.0ms (1.2%)

Memory
-35.7MiB live, 10.2MiB allocated; 3ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01638
13438
25438
36938
47238
Stop Event
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 b a) (*.f64 b a))
Outputs
(*.f64 (*.f64 (neg.f64 b) a) (*.f64 b a))
(*.f64 (*.f64 b a) (*.f64 (neg.f64 b) a))
(neg.f64 (*.f64 (*.f64 (*.f64 b a) a) b))
(*.f64 (*.f64 (*.f64 (neg.f64 b) a) a) b)
(neg.f64 (*.f64 (*.f64 (*.f64 a a) b) b))
(*.f64 (*.f64 (*.f64 a a) b) (neg.f64 b))
(*.f64 (*.f64 b (*.f64 a a)) b)
(*.f64 (*.f64 b a) (*.f64 b a))

derivations13.0ms (0.5%)

Memory
8.0MiB live, 8.0MiB allocated; 0ms collecting garbage
Stop Event
fuel
Compiler

Compiled 38 to 14 computations (63.2% saved)

preprocess48.0ms (1.9%)

Memory
-2.3MiB live, 44.8MiB allocated; 11ms collecting garbage
Remove

(sort a b)

(abs a)

(abs b)

Compiler

Compiled 284 to 184 computations (35.2% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...