Details

Time bar (total: 9.9s)

analyze190.0ms (1.9%)

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
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
12.5%12.5%87.4%0.1%0%0%0%7
18.8%18.7%81.1%0.1%0%0%0%8
26.2%25%70.2%0.1%4.7%0%0%9
39.7%37.4%56.9%0.1%5.5%0%0%10
47.1%44.5%49.9%0.1%5.5%0%0%11
54.9%50.3%41.3%0.1%8.2%0%0%12
Compiler

Compiled 11 to 8 computations (27.3% saved)

sample1.1s (11.4%)

Results
1.1s8256×body256valid
49.0ms390×body256infinite
Bogosity

preprocess3.5s (34.8%)

Algorithm
egglog
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(-.f64 (*.f64 (*.f64 x 3) y) z)
(-.f64 (*.f64 (*.f64 y 3) x) z)
(-.f64 (*.f64 (*.f64 z 3) y) x)
(-.f64 (*.f64 (*.f64 x 3) z) y)
Outputs
(-.f64 (*.f64 (*.f64 x 3) y) z)
(-.f64 (*.f64 3 (*.f64 x y)) z)
(-.f64 (*.f64 (*.f64 y 3) x) z)
(-.f64 (*.f64 3 (*.f64 x y)) z)
(-.f64 (*.f64 (*.f64 z 3) y) x)
(-.f64 (*.f64 3 (*.f64 z y)) x)
(-.f64 (*.f64 (*.f64 x 3) z) y)
(-.f64 (*.f64 3 (*.f64 x z)) y)
Compiler

Compiled 13 to 10 computations (23.1% saved)

simplify1.6s (15.7%)

Algorithm
egglog
Counts
1 → 2
Calls
Call 1
Inputs
(-.f64 (*.f64 (*.f64 x 3) y) z)
Outputs
(-.f64 (*.f64 (*.f64 x 3) y) z)
(-.f64 (*.f64 3 (*.f64 x y)) z)

eval1.0ms (0%)

Compiler

Compiled 17 to 11 computations (35.3% saved)

prune3.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.1b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(-.f64 (*.f64 (*.f64 x 3) y) z)
0.1b
(-.f64 (*.f64 3 (*.f64 x y)) z)
Compiler

Compiled 20 to 14 computations (30% saved)

localize16.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 3 (*.f64 x y)) z)
0.3b
(*.f64 3 (*.f64 x y))
Compiler

Compiled 22 to 10 computations (54.5% saved)

series26.0ms (0.3%)

Counts
2 → 60
Calls

15 calls:

TimeVariablePointExpression
1.0ms
y
@0
(*.f64 3 (*.f64 x y))
1.0ms
x
@inf
(*.f64 3 (*.f64 x y))
1.0ms
x
@0
(*.f64 3 (*.f64 x y))
1.0ms
y
@inf
(*.f64 3 (*.f64 x y))
0.0ms
z
@0
(-.f64 (*.f64 3 (*.f64 x y)) z)
Compiler

Compiled 2020 to 1030 computations (49% saved)

rewrite1.6s (15.9%)

Algorithm
batch-egg-rewrite
Rules
73×egg-rr
52×egg-rr
Counts
2 → 125
Calls
Call 1
Inputs
(*.f64 3 (*.f64 x y))
(-.f64 (*.f64 3 (*.f64 x y)) z)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 x) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (*.f64 3 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 3) (*.f64 (cbrt.f64 9) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 3 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x y)) (*.f64 3 (cbrt.f64 (pow.f64 (*.f64 x y) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 3 x) (cbrt.f64 y)) (cbrt.f64 (pow.f64 y 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 y) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 27 (*.f64 x y))) (cbrt.f64 (pow.f64 (*.f64 x y) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 3) (*.f64 x y)) (sqrt.f64 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 x y) 2)) (cbrt.f64 (*.f64 27 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 9) (*.f64 x y)) (cbrt.f64 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (cbrt.f64 (pow.f64 (*.f64 x y) 2))) (cbrt.f64 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 y 2)) (*.f64 (*.f64 3 x) (cbrt.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 9) (*.f64 (*.f64 x y) (cbrt.f64 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x y) (cbrt.f64 3)) (cbrt.f64 9))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (+.f64 0 (*.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) 0))) (-.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) 0))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (-.f64 0 (*.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) 0))) (+.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) 0))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (*.f64 (*.f64 x -3) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (+.f64 (*.f64 x y) 0))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (-.f64 (*.f64 x y) 0))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 3 (*.f64 x y)) 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x -3) y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x y) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (cbrt.f64 (*.f64 3 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 (*.f64 x -3) y))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 3 (*.f64 x y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x -3) y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 (*.f64 x -3) y))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (/.f64 1 (/.f64 1 (*.f64 3 (*.f64 x y)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (/.f64 (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (-.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) 0) (*.f64 3 (*.f64 x y))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (*.f64 (*.f64 3 (*.f64 x y)) (+.f64 1 (/.f64 0 (*.f64 3 (*.f64 x y))))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 0 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (+.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (-.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0))) 0) (/.f64 (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (-.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (+.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0))) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (+.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 0 0) (/.f64 (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (-.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) 0) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (+.f64 0 (*.f64 (*.f64 3 (*.f64 x y)) 0)))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 1 0) (*.f64 3 (*.f64 x y)) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 2 0) (*.f64 3 (*.f64 x y)) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (*.f64 x y)) (*.f64 -1 0))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (*.f64 x y)) 0)))))
((#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z)) (cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (*.f64 (cbrt.f64 z) (+.f64 (cbrt.f64 z) (cbrt.f64 (*.f64 3 (*.f64 x y)))))) (-.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) (cbrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 z (*.f64 3 (*.f64 x y)))) (neg.f64 (cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 0 (+.f64 (cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (*.f64 0 (cbrt.f64 (-.f64 z (*.f64 3 (*.f64 x y))))))) (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 0 (-.f64 (cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (*.f64 0 (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (+.f64 0 (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (cbrt.f64 (pow.f64 z 2)) (-.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (*.f64 (neg.f64 (cbrt.f64 z)) (cbrt.f64 (*.f64 3 (*.f64 x y)))))) (+.f64 (neg.f64 (cbrt.f64 z)) (cbrt.f64 (*.f64 3 (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (-.f64 (cbrt.f64 (pow.f64 z 2)) (*.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) (neg.f64 (cbrt.f64 z))))) (-.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) (cbrt.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (-.f64 z (*.f64 3 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 z (*.f64 3 (*.f64 x y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 3 (*.f64 x y)) z)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (neg.f64 z) (*.f64 (*.f64 x -3) y))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (-.f64 z (*.f64 3 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 z (*.f64 3 (*.f64 x y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 z) (neg.f64 (cbrt.f64 (pow.f64 z 2))) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 z (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (cbrt.f64 z)) (cbrt.f64 (pow.f64 z 2)) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (neg.f64 z) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 x) y (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 3 y) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x y)) (*.f64 3 (cbrt.f64 (pow.f64 (*.f64 x y) 2))) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 y) x (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 3 x) (cbrt.f64 y)) (cbrt.f64 (pow.f64 y 2)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 3) (*.f64 (cbrt.f64 9) (*.f64 x y)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (*.f64 3 x) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 3) (*.f64 x y)) (sqrt.f64 3) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 3) (*.f64 x y)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 27 (*.f64 x y))) (cbrt.f64 (pow.f64 (*.f64 x y) 2)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 3 (*.f64 x y))) (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 x y) (cbrt.f64 3)) (cbrt.f64 9) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2)) (cbrt.f64 (*.f64 3 (*.f64 x y))) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 3 (*.f64 x y)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 3 (*.f64 x y) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 (*.f64 x y)) 1 (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x y) 3 (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 0 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 (*.f64 3 (*.f64 x y)) z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (-.f64 z (*.f64 3 (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (fma.f64 (*.f64 3 x) y z) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (pow.f64 z 2)) (fma.f64 (*.f64 3 x) y z)) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (*.f64 (*.f64 3 (*.f64 x y)) (+.f64 1 (/.f64 z (*.f64 (*.f64 x -3) y)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (-.f64 (*.f64 (*.f64 x -3) y) z) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (pow.f64 z 2)) (fma.f64 (*.f64 3 x) y z)) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (neg.f64 z) 0) (*.f64 (neg.f64 z) (/.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) (neg.f64 z))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (-.f64 z (*.f64 3 (*.f64 x y))) 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 0 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 0) (/.f64 1 (/.f64 1 (-.f64 (*.f64 3 (*.f64 x y)) z))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (neg.f64 z) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (fma.f64 9 (pow.f64 (*.f64 x y) 2) (*.f64 z (fma.f64 (*.f64 3 x) y z)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 0 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (+.f64 0 (-.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) (*.f64 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (-.f64 z (*.f64 3 (*.f64 x y))) 0) (/.f64 (neg.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (-.f64 z (*.f64 3 (*.f64 x y)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 0 0) (*.f64 0 (+.f64 1 (/.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 0))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 (*.f64 x -3) y) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (+.f64 (pow.f64 z 2) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (*.f64 (neg.f64 z) (*.f64 (*.f64 x -3) y))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (+.f64 0 (-.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) (*.f64 0 (-.f64 (*.f64 3 (*.f64 x y)) z)))) 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (+.f64 0 (-.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) (*.f64 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (+.f64 (pow.f64 z 2) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (*.f64 (neg.f64 z) (*.f64 (*.f64 x -3) y)))) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (+.f64 (pow.f64 z 2) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (*.f64 (neg.f64 z) (*.f64 (*.f64 x -3) y))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (*.f64 3 (*.f64 x y)) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (fma.f64 9 (pow.f64 (*.f64 x y) 2) (*.f64 z (fma.f64 (*.f64 3 x) y z)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (+.f64 0 (-.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) (*.f64 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (neg.f64 z) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (+.f64 (pow.f64 z 2) (+.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 2) (*.f64 (neg.f64 z) (*.f64 (*.f64 x -3) y))))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 1 0) (-.f64 (*.f64 3 (*.f64 x y)) z) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 2 0) (-.f64 (*.f64 3 (*.f64 x y)) z) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2) 0) (/.f64 (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 3) (pow.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 2)) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 (fma.f64 9 (pow.f64 (*.f64 x y) 2) (*.f64 z (fma.f64 (*.f64 3 x) y z))) 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (fma.f64 9 (pow.f64 (*.f64 x y) 2) (*.f64 z (fma.f64 (*.f64 3 x) y z)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x if (!=.f64 z 0) (/.f64 (-.f64 (pow.f64 (*.f64 3 (*.f64 x y)) 3) (pow.f64 z 3)) (fma.f64 9 (pow.f64 (*.f64 x y) 2) (*.f64 z (fma.f64 (*.f64 3 x) y z)))) (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 z) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (*.f64 x y)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (neg.f64 z) 0) (*.f64 3 (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 (*.f64 3 (*.f64 x y)) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (*.f64 3 (*.f64 x y)) z) 0)))))

simplify2.0s (19.8%)

Algorithm
egglog

end0.0ms (0%)

Profiling

Loading profile data...