34 lines
876 B
Text
34 lines
876 B
Text
|
import logic
|
||
|
|
||
|
namespace nat
|
||
|
variable nat : Type.{1}
|
||
|
variable add : nat → nat → nat
|
||
|
variable le : nat → nat → Prop
|
||
|
variable one : nat
|
||
|
infixl `+`:65 := add
|
||
|
infix `≤`:50 := le
|
||
|
axiom add_assoc (a b c : nat) : (a + b) + c = a + (b + c)
|
||
|
axiom add_le_left {a b : nat} (H : a ≤ b) (c : nat) : c + a ≤ c + b
|
||
|
end nat
|
||
|
|
||
|
namespace int
|
||
|
variable int : Type.{1}
|
||
|
variable add : int → int → int
|
||
|
variable le : int → int → Prop
|
||
|
variable one : int
|
||
|
infixl `+`:65 := add
|
||
|
infix `≤`:50 := le
|
||
|
axiom add_assoc (a b c : int) : (a + b) + c = a + (b + c)
|
||
|
axiom add_le_left {a b : int} (H : a ≤ b) (c : int) : c + a ≤ c + b
|
||
|
abbreviation lt (a b : int) := a + one ≤ b
|
||
|
infix `<`:50 := lt
|
||
|
end int
|
||
|
|
||
|
using int
|
||
|
using nat
|
||
|
|
||
|
set_option unifier.expensive true
|
||
|
|
||
|
theorem add_lt_left {a b : int} (H : a < b) (c : int) : c + a < c + b :=
|
||
|
subst (symm (add_assoc c a one)) (add_le_left H c)
|