const In : set set prop term iIn = In infix iIn 2000 2000 term Subq = \x:set.\y:set.!z:set.z iIn x -> z iIn y const omega : set const ordsucc : set set axiom omega_ordsucc: !x:set.x iIn omega -> ordsucc x iIn omega const SNo : set prop const eps_ : set set axiom SNo_eps_: !x:set.x iIn omega -> SNo (eps_ x) const SNoS_ : set set const SNoLt : set set prop term < = SNoLt infix < 2020 2020 const Empty : set const add_SNo : set set set term + = add_SNo infix + 2281 2280 const SNoLe : set set prop term <= = SNoLe infix <= 2020 2020 lemma !x:set.!y:set.!P:prop.!z:set.!w:set.SNo x -> y iIn omega -> (!u:set.u iIn SNoS_ omega -> Empty < u -> u < x -> x < u + eps_ y -> P) -> x < z + eps_ y -> SNo z -> z <= Empty -> ~ P -> w iIn omega -> eps_ w <= x -> SNo (eps_ w) -> SNo (eps_ (ordsucc w)) -> x < eps_ w var x:set var y:set var P:prop var z:set var w:set hyp SNo x hyp y iIn omega hyp !u:set.u iIn SNoS_ omega -> Empty < u -> u < x -> x < u + eps_ y -> P hyp x < z + eps_ y hyp SNo z hyp z <= Empty hyp ~ P hyp w iIn omega hyp eps_ w <= x claim SNo (eps_ w) -> x < eps_ w