R
↳Dependency Pair Analysis
MINUS(X, s(Y)) -> PRED(minus(X, Y))
MINUS(X, s(Y)) -> MINUS(X, Y)
LE(s(X), s(Y)) -> LE(X, Y)
GCD(s(X), s(Y)) -> IF(le(Y, X), s(X), s(Y))
GCD(s(X), s(Y)) -> LE(Y, X)
IF(true, s(X), s(Y)) -> GCD(minus(X, Y), s(Y))
IF(true, s(X), s(Y)) -> MINUS(X, Y)
IF(false, s(X), s(Y)) -> GCD(minus(Y, X), s(X))
IF(false, s(X), s(Y)) -> MINUS(Y, X)
R
↳DPs
→DP Problem 1
↳Forward Instantiation Transformation
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
MINUS(X, s(Y)) -> MINUS(X, Y)
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
MINUS(X, s(Y)) -> MINUS(X, Y)
MINUS(X'', s(s(Y''))) -> MINUS(X'', s(Y''))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 4
↳Forward Instantiation Transformation
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
MINUS(X'', s(s(Y''))) -> MINUS(X'', s(Y''))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
MINUS(X'', s(s(Y''))) -> MINUS(X'', s(Y''))
MINUS(X'''', s(s(s(Y'''')))) -> MINUS(X'''', s(s(Y'''')))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 4
↳FwdInst
...
→DP Problem 5
↳Argument Filtering and Ordering
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
MINUS(X'''', s(s(s(Y'''')))) -> MINUS(X'''', s(s(Y'''')))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
MINUS(X'''', s(s(s(Y'''')))) -> MINUS(X'''', s(s(Y'''')))
POL(MINUS(x1, x2)) = 1 + x1 + x2 POL(s(x1)) = 1 + x1
MINUS(x1, x2) -> MINUS(x1, x2)
s(x1) -> s(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 4
↳FwdInst
...
→DP Problem 6
↳Dependency Graph
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Forward Instantiation Transformation
→DP Problem 3
↳Nar
LE(s(X), s(Y)) -> LE(X, Y)
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
LE(s(X), s(Y)) -> LE(X, Y)
LE(s(s(X'')), s(s(Y''))) -> LE(s(X''), s(Y''))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 7
↳Forward Instantiation Transformation
→DP Problem 3
↳Nar
LE(s(s(X'')), s(s(Y''))) -> LE(s(X''), s(Y''))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
LE(s(s(X'')), s(s(Y''))) -> LE(s(X''), s(Y''))
LE(s(s(s(X''''))), s(s(s(Y'''')))) -> LE(s(s(X'''')), s(s(Y'''')))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 7
↳FwdInst
...
→DP Problem 8
↳Argument Filtering and Ordering
→DP Problem 3
↳Nar
LE(s(s(s(X''''))), s(s(s(Y'''')))) -> LE(s(s(X'''')), s(s(Y'''')))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
LE(s(s(s(X''''))), s(s(s(Y'''')))) -> LE(s(s(X'''')), s(s(Y'''')))
POL(LE(x1, x2)) = 1 + x1 + x2 POL(s(x1)) = 1 + x1
LE(x1, x2) -> LE(x1, x2)
s(x1) -> s(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 7
↳FwdInst
...
→DP Problem 9
↳Dependency Graph
→DP Problem 3
↳Nar
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Narrowing Transformation
IF(false, s(X), s(Y)) -> GCD(minus(Y, X), s(X))
IF(true, s(X), s(Y)) -> GCD(minus(X, Y), s(Y))
GCD(s(X), s(Y)) -> IF(le(Y, X), s(X), s(Y))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
three new Dependency Pairs are created:
GCD(s(X), s(Y)) -> IF(le(Y, X), s(X), s(Y))
GCD(s(s(Y'')), s(s(X''))) -> IF(le(X'', Y''), s(s(Y'')), s(s(X'')))
GCD(s(0), s(s(X''))) -> IF(false, s(0), s(s(X'')))
GCD(s(X'), s(0)) -> IF(true, s(X'), s(0))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Narrowing Transformation
GCD(s(X'), s(0)) -> IF(true, s(X'), s(0))
GCD(s(0), s(s(X''))) -> IF(false, s(0), s(s(X'')))
IF(true, s(X), s(Y)) -> GCD(minus(X, Y), s(Y))
GCD(s(s(Y'')), s(s(X''))) -> IF(le(X'', Y''), s(s(Y'')), s(s(X'')))
IF(false, s(X), s(Y)) -> GCD(minus(Y, X), s(X))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
two new Dependency Pairs are created:
IF(true, s(X), s(Y)) -> GCD(minus(X, Y), s(Y))
IF(true, s(X''), s(s(Y''))) -> GCD(pred(minus(X'', Y'')), s(s(Y'')))
IF(true, s(X''), s(0)) -> GCD(X'', s(0))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 11
↳Forward Instantiation Transformation
IF(true, s(X''), s(0)) -> GCD(X'', s(0))
GCD(s(X'), s(0)) -> IF(true, s(X'), s(0))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
IF(true, s(X''), s(0)) -> GCD(X'', s(0))
IF(true, s(s(X'''')), s(0)) -> GCD(s(X''''), s(0))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 13
↳Forward Instantiation Transformation
IF(true, s(s(X'''')), s(0)) -> GCD(s(X''''), s(0))
GCD(s(X'), s(0)) -> IF(true, s(X'), s(0))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
one new Dependency Pair is created:
GCD(s(X'), s(0)) -> IF(true, s(X'), s(0))
GCD(s(s(X'''''')), s(0)) -> IF(true, s(s(X'''''')), s(0))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 15
↳Argument Filtering and Ordering
GCD(s(s(X'''''')), s(0)) -> IF(true, s(s(X'''''')), s(0))
IF(true, s(s(X'''')), s(0)) -> GCD(s(X''''), s(0))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
IF(true, s(s(X'''')), s(0)) -> GCD(s(X''''), s(0))
POL(0) = 0 POL(GCD(x1, x2)) = x1 + x2 POL(true) = 0 POL(s(x1)) = 1 + x1 POL(IF(x1, x2, x3)) = x1 + x2 + x3
IF(x1, x2, x3) -> IF(x1, x2, x3)
GCD(x1, x2) -> GCD(x1, x2)
s(x1) -> s(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 20
↳Dependency Graph
GCD(s(s(X'''''')), s(0)) -> IF(true, s(s(X'''''')), s(0))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 12
↳Narrowing Transformation
IF(true, s(X''), s(s(Y''))) -> GCD(pred(minus(X'', Y'')), s(s(Y'')))
GCD(s(s(Y'')), s(s(X''))) -> IF(le(X'', Y''), s(s(Y'')), s(s(X'')))
IF(false, s(X), s(Y)) -> GCD(minus(Y, X), s(X))
GCD(s(0), s(s(X''))) -> IF(false, s(0), s(s(X'')))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
two new Dependency Pairs are created:
IF(false, s(X), s(Y)) -> GCD(minus(Y, X), s(X))
IF(false, s(s(Y'')), s(Y0)) -> GCD(pred(minus(Y0, Y'')), s(s(Y'')))
IF(false, s(0), s(Y')) -> GCD(Y', s(0))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 14
↳Narrowing Transformation
IF(false, s(s(Y'')), s(Y0)) -> GCD(pred(minus(Y0, Y'')), s(s(Y'')))
GCD(s(s(Y'')), s(s(X''))) -> IF(le(X'', Y''), s(s(Y'')), s(s(X'')))
IF(true, s(X''), s(s(Y''))) -> GCD(pred(minus(X'', Y'')), s(s(Y'')))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
three new Dependency Pairs are created:
GCD(s(s(Y'')), s(s(X''))) -> IF(le(X'', Y''), s(s(Y'')), s(s(X'')))
GCD(s(s(s(Y'))), s(s(s(X')))) -> IF(le(X', Y'), s(s(s(Y'))), s(s(s(X'))))
GCD(s(s(0)), s(s(s(X')))) -> IF(false, s(s(0)), s(s(s(X'))))
GCD(s(s(Y''')), s(s(0))) -> IF(true, s(s(Y''')), s(s(0)))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 16
↳Narrowing Transformation
GCD(s(s(Y''')), s(s(0))) -> IF(true, s(s(Y''')), s(s(0)))
GCD(s(s(0)), s(s(s(X')))) -> IF(false, s(s(0)), s(s(s(X'))))
IF(true, s(X''), s(s(Y''))) -> GCD(pred(minus(X'', Y'')), s(s(Y'')))
GCD(s(s(s(Y'))), s(s(s(X')))) -> IF(le(X', Y'), s(s(s(Y'))), s(s(s(X'))))
IF(false, s(s(Y'')), s(Y0)) -> GCD(pred(minus(Y0, Y'')), s(s(Y'')))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
two new Dependency Pairs are created:
IF(true, s(X''), s(s(Y''))) -> GCD(pred(minus(X'', Y'')), s(s(Y'')))
IF(true, s(X'''), s(s(s(Y')))) -> GCD(pred(pred(minus(X''', Y'))), s(s(s(Y'))))
IF(true, s(X'''), s(s(0))) -> GCD(pred(X'''), s(s(0)))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 17
↳Argument Filtering and Ordering
IF(true, s(X'''), s(s(0))) -> GCD(pred(X'''), s(s(0)))
GCD(s(s(Y''')), s(s(0))) -> IF(true, s(s(Y''')), s(s(0)))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
GCD(s(s(Y''')), s(s(0))) -> IF(true, s(s(Y''')), s(s(0)))
pred(s(X)) -> X
POL(0) = 0 POL(GCD(x1, x2)) = 1 + x1 + x2 POL(pred(x1)) = x1 POL(true) = 0 POL(s(x1)) = 1 + x1 POL(IF(x1, x2, x3)) = x1 + x2 + x3
GCD(x1, x2) -> GCD(x1, x2)
IF(x1, x2, x3) -> IF(x1, x2, x3)
s(x1) -> s(x1)
pred(x1) -> pred(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 21
↳Dependency Graph
IF(true, s(X'''), s(s(0))) -> GCD(pred(X'''), s(s(0)))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 18
↳Narrowing Transformation
IF(true, s(X'''), s(s(s(Y')))) -> GCD(pred(pred(minus(X''', Y'))), s(s(s(Y'))))
GCD(s(s(s(Y'))), s(s(s(X')))) -> IF(le(X', Y'), s(s(s(Y'))), s(s(s(X'))))
IF(false, s(s(Y'')), s(Y0)) -> GCD(pred(minus(Y0, Y'')), s(s(Y'')))
GCD(s(s(0)), s(s(s(X')))) -> IF(false, s(s(0)), s(s(s(X'))))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
two new Dependency Pairs are created:
IF(false, s(s(Y'')), s(Y0)) -> GCD(pred(minus(Y0, Y'')), s(s(Y'')))
IF(false, s(s(s(Y'))), s(Y0')) -> GCD(pred(pred(minus(Y0', Y'))), s(s(s(Y'))))
IF(false, s(s(0)), s(Y0')) -> GCD(pred(Y0'), s(s(0)))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 19
↳Argument Filtering and Ordering
IF(false, s(s(s(Y'))), s(Y0')) -> GCD(pred(pred(minus(Y0', Y'))), s(s(s(Y'))))
GCD(s(s(s(Y'))), s(s(s(X')))) -> IF(le(X', Y'), s(s(s(Y'))), s(s(s(X'))))
IF(true, s(X'''), s(s(s(Y')))) -> GCD(pred(pred(minus(X''', Y'))), s(s(s(Y'))))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost
IF(false, s(s(s(Y'))), s(Y0')) -> GCD(pred(pred(minus(Y0', Y'))), s(s(s(Y'))))
IF(true, s(X'''), s(s(s(Y')))) -> GCD(pred(pred(minus(X''', Y'))), s(s(s(Y'))))
pred(s(X)) -> X
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
POL(GCD(x1, x2)) = x1 + x2 POL(false) = 0 POL(pred(x1)) = x1 POL(true) = 0 POL(s(x1)) = 1 + x1 POL(le) = 0 POL(IF(x1, x2, x3)) = x1 + x2 + x3
IF(x1, x2, x3) -> IF(x1, x2, x3)
GCD(x1, x2) -> GCD(x1, x2)
s(x1) -> s(x1)
pred(x1) -> pred(x1)
minus(x1, x2) -> x1
le(x1, x2) -> le
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳FwdInst
→DP Problem 3
↳Nar
→DP Problem 10
↳Nar
...
→DP Problem 22
↳Dependency Graph
GCD(s(s(s(Y'))), s(s(s(X')))) -> IF(le(X', Y'), s(s(s(Y'))), s(s(s(X'))))
minus(X, s(Y)) -> pred(minus(X, Y))
minus(X, 0) -> X
pred(s(X)) -> X
le(s(X), s(Y)) -> le(X, Y)
le(s(X), 0) -> false
le(0, Y) -> true
gcd(0, Y) -> 0
gcd(s(X), 0) -> s(X)
gcd(s(X), s(Y)) -> if(le(Y, X), s(X), s(Y))
if(true, s(X), s(Y)) -> gcd(minus(X, Y), s(Y))
if(false, s(X), s(Y)) -> gcd(minus(Y, X), s(X))
innermost