YES
Confluence Proof
Confluence Proof
by csi
Input
The rewrite relation of the following TRS is considered.
b(a(b(x))) |
→ |
b(a(a(a(b(x))))) |
b(a(a(a(b(a(a(b(x)))))))) |
→ |
b(a(a(b(a(a(b(a(a(a(b(b(x)))))))))))) |
b(a(a(a(b(a(a(a(b(x))))))))) |
→ |
b(x) |
b(a(a(a(b(b(b(x))))))) |
→ |
b(b(b(a(a(a(b(x))))))) |
b(a(a(b(b(x))))) |
→ |
b(x) |
b(b(a(a(b(x))))) |
→ |
b(x) |
b(a(a(a(b(a(b(x))))))) |
→ |
b(x) |
b(a(b(a(a(a(b(x))))))) |
→ |
b(x) |
Proof
1 Locally confluent and terminating
Confluence is proven by showing local confluence and termination.
1.1 Rule Removal
Using the
linear polynomial interpretation over (3 x 3)-matrices with strict dimension 1
over the naturals
[a(x1)] |
= |
· x1 +
|
[b(x1)] |
= |
· x1 +
|
the
rules
b(a(a(a(b(a(a(b(x)))))))) |
→ |
b(a(a(b(a(a(b(a(a(a(b(b(x)))))))))))) |
b(a(a(a(b(a(a(a(b(x))))))))) |
→ |
b(x) |
b(a(a(a(b(b(b(x))))))) |
→ |
b(b(b(a(a(a(b(x))))))) |
b(a(a(b(b(x))))) |
→ |
b(x) |
b(b(a(a(b(x))))) |
→ |
b(x) |
remain.
1.1.1 String Reversal
Since only unary symbols occur, one can reverse all terms and obtains the TRS
b(a(a(b(a(a(a(b(x)))))))) |
→ |
b(b(a(a(a(b(a(a(b(a(a(b(x)))))))))))) |
b(a(a(a(b(a(a(a(b(x))))))))) |
→ |
b(x) |
b(b(b(a(a(a(b(x))))))) |
→ |
b(a(a(a(b(b(b(x))))))) |
b(b(a(a(b(x))))) |
→ |
b(x) |
b(a(a(b(b(x))))) |
→ |
b(x) |
1.1.1.1 Dependency Pair Transformation
The following set of initial dependency pairs has been identified.
b#(a(a(b(a(a(a(b(x)))))))) |
→ |
b#(a(a(b(x)))) |
b#(a(a(b(a(a(a(b(x)))))))) |
→ |
b#(a(a(b(a(a(b(x))))))) |
b#(a(a(b(a(a(a(b(x)))))))) |
→ |
b#(a(a(a(b(a(a(b(a(a(b(x))))))))))) |
b#(a(a(b(a(a(a(b(x)))))))) |
→ |
b#(b(a(a(a(b(a(a(b(a(a(b(x)))))))))))) |
b#(b(b(a(a(a(b(x))))))) |
→ |
b#(b(x)) |
b#(b(b(a(a(a(b(x))))))) |
→ |
b#(b(b(x))) |
b#(b(b(a(a(a(b(x))))))) |
→ |
b#(a(a(a(b(b(b(x))))))) |
1.1.1.1.1 Dependency Graph Processor
The dependency pairs are split into 2
components.
1.2 Local Confluence Proof
All critical pairs are joinable which can be seen by computing normal forms of all critical pairs.
Tool configuration
csi
- version: csi 1.2.5 [hg: unknown]
- strategy:
(cr -kb;((( matrix -dim 1 -ib 3 -ob 5 | matrix -dim 2 -ib 2 -ob 3 | matrix -dim 3 -ib 1 -ob 1 | matrix -dim 3 -ib 1 -ob 3 | fail)[2]*);((dp;edg[0.5]?;(sccs | (sc || sct || {ur?;( (matrix -dp -ur -dim 1 -ib 3 -ob 5 | matrix -dp -ur -dim 2 -ib 2 -ob 3 | matrix -dp -ur -dim 3 -ib 1 -ob 1 | matrix -dp -ur -dim 3 -ib 1 -ob 3) || (kbo -ur -af | lpo -ur -af) || ( arctic -dp -ur -dim 2 -ib 2 -ob 2[2] | fail) || ( arctic -bz -dp -ur -dim 2 -ib 2 -ob 2[2] | fail) || fail) }restore || fail;(bounds -dp -rfc -qc || bounds -dp -all -rfc -qc || bounds -rfc -qc)[1] || fail ))*[6])! || (( kbo || (lpo | fail;(ref;lpo)) || fail;(bounds -rfc -qc) || fail)*[7])! || (rev;((dp;edg[0.5]?;(sccs | (sc || sct || {ur?;( (matrix -dp -ur -dim 1 -ib 3 -ob 5 | matrix -dp -ur -dim 2 -ib 2 -ob 3 | matrix -dp -ur -dim 3 -ib 1 -ob 1 | matrix -dp -ur -dim 3 -ib 1 -ob 3) || (kbo -ur -af | lpo -ur -af) || ( arctic -dp -ur -dim 2 -ib 2 -ob 2[2] | fail) || ( arctic -bz -dp -ur -dim 2 -ib 2 -ob 2[2] | fail) || fail) }restore || fail;(bounds -dp -rfc -qc || bounds -dp -all -rfc -qc || bounds -rfc -qc)[1] || fail ))*[6])! || (( kbo || (lpo | fail;(ref;lpo)) || fail;(bounds -rfc -qc) || fail)*[7])!)))))!