namespace Ex1 mutual def f : Nat → α → α → α | 0, a, b => a | n, a, b => g a n b |>.1 def g : α → Nat → α → (α × α) | a, 0, b => (a, b) | a, n, b => (h a b n, a) def h : α → α → Nat → α | a, b, 0 => b | a, b, n+1 => f n a b end termination_by' invImage (fun | PSum.inl ⟨n, _, _⟩ => (n, 2) | PSum.inr <| PSum.inl ⟨_, n, _⟩ => (n, 1) | PSum.inr <| PSum.inr ⟨_, _, n⟩ => (n, 0)) (Prod.lex sizeOfWFRel sizeOfWFRel) #print f #print g #print h #eval f 5 'a' 'b' end Ex1 namespace Ex2 mutual def f : Nat → α → α → α | 0, a, b => a | n, a, b => g a n b |>.1 def g : α → Nat → α → (α × α) | a, 0, b => (a, b) | a, n, b => (h a b n, a) def h : α → α → Nat → α | a, b, 0 => b | a, b, n+1 => f n a b end termination_by f n _ _ => (n, 2) g _ n _ => (n, 1) h _ _ n => (n, 0) #print f #print g #print h #eval f 5 'a' 'b' end Ex2