inductive imf {A B : Sort*} (f : A → B) : B → Sort* | mk : ∀ (a : A), imf (f a) definition inv_1 {A B : Sort*} (f : A → B) : ∀ (b : B), imf f b → A | .(f .(a)) (imf.mk .(f) a) := a -- Error inaccessible annotation inside inaccessible annotation definition inv_2 {A B : Sort*} (f : A → B) : ∀ (b : B), imf f b → A | .(f a) (let x := (imf.mk .(f) a) in x) := a -- Error invalid occurrence of 'let' expression definition inv_3 {A B : Sort*} (f : A → B) : ∀ (b : B), imf f b → A | .(f a) ((λ (x : imf f b), x) (imf.mk .(f) a)) := a -- Error invalid occurrence of 'lambda' expression definition symm {A : Sort*} : ∀ a b : A, a = b → b = a | .(a) .(a) (eq.refl a) := rfl -- Error `a` in eq.refl must be marked as inaccessible since it is an inductive datatype parameter