R
↳Dependency Pair Analysis
HALF(s(s(x))) -> S(half(x))
HALF(s(s(x))) -> HALF(x)
S(log(0)) -> S(0)
LOG(s(x)) -> S(log(half(s(x))))
LOG(s(x)) -> LOG(half(s(x)))
LOG(s(x)) -> HALF(s(x))
R
↳DPs
→DP Problem 1
↳Forward Instantiation Transformation
→DP Problem 2
↳Nar
HALF(s(s(x))) -> HALF(x)
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
one new Dependency Pair is created:
HALF(s(s(x))) -> HALF(x)
HALF(s(s(s(s(x''))))) -> HALF(s(s(x'')))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳Argument Filtering and Ordering
→DP Problem 2
↳Nar
HALF(s(s(s(s(x''))))) -> HALF(s(s(x'')))
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
HALF(s(s(s(s(x''))))) -> HALF(s(s(x'')))
s(log(0)) -> s(0)
HALF(x1) -> HALF(x1)
s(x1) -> s(x1)
log(x1) -> log(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 3
↳AFS
...
→DP Problem 4
↳Dependency Graph
→DP Problem 2
↳Nar
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Narrowing Transformation
LOG(s(x)) -> LOG(half(s(x)))
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
two new Dependency Pairs are created:
LOG(s(x)) -> LOG(half(s(x)))
LOG(s(0)) -> LOG(0)
LOG(s(s(x''))) -> LOG(s(half(x'')))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 5
↳Narrowing Transformation
LOG(s(s(x''))) -> LOG(s(half(x'')))
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
three new Dependency Pairs are created:
LOG(s(s(x''))) -> LOG(s(half(x'')))
LOG(s(s(0))) -> LOG(s(0))
LOG(s(s(s(0)))) -> LOG(s(0))
LOG(s(s(s(s(x'))))) -> LOG(s(s(half(x'))))
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 5
↳Nar
...
→DP Problem 6
↳Argument Filtering and Ordering
LOG(s(s(s(s(x'))))) -> LOG(s(s(half(x'))))
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost
LOG(s(s(s(s(x'))))) -> LOG(s(s(half(x'))))
s(log(0)) -> s(0)
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
LOG(x1) -> LOG(x1)
s(x1) -> s(x1)
half(x1) -> x1
log(x1) -> log(x1)
R
↳DPs
→DP Problem 1
↳FwdInst
→DP Problem 2
↳Nar
→DP Problem 5
↳Nar
...
→DP Problem 7
↳Dependency Graph
half(0) -> 0
half(s(0)) -> 0
half(s(s(x))) -> s(half(x))
s(log(0)) -> s(0)
log(s(x)) -> s(log(half(s(x))))
innermost