The system is accessible function passing by a sort ordering that equates all sorts. We start by computing the following initial DP problem: P1. (1) eval#(x, y, z) => eval#(x + 1, y, z) | y > x /\ z > x (2) eval#(x, y, z) => eval#(x, y, z + 1) | y > x /\ x >= z ***** We apply the Integer Function Processor on P1. We use the following integer mapping: J(eval#) = arg_2 - arg_1 - 1 We thus have: (1) y > x /\ z > x |= y - x - 1 > y - (x + 1) - 1 (and y - x - 1 >= 0) (2) y > x /\ x >= z |= y - x - 1 >= y - x - 1 We may remove the strictly oriented DPs, which yields: P2. (1) eval#(x, y, z) => eval#(x, y, z + 1) | y > x /\ x >= z ***** We apply the Integer Function Processor on P2. We use the following integer mapping: J(eval#) = arg_1 - arg_3 We thus have: (1) y > x /\ x >= z |= x - z > x - (z + 1) (and x - z >= 0) All DPs are strictly oriented, and may be removed. Hence, this DP problem is finite.