R
↳Dependency Pair Analysis
+'(x, +(y, z)) -> +'(+(x, y), z)
+'(x, +(y, z)) -> +'(x, y)
+'(+(x, *(y, z)), *(y, u)) -> +'(x, *(y, +(z, u)))
+'(+(x, *(y, z)), *(y, u)) -> *'(y, +(z, u))
+'(+(x, *(y, z)), *(y, u)) -> +'(z, u)
*'(x, +(y, z)) -> +'(*(x, y), *(x, z))
*'(x, +(y, z)) -> *'(x, y)
*'(x, +(y, z)) -> *'(x, z)
R
↳DPs
→DP Problem 1
↳Argument Filtering and Ordering
*'(x, +(y, z)) -> *'(x, y)
*'(x, +(y, z)) -> +'(*(x, y), *(x, z))
+'(+(x, *(y, z)), *(y, u)) -> *'(y, +(z, u))
+'(x, +(y, z)) -> +'(x, y)
+'(+(x, *(y, z)), *(y, u)) -> +'(x, *(y, +(z, u)))
+'(x, +(y, z)) -> +'(+(x, y), z)
+(x, +(y, z)) -> +(+(x, y), z)
+(+(x, *(y, z)), *(y, u)) -> +(x, *(y, +(z, u)))
*(x, +(y, z)) -> +(*(x, y), *(x, z))
innermost
*'(x, +(y, z)) -> *'(x, y)
*'(x, +(y, z)) -> +'(*(x, y), *(x, z))
+'(x, +(y, z)) -> +'(x, y)
+(x, +(y, z)) -> +(+(x, y), z)
+(+(x, *(y, z)), *(y, u)) -> +(x, *(y, +(z, u)))
*(x, +(y, z)) -> +(*(x, y), *(x, z))
POL(+(x1, x2)) = 1 + x1 + x2 POL(+'(x1, x2)) = x1 + x2
+'(x1, x2) -> +'(x1, x2)
+(x1, x2) -> +(x1, x2)
*(x1, x2) -> x2
*'(x1, x2) -> x2
R
↳DPs
→DP Problem 1
↳AFS
→DP Problem 2
↳Dependency Graph
+'(+(x, *(y, z)), *(y, u)) -> *'(y, +(z, u))
+'(+(x, *(y, z)), *(y, u)) -> +'(x, *(y, +(z, u)))
+'(x, +(y, z)) -> +'(+(x, y), z)
+(x, +(y, z)) -> +(+(x, y), z)
+(+(x, *(y, z)), *(y, u)) -> +(x, *(y, +(z, u)))
*(x, +(y, z)) -> +(*(x, y), *(x, z))
innermost
R
↳DPs
→DP Problem 1
↳AFS
→DP Problem 2
↳DGraph
...
→DP Problem 3
↳Narrowing Transformation
+'(x, +(y, z)) -> +'(+(x, y), z)
+'(+(x, *(y, z)), *(y, u)) -> +'(x, *(y, +(z, u)))
+(x, +(y, z)) -> +(+(x, y), z)
+(+(x, *(y, z)), *(y, u)) -> +(x, *(y, +(z, u)))
*(x, +(y, z)) -> +(*(x, y), *(x, z))
innermost
one new Dependency Pair is created:
+'(+(x, *(y, z)), *(y, u)) -> +'(x, *(y, +(z, u)))
+'(+(x, *(y'', z'')), *(y'', u')) -> +'(x, +(*(y'', z''), *(y'', u')))
R
↳DPs
→DP Problem 1
↳AFS
→DP Problem 2
↳DGraph
...
→DP Problem 4
↳Remaining Obligation(s)
+'(+(x, *(y'', z'')), *(y'', u')) -> +'(x, +(*(y'', z''), *(y'', u')))
+'(x, +(y, z)) -> +'(+(x, y), z)
+(x, +(y, z)) -> +(+(x, y), z)
+(+(x, *(y, z)), *(y, u)) -> +(x, *(y, +(z, u)))
*(x, +(y, z)) -> +(*(x, y), *(x, z))
innermost