We consider universal computability of the LCTRS with only rule scheme Calc: Signature: cond :: Bool -> Int -> Int -> Int log :: Int -> Int -> Int logNat :: Bool -> Int -> Int -> Int Rules: log(x, y) -> logNat(x >= 0 /\ y >= 2, x, y) logNat(true, x, y) -> cond(x <= y, x, y) cond(true, x, y) -> 1 cond(false, x, y) -> 2 * log(x, y * y) The system is accessible function passing by a sort ordering that equates all sorts. We start by computing the initial DP problem D1 = (P1, R UNION R_?, i, c), where: P1. (1) log#(x, y) => logNat#(x >= 0 /\ y >= 2, x, y) (2) logNat#(true, x, y) => cond#(x <= y, x, y) (3) cond#(false, x, y) => log#(x, y * y) ***** We apply the Chaining Processor Processor on D1 = (P1, R UNION R_?, i, c). We chain DPs according to the following mapping: cond#(false, x, y) => logNat#(x >= 0 /\ y * y >= 2, x, y * y) | true /\ true is obtained by chaining cond#(false, x, y) => log#(x, y * y) and log#(x', y') => logNat#(x' >= 0 /\ y' >= 2, x', y') The following DPs were deleted: cond#(false, x, y) => log#(x, y * y) log#(x, y) => logNat#(x >= 0 /\ y >= 2, x, y) By chaining, we added 1 DPs and removed 2 DPs. Processor output: { D2 = (P2, R UNION R_?, i, c) }, where: P2. (1) logNat#(true, x, y) => cond#(x <= y, x, y) (2) cond#(false, x, y) => logNat#(x >= 0 /\ y * y >= 2, x, y * y) | true /\ true ***** We apply the Theory Arguments Processor on D2 = (P2, R UNION R_?, i, c). We use the following theory arguments function: cond# : [1, 2, 3] logNat# : [1, 2, 3] Processor output: { D3 = (P3, R UNION R_?, i, c) ; D4 = (P4, R UNION R_?, i, c) }, where: P3. (1) logNat#(true, x, y) => cond#(x <= y, x, y) (2) cond#(false, x, y) => logNat#(x >= 0 /\ y * y >= 2, x, y * y) | true /\ true /\ x = x /\ y = y P4. (1) cond#(false, x, y) => logNat#(x >= 0 /\ y * y >= 2, x, y * y) | true /\ true ***** We apply the Theory Arguments Processor on D3 = (P3, R UNION R_?, i, c). We use the following theory arguments function: cond# : [1, 2, 3] logNat# : [1, 2, 3] Processor output: { D5 = (P5, R UNION R_?, i, c) ; D6 = (P6, R UNION R_?, i, c) }, where: P5. (1) logNat#(true, x, y) => cond#(x <= y, x, y) | x = x /\ y = y (2) cond#(false, x, y) => logNat#(x >= 0 /\ y * y >= 2, x, y * y) | true /\ true /\ x = x /\ y = y P6. (1) logNat#(true, x, y) => cond#(x <= y, x, y) ***** We apply the Graph Processor on D4 = (P4, R UNION R_?, i, c). We compute a graph approximation with the following edges: 1: As there are no SCCs, this DP problem is removed. Processor output: { }. ***** We apply the Usable Rules Processor on D5 = (P5, R UNION R_?, i, c). We obtain 0 usable rules (out of 4 rules in the input problem). Processor output: { D7 = (P5, {}, i, c) }. ***** We apply the Graph Processor on D6 = (P6, R UNION R_?, i, c). We compute a graph approximation with the following edges: 1: As there are no SCCs, this DP problem is removed. Processor output: { }. ***** No progress could be made on DP problem D7 = (P5, {}, i, c).