Certification Problem
Input (COPS 576)
We consider the TRS containing the following rules:
s(p(x)) |
→ |
x |
(1) |
p(s(x)) |
→ |
x |
(2) |
+(x,0) |
→ |
x |
(3) |
+(x,s(y)) |
→ |
s(+(x,y)) |
(4) |
+(x,p(y)) |
→ |
p(+(x,y)) |
(5) |
-(x,0) |
→ |
x |
(6) |
-(x,s(y)) |
→ |
p(-(x,y)) |
(7) |
-(x,p(y)) |
→ |
s(-(x,y)) |
(8) |
The underlying signature is as follows:
{s/1, p/1, +/2, 0/0, -/2}Property / Task
Prove or disprove confluence.Answer / Result
Yes.Proof (by csi @ CoCo 2020)
1 Redundant Rules Transformation
To prove that the TRS is (non-)confluent, we show (non-)confluence of the following
modified system:
-(x,p(y)) |
→ |
s(-(x,y)) |
(8) |
-(x,s(y)) |
→ |
p(-(x,y)) |
(7) |
-(x,0) |
→ |
x |
(6) |
+(x,p(y)) |
→ |
p(+(x,y)) |
(5) |
+(x,s(y)) |
→ |
s(+(x,y)) |
(4) |
+(x,0) |
→ |
x |
(3) |
p(s(x)) |
→ |
x |
(2) |
s(p(x)) |
→ |
x |
(1) |
All redundant rules that were added or removed can be
simulated in 2 steps
.
1.1 Critical Pair Closing System
Confluence is proven using the following terminating critical-pair-closing-system R:
-(x,s(y)) |
→ |
p(-(x,y)) |
(7) |
s(p(x)) |
→ |
x |
(1) |
+(x,s(y)) |
→ |
s(+(x,y)) |
(4) |
p(s(x)) |
→ |
x |
(2) |
-(x,p(y)) |
→ |
s(-(x,y)) |
(8) |
+(x,p(y)) |
→ |
p(+(x,y)) |
(5) |
1.1.1 Rule Removal
Using the
linear polynomial interpretation over the naturals
[-(x1, x2)] |
= |
2 · x1 + 2 · x2 + 0 |
[s(x1)] |
= |
1 · x1 + 1 |
[+(x1, x2)] |
= |
4 · x1 + 1 · x2 + 0 |
[p(x1)] |
= |
1 · x1 + 2 |
all of the following rules can be deleted.
s(p(x)) |
→ |
x |
(1) |
p(s(x)) |
→ |
x |
(2) |
-(x,p(y)) |
→ |
s(-(x,y)) |
(8) |
1.1.1.1 Rule Removal
Using the
linear polynomial interpretation over the naturals
[-(x1, x2)] |
= |
4 · x1 + 1 · x2 + 4 |
[s(x1)] |
= |
1 · x1 + 6 |
[+(x1, x2)] |
= |
2 · x1 + 4 · x2 + 2 |
[p(x1)] |
= |
1 · x1 + 3 |
all of the following rules can be deleted.
-(x,s(y)) |
→ |
p(-(x,y)) |
(7) |
+(x,s(y)) |
→ |
s(+(x,y)) |
(4) |
+(x,p(y)) |
→ |
p(+(x,y)) |
(5) |
1.1.1.1.1 R is empty
There are no rules in the TRS. Hence, it is terminating.