Documentation

Init.Data.UInt.Lemmas

Equations
  • One or more equations did not get rendered due to their size.
theorem UInt8.add_def (a b : UInt8) :
a + b = { toBitVec := a.toBitVec + b.toBitVec }
@[deprecated UInt8.toNat_toBitVec (since := "2025-02-21")]
@[simp]
theorem UInt8.toNat_mul (a b : UInt8) :
(a * b).toNat = a.toNat * b.toNat % 2 ^ 8
theorem UInt8.mod_lt (a : UInt8) {b : UInt8} :
0 < ba % b < b
@[deprecated UInt8.toFin_ofNat (since := "2025-02-12")]
theorem UInt8.toNat_mod_lt {m : Nat} (u : UInt8) :
0 < m(u % ofNat m).toNat < m
@[simp]
theorem UInt8.not_le {a b : UInt8} :
¬a b b < a
@[simp]
theorem UInt8.toNat_ofBitVec {a : BitVec 8} :
{ toBitVec := a }.toNat = a.toNat
theorem UInt8.le_antisymm {a b : UInt8} (h₁ : a b) (h₂ : b a) :
a = b
@[deprecated UInt8.toFin_inj (since := "2025-02-12")]
theorem UInt8.val_inj {a b : UInt8} :
a.toFin = b.toFin a = b
@[simp]
theorem UInt8.ofNat_toNat {x : UInt8} :
theorem UInt8.one_def :
1 = { toBitVec := 1 }
@[simp]
theorem UInt8.toNat_zero :
toNat 0 = 0
@[deprecated UInt8.lt_iff_toBitVec_lt (since := "2025-03-20")]
theorem UInt8.lt_def {a b : UInt8} :
@[deprecated "Use `toNat_toBitVec` and `toNat_ofNat_of_lt`." (since := "2025-03-05")]
theorem UInt8.toBitVec_eq_of_lt {a : Nat} :
a < size(ofNat a).toBitVec.toNat = a
theorem UInt8.zero_def :
0 = { toBitVec := 0 }
theorem UInt8.le_antisymm_iff {a b : UInt8} :
a = b a b b a
theorem UInt8.toNat.inj {a b : UInt8} :
a.toNat = b.toNata = b
@[simp]
theorem UInt8.toNat_mod (a b : UInt8) :
(a % b).toNat = a.toNat % b.toNat
@[deprecated UInt8.ofBitVec_toBitVec (since := "2025-02-21")]
theorem UInt8.ofBitVec_toBitVec_eq (a : UInt8) :
{ toBitVec := a.toBitVec } = a
theorem UInt8.lt_trans {a b c : UInt8} :
a < bb < ca < c
@[simp]
theorem UInt8.toBitVec_add {a b : UInt8} :
theorem UInt8.mod_def (a b : UInt8) :
a % b = { toBitVec := a.toBitVec % b.toBitVec }
@[simp]
theorem UInt8.le_refl (a : UInt8) :
a a
theorem UInt8.le_rfl {a : UInt8} :
a a
theorem UInt8.eq_of_toBitVec_eq {a b : UInt8} (h : a.toBitVec = b.toBitVec) :
a = b
@[simp]
theorem UInt8.toNat_sub_of_le (a b : UInt8) :
b a(a - b).toNat = a.toNat - b.toNat
theorem UInt8.mul_def (a b : UInt8) :
a * b = { toBitVec := a.toBitVec * b.toBitVec }
@[simp]
theorem UInt8.toBitVec_sub {a b : UInt8} :
@[simp]
theorem UInt8.toNat_ofNat' {n : Nat} :
(ofNat n).toNat = n % 2 ^ 8
@[simp]
theorem UInt8.ofBitVec_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 8 n } = OfNat.ofNat n
@[deprecated UInt8.ofBitVec_ofNat (since := "2025-02-12")]
theorem UInt8.mk_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 8 n } = OfNat.ofNat n
theorem UInt8.le_total (a b : UInt8) :
a b b a
theorem UInt8.lt_asymm {a b : UInt8} :
a < b¬b < a
@[simp]
theorem UInt8.toNat_add (a b : UInt8) :
(a + b).toNat = (a.toNat + b.toNat) % 2 ^ 8
theorem UInt8.toNat_ofNat_of_lt' {n : Nat} (h : n < size) :
(ofNat n).toNat = n
@[deprecated UInt8.toNat_ofNatLT (since := "2025-02-13")]
theorem UInt8.toNat_ofNatCore {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[deprecated UInt8.ofBitVec_toBitVec_eq (since := "2025-02-12")]
theorem UInt8.mk_toBitVec_eq (a : UInt8) :
{ toBitVec := a.toBitVec } = a
@[deprecated UInt8.toNat_mod_lt (since := "2024-09-24")]
theorem UInt8.modn_lt {m : Nat} (u : UInt8) :
m > 0(u % m).toNat < m
@[simp]
theorem UInt8.toNat_div (a b : UInt8) :
(a / b).toNat = a.toNat / b.toNat
@[deprecated UInt8.toNat_ofBitVec (since := "2025-02-12")]
theorem UInt8.toNat_mk {a : BitVec 8} :
{ toBitVec := a }.toNat = a.toNat
@[deprecated UInt8.eq_of_toFin_eq (since := "2025-02-12")]
theorem UInt8.eq_of_val_eq {a b : UInt8} (h : a.toFin = b.toFin) :
a = b
@[simp]
theorem UInt8.toBitVec_mod {a b : UInt8} :
@[simp]
theorem UInt8.lt_irrefl (a : UInt8) :
¬a < a
theorem UInt8.sub_def (a b : UInt8) :
a - b = { toBitVec := a.toBitVec - b.toBitVec }
theorem UInt8.ne_of_lt {a b : UInt8} (h : a < b) :
a b
theorem UInt8.toFin_inj {a b : UInt8} :
a.toFin = b.toFin a = b
theorem UInt8.le_trans {a b c : UInt8} :
a bb ca c
@[deprecated UInt8.le_iff_toBitVec_le (since := "2025-03-20")]
theorem UInt8.le_def {a b : UInt8} :
theorem UInt8.eq_of_toFin_eq {a b : UInt8} (h : a.toFin = b.toFin) :
a = b
@[simp]
theorem UInt8.ofNat_one :
ofNat 1 = 1
theorem UInt8.toNat_sub (a b : UInt8) :
(a - b).toNat = (2 ^ 8 - b.toNat + a.toNat) % 2 ^ 8
theorem UInt8.toNat_ofNat {n : Nat} :
(OfNat.ofNat n).toNat = n % 2 ^ 8
@[simp]
theorem UInt8.toBitVec_div {a b : UInt8} :
@[simp]
@[simp]
theorem UInt8.toFin_val (x : UInt8) :
x.toFin = x.toNat
@[simp]
@[simp]
theorem UInt8.not_lt {a b : UInt8} :
¬a < b b a
@[simp]
theorem UInt8.toBitVec_mul {a b : UInt8} :
theorem UInt8.toNat_inj {a b : UInt8} :
a.toNat = b.toNat a = b
theorem UInt8.toBitVec_eq_of_eq {a b : UInt8} (h : a = b) :
@[deprecated UInt8.toFin_val (since := "2025-02-12")]
theorem UInt8.val_val_eq_toNat (x : UInt8) :
x.toFin = x.toNat
@[simp]
theorem UInt8.toNat_ofNatLT {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[simp]
theorem UInt8.ofBitVec_toBitVec (a : UInt8) :
{ toBitVec := a.toBitVec } = a
@[simp]
@[deprecated UInt16.toFin_ofNat (since := "2025-02-12")]
theorem UInt16.lt_trans {a b c : UInt16} :
a < bb < ca < c
theorem UInt16.le_antisymm {a b : UInt16} (h₁ : a b) (h₂ : b a) :
a = b
@[deprecated UInt16.lt_iff_toBitVec_lt (since := "2025-03-20")]
theorem UInt16.lt_def {a b : UInt16} :
theorem UInt16.toNat_sub (a b : UInt16) :
(a - b).toNat = (2 ^ 16 - b.toNat + a.toNat) % 2 ^ 16
theorem UInt16.sub_def (a b : UInt16) :
a - b = { toBitVec := a.toBitVec - b.toBitVec }
@[simp]
theorem UInt16.toNat_mul (a b : UInt16) :
(a * b).toNat = a.toNat * b.toNat % 2 ^ 16
@[simp]
theorem UInt16.toNat_add (a b : UInt16) :
(a + b).toNat = (a.toNat + b.toNat) % 2 ^ 16
@[simp]
theorem UInt16.toNat_ofBitVec {a : BitVec 16} :
{ toBitVec := a }.toNat = a.toNat
@[simp]
theorem UInt16.lt_irrefl (a : UInt16) :
¬a < a
theorem UInt16.le_antisymm_iff {a b : UInt16} :
a = b a b b a
@[deprecated UInt16.toNat_ofBitVec (since := "2025-02-12")]
theorem UInt16.toNat_mk {a : BitVec 16} :
{ toBitVec := a }.toNat = a.toNat
@[simp]
theorem UInt16.toFin_val (x : UInt16) :
x.toFin = x.toNat
@[deprecated UInt16.ofBitVec_toBitVec_eq (since := "2025-02-12")]
theorem UInt16.mk_toBitVec_eq (a : UInt16) :
{ toBitVec := a.toBitVec } = a
theorem UInt16.toNat_ofNat_of_lt' {n : Nat} (h : n < size) :
(ofNat n).toNat = n
theorem UInt16.le_total (a b : UInt16) :
a b b a
theorem UInt16.le_trans {a b c : UInt16} :
a bb ca c
theorem UInt16.toBitVec_eq_of_eq {a b : UInt16} (h : a = b) :
@[simp]
theorem UInt16.le_refl (a : UInt16) :
a a
@[deprecated UInt16.toNat_toBitVec (since := "2025-02-21")]
@[simp]
@[simp]
theorem UInt16.not_lt {a b : UInt16} :
¬a < b b a
theorem UInt16.lt_asymm {a b : UInt16} :
a < b¬b < a
@[deprecated UInt16.le_iff_toBitVec_le (since := "2025-03-20")]
theorem UInt16.le_def {a b : UInt16} :
@[simp]
theorem UInt16.toNat_inj {a b : UInt16} :
a.toNat = b.toNat a = b
@[deprecated UInt16.ofBitVec_ofNat (since := "2025-02-12")]
theorem UInt16.mk_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 16 n } = OfNat.ofNat n
theorem UInt16.mul_def (a b : UInt16) :
a * b = { toBitVec := a.toBitVec * b.toBitVec }
@[simp]
theorem UInt16.toNat_ofNat {n : Nat} :
(OfNat.ofNat n).toNat = n % 2 ^ 16
@[deprecated UInt16.ofBitVec_toBitVec (since := "2025-02-21")]
theorem UInt16.ofBitVec_toBitVec_eq (a : UInt16) :
{ toBitVec := a.toBitVec } = a
@[deprecated UInt16.eq_of_toFin_eq (since := "2025-02-12")]
theorem UInt16.eq_of_val_eq {a b : UInt16} (h : a.toFin = b.toFin) :
a = b
@[simp]
@[simp]
theorem UInt16.toNat_ofNat' {n : Nat} :
(ofNat n).toNat = n % 2 ^ 16
@[simp]
theorem UInt16.toNat_div (a b : UInt16) :
(a / b).toNat = a.toNat / b.toNat
@[simp]
theorem UInt16.mod_lt (a : UInt16) {b : UInt16} :
0 < ba % b < b
@[deprecated UInt16.toNat_mod_lt (since := "2024-09-24")]
theorem UInt16.modn_lt {m : Nat} (u : UInt16) :
m > 0(u % m).toNat < m
theorem UInt16.ne_of_lt {a b : UInt16} (h : a < b) :
a b
@[simp]
theorem UInt16.ofNat_one :
ofNat 1 = 1
theorem UInt16.le_rfl {a : UInt16} :
a a
theorem UInt16.one_def :
1 = { toBitVec := 1 }
@[deprecated "Use `toNat_toBitVec` and `toNat_ofNat_of_lt`." (since := "2025-03-05")]
theorem UInt16.toBitVec_eq_of_lt {a : Nat} :
a < size(ofNat a).toBitVec.toNat = a
@[deprecated UInt16.toNat_ofNatLT (since := "2025-02-13")]
theorem UInt16.toNat_ofNatCore {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
theorem UInt16.eq_of_toFin_eq {a b : UInt16} (h : a.toFin = b.toFin) :
a = b
theorem UInt16.toNat.inj {a b : UInt16} :
a.toNat = b.toNata = b
theorem UInt16.eq_of_toBitVec_eq {a b : UInt16} (h : a.toBitVec = b.toBitVec) :
a = b
@[simp]
@[deprecated UInt16.toFin_val (since := "2025-02-12")]
theorem UInt16.mod_def (a b : UInt16) :
a % b = { toBitVec := a.toBitVec % b.toBitVec }
@[simp]
theorem UInt16.toNat_sub_of_le (a b : UInt16) :
b a(a - b).toNat = a.toNat - b.toNat
theorem UInt16.add_def (a b : UInt16) :
a + b = { toBitVec := a.toBitVec + b.toBitVec }
theorem UInt16.toFin_inj {a b : UInt16} :
a.toFin = b.toFin a = b
@[simp]
theorem UInt16.ofBitVec_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 16 n } = OfNat.ofNat n
@[simp]
@[simp]
theorem UInt16.toNat_ofNatLT {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[simp]
theorem UInt16.not_le {a b : UInt16} :
¬a b b < a
theorem UInt16.toNat_mod_lt {m : Nat} (u : UInt16) :
0 < m(u % ofNat m).toNat < m
@[simp]
theorem UInt16.toNat_mod (a b : UInt16) :
(a % b).toNat = a.toNat % b.toNat
theorem UInt16.zero_def :
0 = { toBitVec := 0 }
@[simp]
theorem UInt16.ofBitVec_toBitVec (a : UInt16) :
{ toBitVec := a.toBitVec } = a
@[deprecated UInt16.toFin_inj (since := "2025-02-12")]
theorem UInt16.val_inj {a b : UInt16} :
a.toFin = b.toFin a = b
@[deprecated UInt32.toNat_mod_lt (since := "2024-09-24")]
theorem UInt32.modn_lt {m : Nat} (u : UInt32) :
m > 0(u % m).toNat < m
@[simp]
theorem UInt32.ofBitVec_toBitVec (a : UInt32) :
{ toBitVec := a.toBitVec } = a
@[simp]
theorem UInt32.not_le {a b : UInt32} :
¬a b b < a
theorem UInt32.le_rfl {a : UInt32} :
a a
@[simp]
theorem UInt32.le_refl (a : UInt32) :
a a
theorem UInt32.le_antisymm {a b : UInt32} (h₁ : a b) (h₂ : b a) :
a = b
theorem UInt32.toNat_mod_lt {m : Nat} (u : UInt32) :
0 < m(u % ofNat m).toNat < m
@[deprecated UInt32.ofBitVec_toBitVec_eq (since := "2025-02-12")]
theorem UInt32.mk_toBitVec_eq (a : UInt32) :
{ toBitVec := a.toBitVec } = a
@[deprecated UInt32.toFin_inj (since := "2025-02-12")]
theorem UInt32.val_inj {a b : UInt32} :
a.toFin = b.toFin a = b
@[deprecated UInt32.toNat_ofBitVec (since := "2025-02-12")]
theorem UInt32.toNat_mk {a : BitVec 32} :
{ toBitVec := a }.toNat = a.toNat
@[simp]
@[deprecated UInt32.le_iff_toBitVec_le (since := "2025-03-20")]
theorem UInt32.le_def {a b : UInt32} :
@[deprecated "Use `toNat_toBitVec` and `toNat_ofNat_of_lt`." (since := "2025-03-05")]
theorem UInt32.toBitVec_eq_of_lt {a : Nat} :
a < size(ofNat a).toBitVec.toNat = a
theorem UInt32.lt_asymm {a b : UInt32} :
a < b¬b < a
@[simp]
theorem UInt32.toNat_inj {a b : UInt32} :
a.toNat = b.toNat a = b
@[simp]
@[simp]
theorem UInt32.toNat_mul (a b : UInt32) :
(a * b).toNat = a.toNat * b.toNat % 2 ^ 32
theorem UInt32.le_antisymm_iff {a b : UInt32} :
a = b a b b a
@[simp]
theorem UInt32.toNat_add (a b : UInt32) :
(a + b).toNat = (a.toNat + b.toNat) % 2 ^ 32
theorem UInt32.toNat_ofNat {n : Nat} :
(OfNat.ofNat n).toNat = n % 2 ^ 32
theorem UInt32.ne_of_lt {a b : UInt32} (h : a < b) :
a b
@[simp]
theorem UInt32.toNat_div (a b : UInt32) :
(a / b).toNat = a.toNat / b.toNat
theorem UInt32.le_trans {a b c : UInt32} :
a bb ca c
@[simp]
@[simp]
theorem UInt32.toFin_inj {a b : UInt32} :
a.toFin = b.toFin a = b
theorem UInt32.toNat_sub (a b : UInt32) :
(a - b).toNat = (2 ^ 32 - b.toNat + a.toNat) % 2 ^ 32
@[simp]
@[simp]
theorem UInt32.toNat_ofNat' {n : Nat} :
(ofNat n).toNat = n % 2 ^ 32
@[simp]
theorem UInt32.ofNat_one :
ofNat 1 = 1
@[deprecated UInt32.eq_of_toFin_eq (since := "2025-02-12")]
theorem UInt32.eq_of_val_eq {a b : UInt32} (h : a.toFin = b.toFin) :
a = b
theorem UInt32.lt_trans {a b c : UInt32} :
a < bb < ca < c
@[deprecated UInt32.toNat_toBitVec (since := "2025-02-21")]
theorem UInt32.toNat_ofNat_of_lt' {n : Nat} (h : n < size) :
(ofNat n).toNat = n
theorem UInt32.one_def :
1 = { toBitVec := 1 }
theorem UInt32.add_def (a b : UInt32) :
a + b = { toBitVec := a.toBitVec + b.toBitVec }
theorem UInt32.eq_of_toBitVec_eq {a b : UInt32} (h : a.toBitVec = b.toBitVec) :
a = b
theorem UInt32.toBitVec_eq_of_eq {a b : UInt32} (h : a = b) :
theorem UInt32.mul_def (a b : UInt32) :
a * b = { toBitVec := a.toBitVec * b.toBitVec }
@[deprecated UInt32.lt_iff_toBitVec_lt (since := "2025-03-20")]
theorem UInt32.lt_def {a b : UInt32} :
@[deprecated UInt32.toNat_ofNatLT (since := "2025-02-13")]
theorem UInt32.toNat_ofNatCore {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[simp]
@[simp]
@[simp]
theorem UInt32.toNat_ofNatLT {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
theorem UInt32.mod_lt (a : UInt32) {b : UInt32} :
0 < ba % b < b
@[deprecated UInt32.ofBitVec_ofNat (since := "2025-02-12")]
theorem UInt32.mk_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 32 n } = OfNat.ofNat n
@[simp]
theorem UInt32.toNat_mod (a b : UInt32) :
(a % b).toNat = a.toNat % b.toNat
@[simp]
theorem UInt32.ofBitVec_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 32 n } = OfNat.ofNat n
theorem UInt32.le_total (a b : UInt32) :
a b b a
theorem UInt32.zero_def :
0 = { toBitVec := 0 }
@[simp]
theorem UInt32.lt_irrefl (a : UInt32) :
¬a < a
@[deprecated UInt32.ofBitVec_toBitVec (since := "2025-02-21")]
theorem UInt32.ofBitVec_toBitVec_eq (a : UInt32) :
{ toBitVec := a.toBitVec } = a
@[simp]
theorem UInt32.toNat_ofBitVec {a : BitVec 32} :
{ toBitVec := a }.toNat = a.toNat
@[simp]
theorem UInt32.toFin_val (x : UInt32) :
x.toFin = x.toNat
@[simp]
theorem UInt32.not_lt {a b : UInt32} :
¬a < b b a
theorem UInt32.eq_of_toFin_eq {a b : UInt32} (h : a.toFin = b.toFin) :
a = b
theorem UInt32.mod_def (a b : UInt32) :
a % b = { toBitVec := a.toBitVec % b.toBitVec }
theorem UInt32.sub_def (a b : UInt32) :
a - b = { toBitVec := a.toBitVec - b.toBitVec }
@[simp]
theorem UInt32.toNat.inj {a b : UInt32} :
a.toNat = b.toNata = b
@[simp]
theorem UInt32.toNat_sub_of_le (a b : UInt32) :
b a(a - b).toNat = a.toNat - b.toNat
@[deprecated UInt32.toFin_ofNat (since := "2025-02-12")]
@[deprecated UInt32.toFin_val (since := "2025-02-12")]
@[simp]
theorem UInt64.toNat_sub_of_le (a b : UInt64) :
b a(a - b).toNat = a.toNat - b.toNat
@[simp]
theorem UInt64.ofBitVec_toBitVec (a : UInt64) :
{ toBitVec := a.toBitVec } = a
@[simp]
@[simp]
theorem UInt64.eq_of_toFin_eq {a b : UInt64} (h : a.toFin = b.toFin) :
a = b
@[simp]
theorem UInt64.lt_irrefl (a : UInt64) :
¬a < a
@[deprecated UInt64.toFin_inj (since := "2025-02-12")]
theorem UInt64.val_inj {a b : UInt64} :
a.toFin = b.toFin a = b
@[deprecated UInt64.ofBitVec_ofNat (since := "2025-02-12")]
theorem UInt64.mk_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 64 n } = OfNat.ofNat n
@[simp]
@[simp]
theorem UInt64.toNat_mod (a b : UInt64) :
(a % b).toNat = a.toNat % b.toNat
theorem UInt64.sub_def (a b : UInt64) :
a - b = { toBitVec := a.toBitVec - b.toBitVec }
@[simp]
theorem UInt64.not_le {a b : UInt64} :
¬a b b < a
@[deprecated UInt64.toFin_ofNat (since := "2025-02-12")]
theorem UInt64.toBitVec_eq_of_eq {a b : UInt64} (h : a = b) :
theorem UInt64.toNat_mod_lt {m : Nat} (u : UInt64) :
0 < m(u % ofNat m).toNat < m
theorem UInt64.toNat_ofNat {n : Nat} :
(OfNat.ofNat n).toNat = n % 2 ^ 64
theorem UInt64.toFin_inj {a b : UInt64} :
a.toFin = b.toFin a = b
@[simp]
theorem UInt64.toNat_add (a b : UInt64) :
(a + b).toNat = (a.toNat + b.toNat) % 2 ^ 64
theorem UInt64.toNat_ofNat_of_lt' {n : Nat} (h : n < size) :
(ofNat n).toNat = n
theorem UInt64.le_total (a b : UInt64) :
a b b a
theorem UInt64.toNat.inj {a b : UInt64} :
a.toNat = b.toNata = b
@[simp]
theorem UInt64.toNat_ofNatLT {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
theorem UInt64.le_trans {a b c : UInt64} :
a bb ca c
theorem UInt64.mul_def (a b : UInt64) :
a * b = { toBitVec := a.toBitVec * b.toBitVec }
@[deprecated UInt64.ofBitVec_toBitVec_eq (since := "2025-02-12")]
theorem UInt64.mk_toBitVec_eq (a : UInt64) :
{ toBitVec := a.toBitVec } = a
theorem UInt64.ne_of_lt {a b : UInt64} (h : a < b) :
a b
@[simp]
theorem UInt64.toNat_ofNat' {n : Nat} :
(ofNat n).toNat = n % 2 ^ 64
theorem UInt64.zero_def :
0 = { toBitVec := 0 }
@[simp]
theorem UInt64.toNat_ofBitVec {a : BitVec 64} :
{ toBitVec := a }.toNat = a.toNat
@[deprecated UInt64.toNat_mod_lt (since := "2024-09-24")]
theorem UInt64.modn_lt {m : Nat} (u : UInt64) :
m > 0(u % m).toNat < m
theorem UInt64.le_antisymm {a b : UInt64} (h₁ : a b) (h₂ : b a) :
a = b
@[deprecated UInt64.ofBitVec_toBitVec (since := "2025-02-21")]
theorem UInt64.ofBitVec_toBitVec_eq (a : UInt64) :
{ toBitVec := a.toBitVec } = a
@[simp]
theorem UInt64.not_lt {a b : UInt64} :
¬a < b b a
@[simp]
theorem UInt64.le_refl (a : UInt64) :
a a
@[simp]
@[simp]
theorem UInt64.add_def (a b : UInt64) :
a + b = { toBitVec := a.toBitVec + b.toBitVec }
@[simp]
theorem UInt64.lt_trans {a b c : UInt64} :
a < bb < ca < c
@[deprecated UInt64.toNat_ofNatLT (since := "2025-02-13")]
theorem UInt64.toNat_ofNatCore {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
theorem UInt64.le_antisymm_iff {a b : UInt64} :
a = b a b b a
theorem UInt64.lt_asymm {a b : UInt64} :
a < b¬b < a
@[deprecated UInt64.toNat_ofBitVec (since := "2025-02-12")]
theorem UInt64.toNat_mk {a : BitVec 64} :
{ toBitVec := a }.toNat = a.toNat
theorem UInt64.one_def :
1 = { toBitVec := 1 }
@[simp]
theorem UInt64.toNat_sub (a b : UInt64) :
(a - b).toNat = (2 ^ 64 - b.toNat + a.toNat) % 2 ^ 64
theorem UInt64.le_rfl {a : UInt64} :
a a
@[simp]
@[deprecated UInt64.le_iff_toBitVec_le (since := "2025-03-20")]
theorem UInt64.le_def {a b : UInt64} :
theorem UInt64.mod_lt (a : UInt64) {b : UInt64} :
0 < ba % b < b
theorem UInt64.toNat_inj {a b : UInt64} :
a.toNat = b.toNat a = b
@[simp]
theorem UInt64.toNat_div (a b : UInt64) :
(a / b).toNat = a.toNat / b.toNat
@[deprecated "Use `toNat_toBitVec` and `toNat_ofNat_of_lt`." (since := "2025-03-05")]
theorem UInt64.toBitVec_eq_of_lt {a : Nat} :
a < size(ofNat a).toBitVec.toNat = a
@[deprecated UInt64.lt_iff_toBitVec_lt (since := "2025-03-20")]
theorem UInt64.lt_def {a b : UInt64} :
theorem UInt64.mod_def (a b : UInt64) :
a % b = { toBitVec := a.toBitVec % b.toBitVec }
@[simp]
@[simp]
theorem UInt64.toFin_val (x : UInt64) :
x.toFin = x.toNat
@[simp]
theorem UInt64.eq_of_toBitVec_eq {a b : UInt64} (h : a.toBitVec = b.toBitVec) :
a = b
@[simp]
theorem UInt64.ofBitVec_ofNat (n : Nat) :
{ toBitVec := BitVec.ofNat 64 n } = OfNat.ofNat n
@[deprecated UInt64.toFin_val (since := "2025-02-12")]
@[simp]
theorem UInt64.ofNat_one :
ofNat 1 = 1
@[deprecated UInt64.eq_of_toFin_eq (since := "2025-02-12")]
theorem UInt64.eq_of_val_eq {a b : UInt64} (h : a.toFin = b.toFin) :
a = b
@[simp]
theorem UInt64.toNat_mul (a b : UInt64) :
(a * b).toNat = a.toNat * b.toNat % 2 ^ 64
@[deprecated UInt64.toNat_toBitVec (since := "2025-02-21")]
@[simp]
theorem USize.toBitVec_mod {a b : USize} :
@[simp]
theorem USize.le_refl (a : USize) :
a a
theorem USize.toNat_mod_lt {m : Nat} (u : USize) :
0 < m(u % ofNat m).toNat < m
@[deprecated USize.toNat_ofBitVec (since := "2025-02-12")]
theorem USize.toNat_mk {a : BitVec System.Platform.numBits} :
{ toBitVec := a }.toNat = a.toNat
@[simp]
theorem USize.toBitVec_sub {a b : USize} :
theorem USize.le_total (a b : USize) :
a b b a
@[simp]
theorem USize.ofBitVec_toBitVec (a : USize) :
{ toBitVec := a.toBitVec } = a
theorem USize.sub_def (a b : USize) :
a - b = { toBitVec := a.toBitVec - b.toBitVec }
@[deprecated USize.ofBitVec_toBitVec (since := "2025-02-21")]
theorem USize.ofBitVec_toBitVec_eq (a : USize) :
{ toBitVec := a.toBitVec } = a
theorem USize.eq_of_toFin_eq {a b : USize} (h : a.toFin = b.toFin) :
a = b
@[deprecated USize.toFin_val (since := "2025-02-12")]
theorem USize.val_val_eq_toNat (x : USize) :
x.toFin = x.toNat
@[deprecated USize.ofBitVec_ofNat (since := "2025-02-12")]
@[simp]
theorem USize.toBitVec_mul {a b : USize} :
theorem USize.toBitVec_eq_of_eq {a b : USize} (h : a = b) :
@[deprecated USize.toNat_mod_lt (since := "2024-09-24")]
theorem USize.modn_lt {m : Nat} (u : USize) :
m > 0(u % m).toNat < m
@[simp]
@[simp]
theorem USize.toBitVec_div {a b : USize} :
theorem USize.zero_def :
0 = { toBitVec := 0 }
@[deprecated USize.eq_of_toFin_eq (since := "2025-02-12")]
theorem USize.eq_of_val_eq {a b : USize} (h : a.toFin = b.toFin) :
a = b
theorem USize.lt_asymm {a b : USize} :
a < b¬b < a
theorem USize.eq_of_toBitVec_eq {a b : USize} (h : a.toBitVec = b.toBitVec) :
a = b
theorem USize.mod_lt (a : USize) {b : USize} :
0 < ba % b < b
@[simp]
theorem USize.toNat_ofNatLT {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[deprecated "Use `toNat_toBitVec` and `toNat_ofNat_of_lt`." (since := "2025-03-05")]
theorem USize.toBitVec_eq_of_lt {a : Nat} :
a < size(ofNat a).toBitVec.toNat = a
theorem USize.lt_trans {a b c : USize} :
a < bb < ca < c
@[simp]
theorem USize.toNat_mod (a b : USize) :
(a % b).toNat = a.toNat % b.toNat
@[deprecated USize.ofBitVec_toBitVec_eq (since := "2025-02-12")]
theorem USize.mk_toBitVec_eq (a : USize) :
{ toBitVec := a.toBitVec } = a
theorem USize.add_def (a b : USize) :
a + b = { toBitVec := a.toBitVec + b.toBitVec }
@[simp]
theorem USize.not_lt {a b : USize} :
¬a < b b a
theorem USize.le_antisymm_iff {a b : USize} :
a = b a b b a
@[simp]
theorem USize.toFin_val (x : USize) :
x.toFin = x.toNat
@[deprecated USize.toFin_ofNat (since := "2025-02-12")]
@[simp]
@[simp]
theorem USize.toNat_div (a b : USize) :
(a / b).toNat = a.toNat / b.toNat
@[deprecated USize.toNat_ofNatLT (since := "2025-02-13")]
theorem USize.toNat_ofNatCore {n : Nat} {h : n < size} :
(ofNatLT n h).toNat = n
@[simp]
theorem USize.toNat_sub_of_le (a b : USize) :
b a(a - b).toNat = a.toNat - b.toNat
theorem USize.ne_of_lt {a b : USize} (h : a < b) :
a b
@[simp]
@[deprecated USize.le_iff_toBitVec_le (since := "2025-03-20")]
theorem USize.le_def {a b : USize} :
theorem USize.mod_def (a b : USize) :
a % b = { toBitVec := a.toBitVec % b.toBitVec }
@[simp]
theorem USize.not_le {a b : USize} :
¬a b b < a
theorem USize.le_antisymm {a b : USize} (h₁ : a b) (h₂ : b a) :
a = b
theorem USize.one_def :
1 = { toBitVec := 1 }
@[simp]
theorem USize.lt_irrefl (a : USize) :
¬a < a
theorem USize.le_trans {a b c : USize} :
a bb ca c
@[simp]
theorem USize.ofNat_one :
ofNat 1 = 1
theorem USize.mul_def (a b : USize) :
a * b = { toBitVec := a.toBitVec * b.toBitVec }
theorem USize.toNat.inj {a b : USize} :
a.toNat = b.toNata = b
theorem USize.toNat_ofNat_of_lt' {n : Nat} (h : n < size) :
(ofNat n).toNat = n
@[deprecated USize.toFin_inj (since := "2025-02-12")]
theorem USize.val_inj {a b : USize} :
a.toFin = b.toFin a = b
@[deprecated USize.toNat_toBitVec (since := "2025-02-21")]
@[simp]
theorem USize.toNat_zero :
toNat 0 = 0
theorem USize.toFin_inj {a b : USize} :
a.toFin = b.toFin a = b
theorem USize.le_rfl {a : USize} :
a a
@[simp]
theorem USize.toBitVec_add {a b : USize} :
theorem USize.toNat_inj {a b : USize} :
a.toNat = b.toNat a = b
@[simp]
theorem USize.ofNat_toNat {x : USize} :
@[simp]
theorem USize.toNat_ofBitVec {a : BitVec System.Platform.numBits} :
{ toBitVec := a }.toNat = a.toNat
@[deprecated USize.lt_iff_toBitVec_lt (since := "2025-03-20")]
theorem USize.lt_def {a b : USize} :
@[simp]
theorem USize.toNat_ofNat32 {n : Nat} {h : n < 4294967296} :
(ofNat32 n h).toNat = n
@[simp]
theorem USize.toNat_toUInt8 (x : USize) :
@[simp]
theorem USize.toNat_toUInt16 (x : USize) :
x.toUInt16.toNat = x.toNat % 2 ^ 16
@[simp]
theorem USize.toNat_toUInt32 (x : USize) :
x.toUInt32.toNat = x.toNat % 2 ^ 32
theorem USize.toNat_ofNat_of_lt_32 {n : Nat} (h : n < 4294967296) :
(ofNat n).toNat = n
theorem UInt8.lt_ofNat_iff {n : UInt8} {m : Nat} (h : m < size) :
n < ofNat m n.toNat < m
theorem UInt8.ofNat_lt_iff {n : UInt8} {m : Nat} (h : m < size) :
ofNat m < n m < n.toNat
theorem UInt8.le_ofNat_iff {n : UInt8} {m : Nat} (h : m < size) :
theorem UInt8.ofNat_le_iff {n : UInt8} {m : Nat} (h : m < size) :
theorem UInt16.lt_ofNat_iff {n : UInt16} {m : Nat} (h : m < size) :
n < ofNat m n.toNat < m
theorem UInt16.ofNat_lt_iff {n : UInt16} {m : Nat} (h : m < size) :
ofNat m < n m < n.toNat
theorem UInt16.le_ofNat_iff {n : UInt16} {m : Nat} (h : m < size) :
theorem UInt16.ofNat_le_iff {n : UInt16} {m : Nat} (h : m < size) :
theorem UInt32.lt_ofNat_iff {n : UInt32} {m : Nat} (h : m < size) :
n < ofNat m n.toNat < m
theorem UInt32.ofNat_lt_iff {n : UInt32} {m : Nat} (h : m < size) :
ofNat m < n m < n.toNat
theorem UInt32.le_ofNat_iff {n : UInt32} {m : Nat} (h : m < size) :
theorem UInt32.ofNat_le_iff {n : UInt32} {m : Nat} (h : m < size) :
@[deprecated UInt32.lt_ofNat_iff (since := "2025-03-18")]
theorem UInt32.toNat_lt_of_lt {n : UInt32} {m : Nat} (h : m < size) :
n < ofNat mn.toNat < m
@[deprecated UInt32.ofNat_lt_iff (since := "2025-03-18")]
theorem UInt32.lt_toNat_of_lt {n : UInt32} {m : Nat} (h : m < size) :
ofNat m < nm < n.toNat
@[deprecated UInt32.le_ofNat_iff (since := "2025-03-18")]
theorem UInt32.toNat_le_of_le {n : UInt32} {m : Nat} (h : m < size) :
n ofNat mn.toNat m
@[deprecated UInt32.ofNat_le_iff (since := "2025-03-18")]
theorem UInt32.le_toNat_of_le {n : UInt32} {m : Nat} (h : m < size) :
ofNat m nm n.toNat
theorem UInt64.lt_ofNat_iff {n : UInt64} {m : Nat} (h : m < size) :
n < ofNat m n.toNat < m
theorem UInt64.ofNat_lt_iff {n : UInt64} {m : Nat} (h : m < size) :
ofNat m < n m < n.toNat
theorem UInt64.le_ofNat_iff {n : UInt64} {m : Nat} (h : m < size) :
theorem UInt64.ofNat_le_iff {n : UInt64} {m : Nat} (h : m < size) :
theorem USize.lt_ofNat_iff {n : USize} {m : Nat} (h : m < size) :
n < ofNat m n.toNat < m
theorem USize.ofNat_lt_iff {n : USize} {m : Nat} (h : m < size) :
ofNat m < n m < n.toNat
theorem USize.le_ofNat_iff {n : USize} {m : Nat} (h : m < size) :
theorem USize.ofNat_le_iff {n : USize} {m : Nat} (h : m < size) :
theorem UInt8.mod_eq_of_lt {a b : UInt8} (h : a < b) :
a % b = a
theorem UInt16.mod_eq_of_lt {a b : UInt16} (h : a < b) :
a % b = a
theorem UInt32.mod_eq_of_lt {a b : UInt32} (h : a < b) :
a % b = a
theorem UInt64.mod_eq_of_lt {a b : UInt64} (h : a < b) :
a % b = a
theorem USize.mod_eq_of_lt {a b : USize} (h : a < b) :
a % b = a
@[simp]
theorem UInt8.toNat_lt (n : UInt8) :
n.toNat < 2 ^ 8
@[simp]
theorem UInt16.toNat_lt (n : UInt16) :
n.toNat < 2 ^ 16
@[simp]
theorem UInt32.toNat_lt (n : UInt32) :
n.toNat < 2 ^ 32
@[simp]
theorem UInt64.toNat_lt (n : UInt64) :
n.toNat < 2 ^ 64
@[simp]
theorem USize.toNat_lt (n : USize) :
n.toNat < 2 ^ 64
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.toUSize_mod_256 (n : UInt8) :
n.toUSize % 256 = n.toUSize
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Fin.mk_uInt8ToNat (n : UInt8) :
n.toNat, = n.toFin
@[simp]
theorem Fin.mk_uInt16ToNat (n : UInt16) :
n.toNat, = n.toFin
@[simp]
theorem Fin.mk_uInt32ToNat (n : UInt32) :
n.toNat, = n.toFin
@[simp]
theorem Fin.mk_uInt64ToNat (n : UInt64) :
n.toNat, = n.toFin
@[simp]
theorem Fin.mk_uSizeToNat (n : USize) :
n.toNat, = n.toFin
@[simp]
theorem BitVec.ofFin_uInt8ToFin (n : UInt8) :
{ toFin := n.toFin } = n.toBitVec
@[simp]
theorem BitVec.ofFin_uInt16ToFin (n : UInt16) :
{ toFin := n.toFin } = n.toBitVec
@[simp]
theorem BitVec.ofFin_uInt32ToFin (n : UInt32) :
{ toFin := n.toFin } = n.toBitVec
@[simp]
theorem BitVec.ofFin_uInt64ToFin (n : UInt64) :
{ toFin := n.toFin } = n.toBitVec
@[simp]
theorem BitVec.ofFin_uSizeToFin (n : USize) :
{ toFin := n.toFin } = n.toBitVec
@[simp]
theorem UInt8.ofNatLT_toNat (n : UInt8) :
ofNatLT n.toNat = n
@[simp]
theorem UInt16.ofNatLT_toNat (n : UInt16) :
ofNatLT n.toNat = n
@[simp]
theorem UInt32.ofNatLT_toNat (n : UInt32) :
ofNatLT n.toNat = n
@[simp]
theorem UInt64.ofNatLT_toNat (n : UInt64) :
ofNatLT n.toNat = n
@[simp]
theorem USize.ofNatLT_toNat (n : USize) :
ofNatLT n.toNat = n
@[simp]
theorem UInt8.ofFin_toFin (n : UInt8) :
@[simp]
@[simp]
@[simp]
@[simp]
theorem USize.ofFin_toFin (n : USize) :
@[simp]
theorem UInt8.toFin_ofFin (n : Fin size) :
(ofFin n).toFin = n
@[simp]
theorem UInt16.toFin_ofFin (n : Fin size) :
(ofFin n).toFin = n
@[simp]
theorem UInt32.toFin_ofFin (n : Fin size) :
(ofFin n).toFin = n
@[simp]
theorem UInt64.toFin_ofFin (n : Fin size) :
(ofFin n).toFin = n
@[simp]
theorem USize.toFin_ofFin (n : Fin size) :
(ofFin n).toFin = n
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.ofNatLT_eq_ofNat (n : Nat) {h : n < size} :
theorem UInt16.ofNatLT_eq_ofNat (n : Nat) {h : n < size} :
theorem UInt32.ofNatLT_eq_ofNat (n : Nat) {h : n < size} :
theorem UInt64.ofNatLT_eq_ofNat (n : Nat) {h : n < size} :
theorem USize.ofNatLT_eq_ofNat (n : Nat) {h : n < size} :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt64.toUInt64_toUInt32 (n : UInt64) :
n.toUInt32.toUInt64 = n % 4294967296
@[simp]
theorem USize.toUSize_toUInt8 (n : USize) :
n.toUInt8.toUSize = n % 256
@[simp]
theorem USize.toUSize_toUInt16 (n : USize) :
n.toUInt16.toUSize = n % 65536
@[simp]
theorem USize.toUSize_toUInt32 (n : USize) :
n.toUInt32.toUSize = n % 4294967296
@[simp]
theorem UInt8.toNat_ofFin (x : Fin size) :
(ofFin x).toNat = x
@[simp]
theorem UInt16.toNat_ofFin (x : Fin size) :
(ofFin x).toNat = x
@[simp]
theorem UInt32.toNat_ofFin (x : Fin size) :
(ofFin x).toNat = x
@[simp]
theorem UInt64.toNat_ofFin (x : Fin size) :
(ofFin x).toNat = x
@[simp]
theorem USize.toNat_ofFin (x : Fin size) :
(ofFin x).toNat = x
@[simp]
theorem UInt8.toFin_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toFin = n, hn
@[simp]
theorem UInt16.toFin_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toFin = n, hn
@[simp]
theorem UInt32.toFin_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toFin = n, hn
@[simp]
theorem UInt64.toFin_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toFin = n, hn
@[simp]
theorem USize.toFin_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toFin = n, hn
@[simp]
@[simp]
@[simp]
theorem UInt8.toFin_ofBitVec {b : BitVec 8} :
{ toBitVec := b }.toFin = b.toFin
@[simp]
theorem UInt16.toFin_ofBitVec {b : BitVec 16} :
{ toBitVec := b }.toFin = b.toFin
@[simp]
theorem UInt32.toFin_ofBitVec {b : BitVec 32} :
{ toBitVec := b }.toFin = b.toFin
@[simp]
theorem UInt64.toFin_ofBitVec {b : BitVec 64} :
{ toBitVec := b }.toFin = b.toFin
@[simp]
theorem USize.toFin_ofBitVec {b : BitVec System.Platform.numBits} :
{ toBitVec := b }.toFin = b.toFin
theorem UInt8.toFin_ofNatTruncate_of_lt {n : Nat} (hn : n < size) :
(ofNatTruncate n).toFin = n, hn
theorem UInt16.toFin_ofNatTruncate_of_lt {n : Nat} (hn : n < size) :
(ofNatTruncate n).toFin = n, hn
theorem UInt32.toFin_ofNatTruncate_of_lt {n : Nat} (hn : n < size) :
(ofNatTruncate n).toFin = n, hn
theorem UInt64.toFin_ofNatTruncate_of_lt {n : Nat} (hn : n < size) :
(ofNatTruncate n).toFin = n, hn
theorem USize.toFin_ofNatTruncate_of_lt {n : Nat} (hn : n < size) :
(ofNatTruncate n).toFin = n, hn
theorem UInt8.toFin_ofNatTruncate_of_le {n : Nat} (hn : size n) :
(ofNatTruncate n).toFin = size - 1,
theorem UInt16.toFin_ofNatTruncate_of_le {n : Nat} (hn : size n) :
(ofNatTruncate n).toFin = size - 1,
theorem UInt32.toFin_ofNatTruncate_of_le {n : Nat} (hn : size n) :
(ofNatTruncate n).toFin = size - 1,
theorem UInt64.toFin_ofNatTruncate_of_le {n : Nat} (hn : size n) :
(ofNatTruncate n).toFin = size - 1,
theorem USize.toFin_ofNatTruncate_of_le {n : Nat} (hn : size n) :
(ofNatTruncate n).toFin = size - 1,
@[simp]
theorem UInt8.toBitVec_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toBitVec = n#'hn
@[simp]
theorem UInt16.toBitVec_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toBitVec = n#'hn
@[simp]
theorem UInt32.toBitVec_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toBitVec = n#'hn
@[simp]
theorem UInt64.toBitVec_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toBitVec = n#'hn
@[simp]
theorem USize.toBitVec_ofNatLT {n : Nat} (hn : n < size) :
(ofNatLT n hn).toBitVec = n#'hn
@[simp]
theorem UInt8.toBitVec_ofFin (n : Fin size) :
(ofFin n).toBitVec = { toFin := n }
@[simp]
theorem UInt16.toBitVec_ofFin (n : Fin size) :
(ofFin n).toBitVec = { toFin := n }
@[simp]
theorem UInt32.toBitVec_ofFin (n : Fin size) :
(ofFin n).toBitVec = { toFin := n }
@[simp]
theorem UInt64.toBitVec_ofFin (n : Fin size) :
(ofFin n).toBitVec = { toFin := n }
@[simp]
theorem USize.toBitVec_ofFin (n : Fin size) :
(ofFin n).toBitVec = { toFin := n }
@[simp]
theorem UInt8.toBitVec_ofBitVec (n : BitVec 8) :
{ toBitVec := n }.toBitVec = n
@[simp]
theorem UInt16.toBitVec_ofBitVec (n : BitVec 16) :
{ toBitVec := n }.toBitVec = n
@[simp]
theorem UInt32.toBitVec_ofBitVec (n : BitVec 32) :
{ toBitVec := n }.toBitVec = n
@[simp]
theorem UInt64.toBitVec_ofBitVec (n : BitVec 64) :
{ toBitVec := n }.toBitVec = n
@[simp]
@[simp]
theorem UInt16.toUInt8_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem UInt32.toUInt8_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem UInt64.toUInt8_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem USize.toUInt8_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt16.toUInt8_ofBitVec (b : BitVec 16) :
{ toBitVec := b }.toUInt8 = { toBitVec := BitVec.setWidth 8 b }
@[simp]
theorem UInt32.toUInt8_ofBitVec (b : BitVec 32) :
{ toBitVec := b }.toUInt8 = { toBitVec := BitVec.setWidth 8 b }
@[simp]
theorem UInt64.toUInt8_ofBitVec (b : BitVec 64) :
{ toBitVec := b }.toUInt8 = { toBitVec := BitVec.setWidth 8 b }
@[simp]
theorem USize.toUInt8_ofBitVec (b : BitVec System.Platform.numBits) :
{ toBitVec := b }.toUInt8 = { toBitVec := BitVec.setWidth 8 b }
@[simp]
theorem UInt32.toUInt16_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem UInt64.toUInt16_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem USize.toUInt16_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem UInt32.toUInt16_ofBitVec (b : BitVec 32) :
{ toBitVec := b }.toUInt16 = { toBitVec := BitVec.setWidth 16 b }
@[simp]
theorem UInt64.toUInt16_ofBitVec (b : BitVec 64) :
{ toBitVec := b }.toUInt16 = { toBitVec := BitVec.setWidth 16 b }
@[simp]
theorem USize.toUInt16_ofBitVec (b : BitVec System.Platform.numBits) :
{ toBitVec := b }.toUInt16 = { toBitVec := BitVec.setWidth 16 b }
@[simp]
theorem UInt64.toUInt32_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem USize.toUInt32_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
theorem UInt64.toUInt32_ofBitVec (b : BitVec 64) :
{ toBitVec := b }.toUInt32 = { toBitVec := BitVec.setWidth 32 b }
@[simp]
theorem USize.toUInt32_ofBitVec (b : BitVec System.Platform.numBits) :
{ toBitVec := b }.toUInt32 = { toBitVec := BitVec.setWidth 32 b }
@[simp]
theorem UInt64.toUSize_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
@[simp]
theorem UInt64.toUSize_ofBitVec (b : BitVec 64) :
{ toBitVec := b }.toUSize = { toBitVec := BitVec.setWidth System.Platform.numBits b }
theorem UInt8.toUSize_ofNatLT {n : Nat} (h : n < size) :
@[simp]
theorem UInt8.toUInt16_ofBitVec {b : BitVec 8} :
{ toBitVec := b }.toUInt16 = { toBitVec := BitVec.setWidth 16 b }
@[simp]
theorem UInt8.toUInt32_ofBitVec {b : BitVec 8} :
{ toBitVec := b }.toUInt32 = { toBitVec := BitVec.setWidth 32 b }
@[simp]
theorem UInt8.toUInt64_ofBitVec {b : BitVec 8} :
{ toBitVec := b }.toUInt64 = { toBitVec := BitVec.setWidth 64 b }
@[simp]
theorem UInt8.toUSize_ofBitVec {b : BitVec 8} :
{ toBitVec := b }.toUSize = { toBitVec := BitVec.setWidth System.Platform.numBits b }
@[simp]
theorem UInt16.toUInt32_ofBitVec {b : BitVec 16} :
{ toBitVec := b }.toUInt32 = { toBitVec := BitVec.setWidth 32 b }
@[simp]
theorem UInt16.toUInt64_ofBitVec {b : BitVec 16} :
{ toBitVec := b }.toUInt64 = { toBitVec := BitVec.setWidth 64 b }
@[simp]
theorem UInt16.toUSize_ofBitVec {b : BitVec 16} :
{ toBitVec := b }.toUSize = { toBitVec := BitVec.setWidth System.Platform.numBits b }
@[simp]
theorem UInt32.toUInt64_ofBitVec {b : BitVec 32} :
{ toBitVec := b }.toUInt64 = { toBitVec := BitVec.setWidth 64 b }
@[simp]
theorem UInt32.toUSize_ofBitVec {b : BitVec 32} :
{ toBitVec := b }.toUSize = { toBitVec := BitVec.setWidth System.Platform.numBits b }
@[simp]
theorem USize.toUInt64_ofBitVec {b : BitVec System.Platform.numBits} :
{ toBitVec := b }.toUInt64 = { toBitVec := BitVec.setWidth 64 b }
@[simp]
theorem UInt8.toUInt16_ofNat' {n : Nat} (hn : n < size) :
@[simp]
theorem UInt8.toUInt32_ofNat' {n : Nat} (hn : n < size) :
@[simp]
theorem UInt8.toUInt64_ofNat' {n : Nat} (hn : n < size) :
@[simp]
theorem UInt8.toUSize_ofNat' {n : Nat} (hn : n < size) :
@[simp]
@[simp]
@[simp]
theorem UInt16.toUSize_ofNat' {n : Nat} (hn : n < size) :
@[simp]
@[simp]
theorem UInt32.toUSize_ofNat' {n : Nat} (hn : n < size) :
@[simp]
theorem USize.toUInt64_ofNat' {n : Nat} (hn : n < size) :
@[simp]
theorem UInt8.toUInt16_ofNat {n : Nat} (hn : n < 256) :
@[simp]
theorem UInt8.toUInt32_ofNat {n : Nat} (hn : n < 256) :
@[simp]
theorem UInt8.toUInt64_ofNat {n : Nat} (hn : n < 256) :
@[simp]
theorem UInt8.toUSize_ofNat {n : Nat} (hn : n < 256) :
@[simp]
theorem UInt16.toUInt32_ofNat {n : Nat} (hn : n < 65536) :
@[simp]
theorem UInt16.toUInt64_ofNat {n : Nat} (hn : n < 65536) :
@[simp]
theorem UInt16.toUSize_ofNat {n : Nat} (hn : n < 65536) :
@[simp]
theorem UInt32.toUInt64_ofNat {n : Nat} (hn : n < 4294967296) :
@[simp]
theorem UInt32.toUSize_ofNat {n : Nat} (hn : n < 4294967296) :
@[simp]
theorem USize.toUInt64_ofNat {n : Nat} (hn : n < 4294967296) :
@[simp]
theorem UInt8.ofNatLT_finVal (n : Fin size) :
ofNatLT n = ofFin n
@[simp]
theorem UInt16.ofNatLT_finVal (n : Fin size) :
ofNatLT n = ofFin n
@[simp]
theorem UInt32.ofNatLT_finVal (n : Fin size) :
ofNatLT n = ofFin n
@[simp]
theorem UInt64.ofNatLT_finVal (n : Fin size) :
ofNatLT n = ofFin n
@[simp]
theorem USize.ofNatLT_finVal (n : Fin size) :
ofNatLT n = ofFin n
@[simp]
theorem UInt8.ofNatLT_bitVecToNat (n : BitVec 8) :
ofNatLT n.toNat = { toBitVec := n }
@[simp]
theorem UInt16.ofNatLT_bitVecToNat (n : BitVec 16) :
ofNatLT n.toNat = { toBitVec := n }
@[simp]
theorem UInt32.ofNatLT_bitVecToNat (n : BitVec 32) :
ofNatLT n.toNat = { toBitVec := n }
@[simp]
theorem UInt64.ofNatLT_bitVecToNat (n : BitVec 64) :
ofNatLT n.toNat = { toBitVec := n }
@[simp]
@[simp]
theorem UInt8.ofNat_finVal (n : Fin size) :
ofNat n = ofFin n
@[simp]
theorem UInt16.ofNat_finVal (n : Fin size) :
ofNat n = ofFin n
@[simp]
theorem UInt32.ofNat_finVal (n : Fin size) :
ofNat n = ofFin n
@[simp]
theorem UInt64.ofNat_finVal (n : Fin size) :
ofNat n = ofFin n
@[simp]
theorem USize.ofNat_finVal (n : Fin size) :
ofNat n = ofFin n
@[simp]
theorem UInt8.ofNat_bitVecToNat (n : BitVec 8) :
ofNat n.toNat = { toBitVec := n }
@[simp]
theorem UInt16.ofNat_bitVecToNat (n : BitVec 16) :
ofNat n.toNat = { toBitVec := n }
@[simp]
theorem UInt32.ofNat_bitVecToNat (n : BitVec 32) :
ofNat n.toNat = { toBitVec := n }
@[simp]
theorem UInt64.ofNat_bitVecToNat (n : BitVec 64) :
ofNat n.toNat = { toBitVec := n }
@[simp]
@[simp]
theorem UInt8.ofNatTruncate_bitVecToNat (n : BitVec 8) :
ofNatTruncate n.toNat = { toBitVec := n }
@[simp]
theorem UInt16.ofNatTruncate_bitVecToNat (n : BitVec 16) :
ofNatTruncate n.toNat = { toBitVec := n }
@[simp]
theorem UInt32.ofNatTruncate_bitVecToNat (n : BitVec 32) :
ofNatTruncate n.toNat = { toBitVec := n }
@[simp]
theorem UInt64.ofNatTruncate_bitVecToNat (n : BitVec 64) :
ofNatTruncate n.toNat = { toBitVec := n }
@[simp]
theorem UInt8.ofFin_mk {n : Nat} (hn : n < size) :
ofFin n, hn = ofNatLT n hn
@[simp]
theorem UInt16.ofFin_mk {n : Nat} (hn : n < size) :
ofFin n, hn = ofNatLT n hn
@[simp]
theorem UInt32.ofFin_mk {n : Nat} (hn : n < size) :
ofFin n, hn = ofNatLT n hn
@[simp]
theorem UInt64.ofFin_mk {n : Nat} (hn : n < size) :
ofFin n, hn = ofNatLT n hn
@[simp]
theorem USize.ofFin_mk {n : Nat} (hn : n < size) :
ofFin n, hn = ofNatLT n hn
@[simp]
theorem UInt8.ofFin_bitVecToFin (n : BitVec 8) :
ofFin n.toFin = { toBitVec := n }
@[simp]
theorem UInt16.ofFin_bitVecToFin (n : BitVec 16) :
ofFin n.toFin = { toBitVec := n }
@[simp]
theorem UInt32.ofFin_bitVecToFin (n : BitVec 32) :
ofFin n.toFin = { toBitVec := n }
@[simp]
theorem UInt64.ofFin_bitVecToFin (n : BitVec 64) :
ofFin n.toFin = { toBitVec := n }
@[simp]
@[simp]
theorem UInt8.ofBitVec_ofNatLT {n : Nat} (hn : n < 2 ^ 8) :
{ toBitVec := n#'hn } = ofNatLT n hn
@[simp]
theorem UInt16.ofBitVec_ofNatLT {n : Nat} (hn : n < 2 ^ 16) :
{ toBitVec := n#'hn } = ofNatLT n hn
@[simp]
theorem UInt32.ofBitVec_ofNatLT {n : Nat} (hn : n < 2 ^ 32) :
{ toBitVec := n#'hn } = ofNatLT n hn
@[simp]
theorem UInt64.ofBitVec_ofNatLT {n : Nat} (hn : n < 2 ^ 64) :
{ toBitVec := n#'hn } = ofNatLT n hn
@[simp]
theorem USize.ofBitVec_ofNatLT {n : Nat} (hn : n < 2 ^ System.Platform.numBits) :
{ toBitVec := n#'hn } = ofNatLT n hn
@[simp]
theorem UInt8.ofBitVec_ofFin (n : Fin (2 ^ 8)) :
{ toBitVec := { toFin := n } } = ofFin n
@[simp]
theorem UInt16.ofBitVec_ofFin (n : Fin (2 ^ 16)) :
{ toBitVec := { toFin := n } } = ofFin n
@[simp]
theorem UInt32.ofBitVec_ofFin (n : Fin (2 ^ 32)) :
{ toBitVec := { toFin := n } } = ofFin n
@[simp]
theorem UInt64.ofBitVec_ofFin (n : Fin (2 ^ 64)) :
{ toBitVec := { toFin := n } } = ofFin n
@[simp]
theorem USize.ofBitVec_ofFin (n : Fin (2 ^ System.Platform.numBits)) :
{ toBitVec := { toFin := n } } = ofFin n
@[simp]
theorem UInt8.toFin_div (a b : UInt8) :
(a / b).toFin = a.toFin / b.toFin
@[simp]
theorem UInt16.toFin_div (a b : UInt16) :
(a / b).toFin = a.toFin / b.toFin
@[simp]
theorem UInt32.toFin_div (a b : UInt32) :
(a / b).toFin = a.toFin / b.toFin
@[simp]
theorem UInt64.toFin_div (a b : UInt64) :
(a / b).toFin = a.toFin / b.toFin
@[simp]
theorem USize.toFin_div (a b : USize) :
(a / b).toFin = a.toFin / b.toFin
@[simp]
theorem UInt8.toUInt16_div (a b : UInt8) :
@[simp]
theorem UInt8.toUInt32_div (a b : UInt8) :
@[simp]
theorem UInt8.toUInt64_div (a b : UInt8) :
@[simp]
theorem UInt8.toUSize_div (a b : UInt8) :
@[simp]
@[simp]
@[simp]
theorem UInt16.toUSize_div (a b : UInt16) :
@[simp]
@[simp]
theorem UInt32.toUSize_div (a b : UInt32) :
@[simp]
theorem USize.toUInt64_div (a b : USize) :
theorem UInt16.toUInt8_div (a b : UInt16) (ha : a < 256) (hb : b < 256) :
theorem UInt32.toUInt8_div (a b : UInt32) (ha : a < 256) (hb : b < 256) :
theorem UInt32.toUInt16_div (a b : UInt32) (ha : a < 65536) (hb : b < 65536) :
theorem USize.toUInt8_div (a b : USize) (ha : a < 256) (hb : b < 256) :
theorem USize.toUInt16_div (a b : USize) (ha : a < 65536) (hb : b < 65536) :
theorem UInt64.toUInt8_div (a b : UInt64) (ha : a < 256) (hb : b < 256) :
theorem UInt64.toUInt16_div (a b : UInt64) (ha : a < 65536) (hb : b < 65536) :
theorem UInt64.toUInt32_div (a b : UInt64) (ha : a < 4294967296) (hb : b < 4294967296) :
theorem UInt64.toUSize_div (a b : UInt64) (ha : a < 4294967296) (hb : b < 4294967296) :
@[simp]
theorem UInt8.toFin_mod (a b : UInt8) :
(a % b).toFin = a.toFin % b.toFin
@[simp]
theorem UInt16.toFin_mod (a b : UInt8) :
(a % b).toFin = a.toFin % b.toFin
@[simp]
theorem UInt32.toFin_mod (a b : UInt32) :
(a % b).toFin = a.toFin % b.toFin
@[simp]
theorem UInt64.toFin_mod (a b : UInt64) :
(a % b).toFin = a.toFin % b.toFin
@[simp]
theorem USize.toFin_mod (a b : USize) :
(a % b).toFin = a.toFin % b.toFin
@[simp]
theorem UInt8.toUInt16_mod (a b : UInt8) :
@[simp]
theorem UInt8.toUInt32_mod (a b : UInt8) :
@[simp]
theorem UInt8.toUInt64_mod (a b : UInt8) :
@[simp]
theorem UInt8.toUSize_mod (a b : UInt8) :
@[simp]
@[simp]
@[simp]
theorem UInt16.toUSize_mod (a b : UInt16) :
@[simp]
@[simp]
theorem UInt32.toUSize_mod (a b : UInt32) :
@[simp]
theorem USize.toUInt64_mod (a b : USize) :
theorem UInt16.toUInt8_mod (a b : UInt16) (ha : a < 256) (hb : b < 256) :
theorem UInt16.toUInt8_mod_of_dvd (a b : UInt16) (hb : b.toNat 256) :
theorem UInt32.toUInt8_mod (a b : UInt32) (ha : a < 256) (hb : b < 256) :
theorem UInt32.toUInt16_mod (a b : UInt32) (ha : a < 65536) (hb : b < 65536) :
theorem UInt32.toUInt8_mod_of_dvd (a b : UInt32) (hb : b.toNat 256) :
theorem UInt32.toUInt16_mod_of_dvd (a b : UInt32) (hb : b.toNat 65536) :
theorem USize.toUInt8_mod (a b : USize) (ha : a < 256) (hb : b < 256) :
theorem USize.toUInt16_mod (a b : USize) (ha : a < 65536) (hb : b < 65536) :
theorem USize.toUInt32_mod (a b : USize) (ha : a < 4294967296) (hb : b < 4294967296) :
theorem USize.toUInt8_mod_of_dvd (a b : USize) (hb : b.toNat 256) :
theorem USize.toUInt16_mod_of_dvd (a b : USize) (hb : b.toNat 65536) :
theorem USize.toUInt32_mod_of_dvd (a b : USize) (hb : b.toNat 4294967296) :
theorem UInt64.toUInt8_mod (a b : UInt64) (ha : a < 256) (hb : b < 256) :
theorem UInt64.toUInt16_mod (a b : UInt64) (ha : a < 65536) (hb : b < 65536) :
theorem UInt64.toUInt32_mod (a b : UInt64) (ha : a < 4294967296) (hb : b < 4294967296) :
theorem UInt64.toUSize_mod (a b : UInt64) (ha : a < 4294967296) (hb : b < 4294967296) :
theorem UInt64.toUInt8_mod_of_dvd (a b : UInt64) (hb : b.toNat 256) :
theorem UInt64.toUInt16_mod_of_dvd (a b : UInt64) (hb : b.toNat 65536) :
theorem UInt64.toUInt32_mod_of_dvd (a b : UInt64) (hb : b.toNat 4294967296) :
theorem UInt64.toUSize_mod_of_dvd (a b : UInt64) (hb : b.toNat 4294967296) :
@[simp]
theorem UInt8.toFin_add (a b : UInt8) :
(a + b).toFin = a.toFin + b.toFin
@[simp]
theorem UInt16.toFin_add (a b : UInt16) :
(a + b).toFin = a.toFin + b.toFin
@[simp]
theorem UInt32.toFin_add (a b : UInt32) :
(a + b).toFin = a.toFin + b.toFin
@[simp]
theorem UInt64.toFin_add (a b : UInt64) :
(a + b).toFin = a.toFin + b.toFin
@[simp]
theorem USize.toFin_add (a b : USize) :
(a + b).toFin = a.toFin + b.toFin
@[simp]
theorem UInt16.toUInt8_add (a b : UInt16) :
@[simp]
theorem UInt32.toUInt8_add (a b : UInt32) :
@[simp]
theorem UInt64.toUInt8_add (a b : UInt64) :
@[simp]
theorem USize.toUInt8_add (a b : USize) :
@[simp]
@[simp]
@[simp]
theorem USize.toUInt16_add (a b : USize) :
@[simp]
@[simp]
theorem USize.toUInt32_add (a b : USize) :
@[simp]
theorem UInt64.toUSize_add (a b : UInt64) :
@[simp]
theorem UInt8.toUInt16_add (a b : UInt8) :
(a + b).toUInt16 = (a.toUInt16 + b.toUInt16) % 256
@[simp]
theorem UInt8.toUInt32_add (a b : UInt8) :
(a + b).toUInt32 = (a.toUInt32 + b.toUInt32) % 256
@[simp]
theorem UInt8.toUInt64_add (a b : UInt8) :
(a + b).toUInt64 = (a.toUInt64 + b.toUInt64) % 256
@[simp]
theorem UInt8.toUSize_add (a b : UInt8) :
(a + b).toUSize = (a.toUSize + b.toUSize) % 256
@[simp]
theorem UInt16.toUInt32_add (a b : UInt16) :
(a + b).toUInt32 = (a.toUInt32 + b.toUInt32) % 65536
@[simp]
theorem UInt16.toUInt64_add (a b : UInt16) :
(a + b).toUInt64 = (a.toUInt64 + b.toUInt64) % 65536
@[simp]
theorem UInt16.toUSize_add (a b : UInt16) :
(a + b).toUSize = (a.toUSize + b.toUSize) % 65536
@[simp]
theorem UInt32.toUInt64_add (a b : UInt32) :
(a + b).toUInt64 = (a.toUInt64 + b.toUInt64) % 4294967296
@[simp]
theorem UInt32.toUSize_add (a b : UInt32) :
(a + b).toUSize = (a.toUSize + b.toUSize) % 4294967296

Note that on 32-bit machines we are doing a modulo by zero.

@[simp]
theorem UInt8.toFin_sub (a b : UInt8) :
(a - b).toFin = a.toFin - b.toFin
@[simp]
theorem UInt16.toFin_sub (a b : UInt16) :
(a - b).toFin = a.toFin - b.toFin
@[simp]
theorem UInt32.toFin_sub (a b : UInt32) :
(a - b).toFin = a.toFin - b.toFin
@[simp]
theorem UInt64.toFin_sub (a b : UInt64) :
(a - b).toFin = a.toFin - b.toFin
@[simp]
theorem USize.toFin_sub (a b : USize) :
(a - b).toFin = a.toFin - b.toFin
@[simp]
theorem UInt8.toFin_mul (a b : UInt8) :
(a * b).toFin = a.toFin * b.toFin
@[simp]
theorem UInt16.toFin_mul (a b : UInt16) :
(a * b).toFin = a.toFin * b.toFin
@[simp]
theorem UInt32.toFin_mul (a b : UInt32) :
(a * b).toFin = a.toFin * b.toFin
@[simp]
theorem UInt64.toFin_mul (a b : UInt64) :
(a * b).toFin = a.toFin * b.toFin
@[simp]
theorem USize.toFin_mul (a b : USize) :
(a * b).toFin = a.toFin * b.toFin
@[simp]
theorem UInt16.toUInt8_mul (a b : UInt16) :
@[simp]
theorem UInt32.toUInt8_mul (a b : UInt32) :
@[simp]
theorem UInt64.toUInt8_mul (a b : UInt64) :
@[simp]
theorem USize.toUInt8_mul (a b : USize) :
@[simp]
@[simp]
@[simp]
theorem USize.toUInt16_mul (a b : USize) :
@[simp]
@[simp]
theorem USize.toUInt32_mul (a b : USize) :
@[simp]
theorem UInt64.toUSize_mul (a b : UInt64) :
@[simp]
theorem UInt8.toUInt16_mul (a b : UInt8) :
(a * b).toUInt16 = a.toUInt16 * b.toUInt16 % 256
@[simp]
theorem UInt8.toUInt32_mul (a b : UInt8) :
(a * b).toUInt32 = a.toUInt32 * b.toUInt32 % 256
@[simp]
theorem UInt8.toUInt64_mul (a b : UInt8) :
(a * b).toUInt64 = a.toUInt64 * b.toUInt64 % 256
@[simp]
theorem UInt8.toUSize_mul (a b : UInt8) :
(a * b).toUSize = a.toUSize * b.toUSize % 256
@[simp]
theorem UInt16.toUInt32_mul (a b : UInt16) :
(a * b).toUInt32 = a.toUInt32 * b.toUInt32 % 65536
@[simp]
theorem UInt16.toUInt64_mul (a b : UInt16) :
(a * b).toUInt64 = a.toUInt64 * b.toUInt64 % 65536
@[simp]
theorem UInt16.toUSize_mul (a b : UInt16) :
(a * b).toUSize = a.toUSize * b.toUSize % 65536
@[simp]
theorem UInt32.toUInt64_mul (a b : UInt32) :
(a * b).toUInt64 = a.toUInt64 * b.toUInt64 % 4294967296
@[simp]
theorem UInt32.toUSize_mul (a b : UInt32) :
(a * b).toUSize = a.toUSize * b.toUSize % 4294967296

Note that on 32-bit machines we are doing a modulo by zero.

theorem UInt16.toUInt8_eq (a b : UInt16) :
a.toUInt8 = b.toUInt8 a % 256 = b % 256
theorem UInt32.toUInt8_eq (a b : UInt32) :
a.toUInt8 = b.toUInt8 a % 256 = b % 256
theorem UInt64.toUInt8_eq (a b : UInt64) :
a.toUInt8 = b.toUInt8 a % 256 = b % 256
theorem USize.toUInt8_eq (a b : USize) :
a.toUInt8 = b.toUInt8 a % 256 = b % 256
theorem UInt32.toUInt16_eq (a b : UInt32) :
a.toUInt16 = b.toUInt16 a % 65536 = b % 65536
theorem UInt64.toUInt16_eq (a b : UInt64) :
a.toUInt16 = b.toUInt16 a % 65536 = b % 65536
theorem USize.toUInt16_eq (a b : USize) :
a.toUInt16 = b.toUInt16 a % 65536 = b % 65536
theorem UInt64.toUInt32_eq (a b : UInt64) :
a.toUInt32 = b.toUInt32 a % 4294967296 = b % 4294967296
theorem USize.toUInt32_eq (a b : USize) :
a.toUInt32 = b.toUInt32 a % 4294967296 = b % 4294967296
@[simp]
theorem UInt8.toUInt16_lt {a b : UInt8} :
@[simp]
theorem UInt8.toUInt32_lt {a b : UInt8} :
@[simp]
theorem UInt8.toUInt64_lt {a b : UInt8} :
@[simp]
theorem UInt8.toUSize_lt {a b : UInt8} :
@[simp]
theorem UInt16.toUInt32_lt {a b : UInt16} :
@[simp]
theorem UInt16.toUInt64_lt {a b : UInt16} :
@[simp]
theorem UInt16.toUSize_lt {a b : UInt16} :
@[simp]
theorem UInt32.toUInt64_lt {a b : UInt32} :
@[simp]
theorem UInt32.toUSize_lt {a b : UInt32} :
@[simp]
theorem USize.toUInt64_lt {a b : USize} :
@[simp]
theorem UInt16.toUInt8_lt {a b : UInt16} :
a.toUInt8 < b.toUInt8 a % 256 < b % 256
@[simp]
theorem UInt32.toUInt8_lt {a b : UInt32} :
a.toUInt8 < b.toUInt8 a % 256 < b % 256
@[simp]
theorem UInt64.toUInt8_lt {a b : UInt64} :
a.toUInt8 < b.toUInt8 a % 256 < b % 256
@[simp]
theorem USize.toUInt8_lt {a b : USize} :
a.toUInt8 < b.toUInt8 a % 256 < b % 256
@[simp]
theorem UInt32.toUInt16_lt {a b : UInt32} :
a.toUInt16 < b.toUInt16 a % 65536 < b % 65536
@[simp]
theorem UInt64.toUInt16_lt {a b : UInt64} :
a.toUInt16 < b.toUInt16 a % 65536 < b % 65536
@[simp]
theorem USize.toUInt16_lt {a b : USize} :
a.toUInt16 < b.toUInt16 a % 65536 < b % 65536
@[simp]
theorem UInt64.toUInt32_lt {a b : UInt64} :
a.toUInt32 < b.toUInt32 a % 4294967296 < b % 4294967296
@[simp]
theorem USize.toUInt32_lt {a b : USize} :
a.toUInt32 < b.toUInt32 a % 4294967296 < b % 4294967296
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.toUSize_le {a b : UInt8} :
@[simp]
@[simp]
@[simp]
theorem UInt16.toUSize_le {a b : UInt16} :
@[simp]
@[simp]
theorem UInt32.toUSize_le {a b : UInt32} :
@[simp]
@[simp]
theorem UInt16.toUInt8_le {a b : UInt16} :
a.toUInt8 b.toUInt8 a % 256 b % 256
@[simp]
theorem UInt32.toUInt8_le {a b : UInt32} :
a.toUInt8 b.toUInt8 a % 256 b % 256
@[simp]
theorem UInt64.toUInt8_le {a b : UInt64} :
a.toUInt8 b.toUInt8 a % 256 b % 256
@[simp]
theorem USize.toUInt8_le {a b : USize} :
a.toUInt8 b.toUInt8 a % 256 b % 256
@[simp]
theorem UInt32.toUInt16_le {a b : UInt32} :
a.toUInt16 b.toUInt16 a % 65536 b % 65536
@[simp]
theorem UInt64.toUInt16_le {a b : UInt64} :
a.toUInt16 b.toUInt16 a % 65536 b % 65536
@[simp]
theorem USize.toUInt16_le {a b : USize} :
a.toUInt16 b.toUInt16 a % 65536 b % 65536
@[simp]
theorem UInt64.toUInt32_le {a b : UInt64} :
a.toUInt32 b.toUInt32 a % 4294967296 b % 4294967296
@[simp]
theorem USize.toUInt32_le {a b : USize} :
a.toUInt32 b.toUInt32 a % 4294967296 b % 4294967296
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.toUInt16_neg (a : UInt8) :
@[simp]
theorem UInt8.toUInt32_neg (a : UInt8) :
@[simp]
theorem UInt8.toUInt64_neg (a : UInt8) :
@[simp]
theorem UInt8.toUSize_neg (a : UInt8) :
(-a).toUSize = -a.toUSize % 256
@[simp]
theorem UInt16.toUInt32_neg (a : UInt16) :
(-a).toUInt32 = -a.toUInt32 % 65536
@[simp]
theorem UInt16.toUInt64_neg (a : UInt16) :
(-a).toUInt64 = -a.toUInt64 % 65536
@[simp]
theorem UInt16.toUSize_neg (a : UInt16) :
(-a).toUSize = -a.toUSize % 65536
@[simp]
theorem UInt32.toUInt64_neg (a : UInt32) :
(-a).toUInt64 = -a.toUInt64 % 4294967296
@[simp]
theorem UInt32.toUSize_neg (a : UInt32) :
(-a).toUSize = -a.toUSize % 4294967296
@[simp]
theorem UInt8.toNat_neg (a : UInt8) :
@[simp]
theorem UInt16.toNat_neg (a : UInt16) :
@[simp]
theorem UInt32.toNat_neg (a : UInt32) :
@[simp]
theorem UInt64.toNat_neg (a : UInt64) :
@[simp]
theorem USize.toNat_neg (a : USize) :
theorem UInt8.sub_eq_add_neg (a b : UInt8) :
a - b = a + -b
theorem UInt16.sub_eq_add_neg (a b : UInt16) :
a - b = a + -b
theorem UInt32.sub_eq_add_neg (a b : UInt32) :
a - b = a + -b
theorem UInt64.sub_eq_add_neg (a b : UInt64) :
a - b = a + -b
theorem USize.sub_eq_add_neg (a b : USize) :
a - b = a + -b
theorem UInt8.add_neg_eq_sub {a b : UInt8} :
a + -b = a - b
theorem UInt16.add_neg_eq_sub {a b : UInt16} :
a + -b = a - b
theorem UInt32.add_neg_eq_sub {a b : UInt32} :
a + -b = a - b
theorem UInt64.add_neg_eq_sub {a b : UInt64} :
a + -b = a - b
theorem USize.add_neg_eq_sub {a b : USize} :
a + -b = a - b
theorem UInt8.neg_one_eq :
-1 = 255
theorem UInt16.neg_one_eq :
-1 = 65535
theorem UInt32.neg_one_eq :
-1 = 4294967295
theorem UInt64.neg_one_eq :
-1 = 18446744073709551615
theorem USize.neg_one_eq :
-1 = ofNatLT (size - 1)
theorem UInt8.sub_eq_add_mul (a b : UInt8) :
a - b = a + 255 * b
theorem UInt16.sub_eq_add_mul (a b : UInt16) :
a - b = a + 65535 * b
theorem UInt32.sub_eq_add_mul (a b : UInt32) :
a - b = a + 4294967295 * b
theorem UInt64.sub_eq_add_mul (a b : UInt64) :
a - b = a + 18446744073709551615 * b
theorem USize.sub_eq_add_mul (a b : USize) :
a - b = a + ofNatLT (size - 1) * b
@[simp]
@[simp]
theorem UInt16.toUInt8_sub (a b : UInt16) :
@[simp]
theorem UInt32.toUInt8_sub (a b : UInt32) :
@[simp]
@[simp]
theorem UInt64.toUInt8_sub (a b : UInt64) :
@[simp]
@[simp]
@[simp]
theorem UInt64.toUSize_sub (a b : UInt64) :
@[simp]
theorem USize.toUInt8_sub (a b : USize) :
@[simp]
theorem USize.toUInt16_sub (a b : USize) :
@[simp]
theorem USize.toUInt32_sub (a b : USize) :
@[simp]
theorem UInt8.toUInt16_sub (a b : UInt8) :
(a - b).toUInt16 = (a.toUInt16 - b.toUInt16) % 256
@[simp]
theorem UInt8.toUInt32_sub (a b : UInt8) :
(a - b).toUInt32 = (a.toUInt32 - b.toUInt32) % 256
@[simp]
theorem UInt8.toUInt64_sub (a b : UInt8) :
(a - b).toUInt64 = (a.toUInt64 - b.toUInt64) % 256
@[simp]
theorem UInt8.toUSize_sub (a b : UInt8) :
(a - b).toUSize = (a.toUSize - b.toUSize) % 256
@[simp]
theorem UInt16.toUInt32_sub (a b : UInt16) :
(a - b).toUInt32 = (a.toUInt32 - b.toUInt32) % 65536
@[simp]
theorem UInt16.toUInt64_sub (a b : UInt16) :
(a - b).toUInt64 = (a.toUInt64 - b.toUInt64) % 65536
@[simp]
theorem UInt16.toUSize_sub (a b : UInt16) :
(a - b).toUSize = (a.toUSize - b.toUSize) % 65536
@[simp]
theorem UInt32.toUInt64_sub (a b : UInt32) :
(a - b).toUInt64 = (a.toUInt64 - b.toUInt64) % 4294967296
@[simp]
theorem UInt32.toUSize_sub (a b : UInt32) :
(a - b).toUSize = (a.toUSize - b.toUSize) % 4294967296
@[simp]
theorem UInt8.ofBitVec_neg (b : BitVec 8) :
{ toBitVec := -b } = -{ toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_neg (b : BitVec 16) :
{ toBitVec := -b } = -{ toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_neg (b : BitVec 32) :
{ toBitVec := -b } = -{ toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_neg (b : BitVec 64) :
{ toBitVec := -b } = -{ toBitVec := b }
@[simp]
theorem USize.ofBitVec_neg (b : BitVec System.Platform.numBits) :
{ toBitVec := -b } = -{ toBitVec := b }
@[simp]
theorem UInt8.ofFin_div (a b : Fin size) :
ofFin (a / b) = ofFin a / ofFin b
@[simp]
theorem UInt16.ofFin_div (a b : Fin size) :
ofFin (a / b) = ofFin a / ofFin b
@[simp]
theorem UInt32.ofFin_div (a b : Fin size) :
ofFin (a / b) = ofFin a / ofFin b
@[simp]
theorem UInt64.ofFin_div (a b : Fin size) :
ofFin (a / b) = ofFin a / ofFin b
@[simp]
theorem USize.ofFin_div (a b : Fin size) :
ofFin (a / b) = ofFin a / ofFin b
@[simp]
theorem UInt8.ofBitVec_div (a b : BitVec 8) :
{ toBitVec := a / b } = { toBitVec := a } / { toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_div (a b : BitVec 16) :
{ toBitVec := a / b } = { toBitVec := a } / { toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_div (a b : BitVec 32) :
{ toBitVec := a / b } = { toBitVec := a } / { toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_div (a b : BitVec 64) :
{ toBitVec := a / b } = { toBitVec := a } / { toBitVec := b }
@[simp]
theorem USize.ofBitVec_div (a b : BitVec System.Platform.numBits) :
{ toBitVec := a / b } = { toBitVec := a } / { toBitVec := b }
@[simp]
theorem UInt8.ofFin_mod (a b : Fin size) :
ofFin (a % b) = ofFin a % ofFin b
@[simp]
theorem UInt16.ofFin_mod (a b : Fin size) :
ofFin (a % b) = ofFin a % ofFin b
@[simp]
theorem UInt32.ofFin_mod (a b : Fin size) :
ofFin (a % b) = ofFin a % ofFin b
@[simp]
theorem UInt64.ofFin_mod (a b : Fin size) :
ofFin (a % b) = ofFin a % ofFin b
@[simp]
theorem USize.ofFin_mod (a b : Fin size) :
ofFin (a % b) = ofFin a % ofFin b
@[simp]
theorem UInt8.ofBitVec_mod (a b : BitVec 8) :
{ toBitVec := a % b } = { toBitVec := a } % { toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_mod (a b : BitVec 16) :
{ toBitVec := a % b } = { toBitVec := a } % { toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_mod (a b : BitVec 32) :
{ toBitVec := a % b } = { toBitVec := a } % { toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_mod (a b : BitVec 64) :
{ toBitVec := a % b } = { toBitVec := a } % { toBitVec := b }
@[simp]
theorem USize.ofBitVec_mod (a b : BitVec System.Platform.numBits) :
{ toBitVec := a % b } = { toBitVec := a } % { toBitVec := b }
theorem UInt8.ofNat_eq_iff_mod_eq_toNat (a : Nat) (b : UInt8) :
ofNat a = b a % 2 ^ 8 = b.toNat
theorem UInt16.ofNat_eq_iff_mod_eq_toNat (a : Nat) (b : UInt16) :
ofNat a = b a % 2 ^ 16 = b.toNat
theorem UInt32.ofNat_eq_iff_mod_eq_toNat (a : Nat) (b : UInt32) :
ofNat a = b a % 2 ^ 32 = b.toNat
theorem UInt64.ofNat_eq_iff_mod_eq_toNat (a : Nat) (b : UInt64) :
ofNat a = b a % 2 ^ 64 = b.toNat
@[simp]
theorem UInt8.ofNat_div {a b : Nat} (ha : a < 2 ^ 8) (hb : b < 2 ^ 8) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem UInt16.ofNat_div {a b : Nat} (ha : a < 2 ^ 16) (hb : b < 2 ^ 16) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem UInt32.ofNat_div {a b : Nat} (ha : a < 2 ^ 32) (hb : b < 2 ^ 32) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem UInt64.ofNat_div {a b : Nat} (ha : a < 2 ^ 64) (hb : b < 2 ^ 64) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem USize.ofNat_div {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hb : b < 2 ^ System.Platform.numBits) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem UInt8.ofNatLT_div {a b : Nat} (ha : a < 2 ^ 8) (hb : b < 2 ^ 8) :
ofNatLT (a / b) = ofNatLT a ha / ofNatLT b hb
@[simp]
theorem UInt16.ofNatLT_div {a b : Nat} (ha : a < 2 ^ 16) (hb : b < 2 ^ 16) :
ofNatLT (a / b) = ofNatLT a ha / ofNatLT b hb
@[simp]
theorem UInt32.ofNatLT_div {a b : Nat} (ha : a < 2 ^ 32) (hb : b < 2 ^ 32) :
ofNatLT (a / b) = ofNatLT a ha / ofNatLT b hb
@[simp]
theorem UInt64.ofNatLT_div {a b : Nat} (ha : a < 2 ^ 64) (hb : b < 2 ^ 64) :
ofNatLT (a / b) = ofNatLT a ha / ofNatLT b hb
@[simp]
theorem USize.ofNatLT_div {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hb : b < 2 ^ System.Platform.numBits) :
ofNatLT (a / b) = ofNatLT a ha / ofNatLT b hb
@[simp]
theorem UInt8.ofNat_mod {a b : Nat} (ha : a < 2 ^ 8) (hb : b < 2 ^ 8) :
ofNat (a % b) = ofNat a % ofNat b
@[simp]
theorem UInt16.ofNat_mod {a b : Nat} (ha : a < 2 ^ 16) (hb : b < 2 ^ 16) :
ofNat (a % b) = ofNat a % ofNat b
@[simp]
theorem UInt32.ofNat_mod {a b : Nat} (ha : a < 2 ^ 32) (hb : b < 2 ^ 32) :
ofNat (a % b) = ofNat a % ofNat b
@[simp]
theorem UInt64.ofNat_mod {a b : Nat} (ha : a < 2 ^ 64) (hb : b < 2 ^ 64) :
ofNat (a % b) = ofNat a % ofNat b
@[simp]
theorem USize.ofNat_mod {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hb : b < 2 ^ System.Platform.numBits) :
ofNat (a % b) = ofNat a % ofNat b
@[simp]
theorem UInt8.ofNatLT_mod {a b : Nat} (ha : a < 2 ^ 8) (hb : b < 2 ^ 8) :
ofNatLT (a % b) = ofNatLT a ha % ofNatLT b hb
@[simp]
theorem UInt16.ofNatLT_mod {a b : Nat} (ha : a < 2 ^ 16) (hb : b < 2 ^ 16) :
ofNatLT (a % b) = ofNatLT a ha % ofNatLT b hb
@[simp]
theorem UInt32.ofNatLT_mod {a b : Nat} (ha : a < 2 ^ 32) (hb : b < 2 ^ 32) :
ofNatLT (a % b) = ofNatLT a ha % ofNatLT b hb
@[simp]
theorem UInt64.ofNatLT_mod {a b : Nat} (ha : a < 2 ^ 64) (hb : b < 2 ^ 64) :
ofNatLT (a % b) = ofNatLT a ha % ofNatLT b hb
@[simp]
theorem USize.ofNatLT_mod {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hb : b < 2 ^ System.Platform.numBits) :
ofNatLT (a % b) = ofNatLT a ha % ofNatLT b hb
@[simp]
theorem UInt8.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem UInt16.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem UInt32.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem UInt64.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem USize.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem UInt8.ofNatLT_add {a b : Nat} (hab : a + b < 2 ^ 8) :
ofNatLT (a + b) hab = ofNatLT a + ofNatLT b
@[simp]
theorem UInt16.ofNatLT_add {a b : Nat} (hab : a + b < 2 ^ 16) :
ofNatLT (a + b) hab = ofNatLT a + ofNatLT b
@[simp]
theorem UInt32.ofNatLT_add {a b : Nat} (hab : a + b < 2 ^ 32) :
ofNatLT (a + b) hab = ofNatLT a + ofNatLT b
@[simp]
theorem UInt64.ofNatLT_add {a b : Nat} (hab : a + b < 2 ^ 64) :
ofNatLT (a + b) hab = ofNatLT a + ofNatLT b
@[simp]
theorem USize.ofNatLT_add {a b : Nat} (hab : a + b < 2 ^ System.Platform.numBits) :
ofNatLT (a + b) hab = ofNatLT a + ofNatLT b
@[simp]
theorem UInt8.ofFin_add (a b : Fin size) :
ofFin (a + b) = ofFin a + ofFin b
@[simp]
theorem UInt16.ofFin_add (a b : Fin size) :
ofFin (a + b) = ofFin a + ofFin b
@[simp]
theorem UInt32.ofFin_add (a b : Fin size) :
ofFin (a + b) = ofFin a + ofFin b
@[simp]
theorem UInt64.ofFin_add (a b : Fin size) :
ofFin (a + b) = ofFin a + ofFin b
@[simp]
theorem USize.ofFin_add (a b : Fin size) :
ofFin (a + b) = ofFin a + ofFin b
@[simp]
theorem UInt8.ofBitVec_add (a b : BitVec 8) :
{ toBitVec := a + b } = { toBitVec := a } + { toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_add (a b : BitVec 16) :
{ toBitVec := a + b } = { toBitVec := a } + { toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_add (a b : BitVec 32) :
{ toBitVec := a + b } = { toBitVec := a } + { toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_add (a b : BitVec 64) :
{ toBitVec := a + b } = { toBitVec := a } + { toBitVec := b }
@[simp]
theorem USize.ofBitVec_add (a b : BitVec System.Platform.numBits) :
{ toBitVec := a + b } = { toBitVec := a } + { toBitVec := b }
@[simp]
theorem UInt8.ofFin_sub (a b : Fin size) :
ofFin (a - b) = ofFin a - ofFin b
@[simp]
theorem UInt16.ofFin_sub (a b : Fin size) :
ofFin (a - b) = ofFin a - ofFin b
@[simp]
theorem UInt32.ofFin_sub (a b : Fin size) :
ofFin (a - b) = ofFin a - ofFin b
@[simp]
theorem UInt64.ofFin_sub (a b : Fin size) :
ofFin (a - b) = ofFin a - ofFin b
@[simp]
theorem USize.ofFin_sub (a b : Fin size) :
ofFin (a - b) = ofFin a - ofFin b
@[simp]
theorem UInt8.ofBitVec_sub (a b : BitVec 8) :
{ toBitVec := a - b } = { toBitVec := a } - { toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_sub (a b : BitVec 16) :
{ toBitVec := a - b } = { toBitVec := a } - { toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_sub (a b : BitVec 32) :
{ toBitVec := a - b } = { toBitVec := a } - { toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_sub (a b : BitVec 64) :
{ toBitVec := a - b } = { toBitVec := a } - { toBitVec := b }
@[simp]
theorem USize.ofBitVec_sub (a b : BitVec System.Platform.numBits) :
{ toBitVec := a - b } = { toBitVec := a } - { toBitVec := b }
@[simp]
theorem UInt8.add_sub_cancel (a b : UInt8) :
a + b - b = a
@[simp]
theorem UInt16.add_sub_cancel (a b : UInt16) :
a + b - b = a
@[simp]
theorem UInt32.add_sub_cancel (a b : UInt32) :
a + b - b = a
@[simp]
theorem UInt64.add_sub_cancel (a b : UInt64) :
a + b - b = a
@[simp]
theorem USize.add_sub_cancel (a b : USize) :
a + b - b = a
theorem UInt8.ofNat_sub {a b : Nat} (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem UInt16.ofNat_sub {a b : Nat} (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem UInt32.ofNat_sub {a b : Nat} (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem UInt64.ofNat_sub {a b : Nat} (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem USize.ofNat_sub {a b : Nat} (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem UInt8.ofNatLT_sub {a b : Nat} (ha : a < 2 ^ 8) (hab : b a) :
ofNatLT (a - b) = ofNatLT a ha - ofNatLT b
theorem UInt16.ofNatLT_sub {a b : Nat} (ha : a < 2 ^ 16) (hab : b a) :
ofNatLT (a - b) = ofNatLT a ha - ofNatLT b
theorem UInt32.ofNatLT_sub {a b : Nat} (ha : a < 2 ^ 32) (hab : b a) :
ofNatLT (a - b) = ofNatLT a ha - ofNatLT b
theorem UInt64.ofNatLT_sub {a b : Nat} (ha : a < 2 ^ 64) (hab : b a) :
ofNatLT (a - b) = ofNatLT a ha - ofNatLT b
theorem USize.ofNatLT_sub {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hab : b a) :
ofNatLT (a - b) = ofNatLT a ha - ofNatLT b
@[simp]
theorem UInt8.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem UInt16.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem UInt32.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem UInt64.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem USize.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem UInt8.ofNatLT_mul {a b : Nat} (ha : a < 2 ^ 8) (hb : b < 2 ^ 8) (hab : a * b < 2 ^ 8) :
ofNatLT (a * b) hab = ofNatLT a ha * ofNatLT b hb
@[simp]
theorem UInt16.ofNatLT_mul {a b : Nat} (ha : a < 2 ^ 16) (hb : b < 2 ^ 16) (hab : a * b < 2 ^ 16) :
ofNatLT (a * b) hab = ofNatLT a ha * ofNatLT b hb
@[simp]
theorem UInt32.ofNatLT_mul {a b : Nat} (ha : a < 2 ^ 32) (hb : b < 2 ^ 32) (hab : a * b < 2 ^ 32) :
ofNatLT (a * b) hab = ofNatLT a ha * ofNatLT b hb
@[simp]
theorem UInt64.ofNatLT_mul {a b : Nat} (ha : a < 2 ^ 64) (hb : b < 2 ^ 64) (hab : a * b < 2 ^ 64) :
ofNatLT (a * b) hab = ofNatLT a ha * ofNatLT b hb
@[simp]
theorem USize.ofNatLT_mul {a b : Nat} (ha : a < 2 ^ System.Platform.numBits) (hb : b < 2 ^ System.Platform.numBits) (hab : a * b < 2 ^ System.Platform.numBits) :
ofNatLT (a * b) hab = ofNatLT a ha * ofNatLT b hb
@[simp]
theorem UInt8.ofFin_mul (a b : Fin size) :
ofFin (a * b) = ofFin a * ofFin b
@[simp]
theorem UInt16.ofFin_mul (a b : Fin size) :
ofFin (a * b) = ofFin a * ofFin b
@[simp]
theorem UInt32.ofFin_mul (a b : Fin size) :
ofFin (a * b) = ofFin a * ofFin b
@[simp]
theorem UInt64.ofFin_mul (a b : Fin size) :
ofFin (a * b) = ofFin a * ofFin b
@[simp]
theorem USize.ofFin_mul (a b : Fin size) :
ofFin (a * b) = ofFin a * ofFin b
@[simp]
theorem UInt8.ofBitVec_mul (a b : BitVec 8) :
{ toBitVec := a * b } = { toBitVec := a } * { toBitVec := b }
@[simp]
theorem UInt16.ofBitVec_mul (a b : BitVec 16) :
{ toBitVec := a * b } = { toBitVec := a } * { toBitVec := b }
@[simp]
theorem UInt32.ofBitVec_mul (a b : BitVec 32) :
{ toBitVec := a * b } = { toBitVec := a } * { toBitVec := b }
@[simp]
theorem UInt64.ofBitVec_mul (a b : BitVec 64) :
{ toBitVec := a * b } = { toBitVec := a } * { toBitVec := b }
@[simp]
theorem USize.ofBitVec_mul (a b : BitVec System.Platform.numBits) :
{ toBitVec := a * b } = { toBitVec := a } * { toBitVec := b }
theorem UInt8.ofBitVec_lt_iff_lt {a b : BitVec 8} :
{ toBitVec := a } < { toBitVec := b } a < b
theorem UInt16.ofBitVec_lt_iff_lt {a b : BitVec 16} :
{ toBitVec := a } < { toBitVec := b } a < b
theorem UInt32.ofBitVec_lt_iff_lt {a b : BitVec 32} :
{ toBitVec := a } < { toBitVec := b } a < b
theorem UInt64.ofBitVec_lt_iff_lt {a b : BitVec 64} :
{ toBitVec := a } < { toBitVec := b } a < b
theorem USize.ofBitVec_lt_iff_lt {a b : BitVec System.Platform.numBits} :
{ toBitVec := a } < { toBitVec := b } a < b
theorem UInt8.ofBitVec_le_iff_le {a b : BitVec 8} :
{ toBitVec := a } { toBitVec := b } a b
theorem UInt16.ofBitVec_le_iff_le {a b : BitVec 16} :
{ toBitVec := a } { toBitVec := b } a b
theorem UInt32.ofBitVec_le_iff_le {a b : BitVec 32} :
{ toBitVec := a } { toBitVec := b } a b
theorem UInt64.ofBitVec_le_iff_le {a b : BitVec 64} :
{ toBitVec := a } { toBitVec := b } a b
theorem USize.ofBitVec_le_iff_le {a b : BitVec System.Platform.numBits} :
{ toBitVec := a } { toBitVec := b } a b
theorem UInt8.ofNatLT_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha < ofNatLT b hb a < b
theorem UInt16.ofNatLT_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha < ofNatLT b hb a < b
theorem UInt32.ofNatLT_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha < ofNatLT b hb a < b
theorem UInt64.ofNatLT_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha < ofNatLT b hb a < b
theorem USize.ofNatLT_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha < ofNatLT b hb a < b
theorem UInt8.ofNatLT_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha ofNatLT b hb a b
theorem UInt16.ofNatLT_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha ofNatLT b hb a b
theorem UInt32.ofNatLT_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha ofNatLT b hb a b
theorem UInt64.ofNatLT_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha ofNatLT b hb a b
theorem USize.ofNatLT_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
ofNatLT a ha ofNatLT b hb a b
theorem UInt8.ofNat_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNat a < ofNat b a < b
theorem UInt16.ofNat_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNat a < ofNat b a < b
theorem UInt32.ofNat_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNat a < ofNat b a < b
theorem UInt64.ofNat_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNat a < ofNat b a < b
theorem USize.ofNat_lt_iff_lt {a b : Nat} (ha : a < size) (hb : b < size) :
ofNat a < ofNat b a < b
theorem UInt8.ofNat_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
theorem UInt16.ofNat_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
theorem UInt32.ofNat_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
theorem UInt64.ofNat_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
theorem USize.ofNat_le_iff_le {a b : Nat} (ha : a < size) (hb : b < size) :
theorem UInt8.add_assoc (a b c : UInt8) :
a + b + c = a + (b + c)
theorem UInt16.add_assoc (a b c : UInt16) :
a + b + c = a + (b + c)
theorem UInt32.add_assoc (a b c : UInt32) :
a + b + c = a + (b + c)
theorem UInt64.add_assoc (a b c : UInt64) :
a + b + c = a + (b + c)
theorem USize.add_assoc (a b c : USize) :
a + b + c = a + (b + c)
instance instAssociativeUInt8HAdd :
Std.Associative fun (x1 x2 : UInt8) => x1 + x2
instance instAssociativeUInt16HAdd :
Std.Associative fun (x1 x2 : UInt16) => x1 + x2
instance instAssociativeUInt32HAdd :
Std.Associative fun (x1 x2 : UInt32) => x1 + x2
instance instAssociativeUInt64HAdd :
Std.Associative fun (x1 x2 : UInt64) => x1 + x2
instance instAssociativeUSizeHAdd :
Std.Associative fun (x1 x2 : USize) => x1 + x2
theorem UInt8.add_comm (a b : UInt8) :
a + b = b + a
theorem UInt16.add_comm (a b : UInt16) :
a + b = b + a
theorem UInt32.add_comm (a b : UInt32) :
a + b = b + a
theorem UInt64.add_comm (a b : UInt64) :
a + b = b + a
theorem USize.add_comm (a b : USize) :
a + b = b + a
instance instCommutativeUInt8HAdd :
Std.Commutative fun (x1 x2 : UInt8) => x1 + x2
instance instCommutativeUInt16HAdd :
Std.Commutative fun (x1 x2 : UInt16) => x1 + x2
instance instCommutativeUInt32HAdd :
Std.Commutative fun (x1 x2 : UInt32) => x1 + x2
instance instCommutativeUInt64HAdd :
Std.Commutative fun (x1 x2 : UInt64) => x1 + x2
instance instCommutativeUSizeHAdd :
Std.Commutative fun (x1 x2 : USize) => x1 + x2
@[simp]
theorem UInt8.add_zero (a : UInt8) :
a + 0 = a
@[simp]
theorem UInt16.add_zero (a : UInt16) :
a + 0 = a
@[simp]
theorem UInt32.add_zero (a : UInt32) :
a + 0 = a
@[simp]
theorem UInt64.add_zero (a : UInt64) :
a + 0 = a
@[simp]
theorem USize.add_zero (a : USize) :
a + 0 = a
@[simp]
theorem UInt8.zero_add (a : UInt8) :
0 + a = a
@[simp]
theorem UInt16.zero_add (a : UInt16) :
0 + a = a
@[simp]
theorem UInt32.zero_add (a : UInt32) :
0 + a = a
@[simp]
theorem UInt64.zero_add (a : UInt64) :
0 + a = a
@[simp]
theorem USize.zero_add (a : USize) :
0 + a = a
@[simp]
theorem UInt8.sub_zero (a : UInt8) :
a - 0 = a
@[simp]
theorem UInt16.sub_zero (a : UInt16) :
a - 0 = a
@[simp]
theorem UInt32.sub_zero (a : UInt32) :
a - 0 = a
@[simp]
theorem UInt64.sub_zero (a : UInt64) :
a - 0 = a
@[simp]
theorem USize.sub_zero (a : USize) :
a - 0 = a
@[simp]
theorem UInt8.zero_sub (a : UInt8) :
0 - a = -a
@[simp]
theorem UInt16.zero_sub (a : UInt16) :
0 - a = -a
@[simp]
theorem UInt32.zero_sub (a : UInt32) :
0 - a = -a
@[simp]
theorem UInt64.zero_sub (a : UInt64) :
0 - a = -a
@[simp]
theorem USize.zero_sub (a : USize) :
0 - a = -a
@[simp]
theorem UInt8.sub_self (a : UInt8) :
a - a = 0
@[simp]
theorem UInt16.sub_self (a : UInt16) :
a - a = 0
@[simp]
theorem UInt32.sub_self (a : UInt32) :
a - a = 0
@[simp]
theorem UInt64.sub_self (a : UInt64) :
a - a = 0
@[simp]
theorem USize.sub_self (a : USize) :
a - a = 0
@[simp]
theorem UInt8.neg_zero :
-0 = 0
@[simp]
theorem UInt16.neg_zero :
-0 = 0
@[simp]
theorem UInt32.neg_zero :
-0 = 0
@[simp]
theorem UInt64.neg_zero :
-0 = 0
@[simp]
theorem USize.neg_zero :
-0 = 0
@[simp]
theorem UInt8.sub_add_cancel (a b : UInt8) :
a - b + b = a
@[simp]
theorem UInt16.sub_add_cancel (a b : UInt16) :
a - b + b = a
@[simp]
theorem UInt32.sub_add_cancel (a b : UInt32) :
a - b + b = a
@[simp]
theorem UInt64.sub_add_cancel (a b : UInt64) :
a - b + b = a
@[simp]
theorem USize.sub_add_cancel (a b : USize) :
a - b + b = a
theorem UInt8.eq_sub_iff_add_eq {a b c : UInt8} :
a = c - b a + b = c
theorem UInt16.eq_sub_iff_add_eq {a b c : UInt16} :
a = c - b a + b = c
theorem UInt32.eq_sub_iff_add_eq {a b c : UInt32} :
a = c - b a + b = c
theorem UInt64.eq_sub_iff_add_eq {a b c : UInt64} :
a = c - b a + b = c
theorem USize.eq_sub_iff_add_eq {a b c : USize} :
a = c - b a + b = c
theorem UInt8.sub_eq_iff_eq_add {a b c : UInt8} :
a - b = c a = c + b
theorem UInt16.sub_eq_iff_eq_add {a b c : UInt16} :
a - b = c a = c + b
theorem UInt32.sub_eq_iff_eq_add {a b c : UInt32} :
a - b = c a = c + b
theorem UInt64.sub_eq_iff_eq_add {a b c : UInt64} :
a - b = c a = c + b
theorem USize.sub_eq_iff_eq_add {a b c : USize} :
a - b = c a = c + b
@[simp]
theorem UInt8.neg_neg {a : UInt8} :
- -a = a
@[simp]
theorem UInt16.neg_neg {a : UInt16} :
- -a = a
@[simp]
theorem UInt32.neg_neg {a : UInt32} :
- -a = a
@[simp]
theorem UInt64.neg_neg {a : UInt64} :
- -a = a
@[simp]
theorem USize.neg_neg {a : USize} :
- -a = a
@[simp]
theorem UInt8.neg_inj {a b : UInt8} :
-a = -b a = b
@[simp]
theorem UInt16.neg_inj {a b : UInt16} :
-a = -b a = b
@[simp]
theorem UInt32.neg_inj {a b : UInt32} :
-a = -b a = b
@[simp]
theorem UInt64.neg_inj {a b : UInt64} :
-a = -b a = b
@[simp]
theorem USize.neg_inj {a b : USize} :
-a = -b a = b
@[simp]
theorem UInt8.neg_ne_zero {a : UInt8} :
-a 0 a 0
@[simp]
theorem UInt16.neg_ne_zero {a : UInt16} :
-a 0 a 0
@[simp]
theorem UInt32.neg_ne_zero {a : UInt32} :
-a 0 a 0
@[simp]
theorem UInt64.neg_ne_zero {a : UInt64} :
-a 0 a 0
@[simp]
theorem USize.neg_ne_zero {a : USize} :
-a 0 a 0
theorem UInt8.neg_add {a b : UInt8} :
-(a + b) = -a - b
theorem UInt16.neg_add {a b : UInt16} :
-(a + b) = -a - b
theorem UInt32.neg_add {a b : UInt32} :
-(a + b) = -a - b
theorem UInt64.neg_add {a b : UInt64} :
-(a + b) = -a - b
theorem USize.neg_add {a b : USize} :
-(a + b) = -a - b
@[simp]
theorem UInt8.sub_neg {a b : UInt8} :
a - -b = a + b
@[simp]
theorem UInt16.sub_neg {a b : UInt16} :
a - -b = a + b
@[simp]
theorem UInt32.sub_neg {a b : UInt32} :
a - -b = a + b
@[simp]
theorem UInt64.sub_neg {a b : UInt64} :
a - -b = a + b
@[simp]
theorem USize.sub_neg {a b : USize} :
a - -b = a + b
@[simp]
theorem UInt8.neg_sub {a b : UInt8} :
-(a - b) = b - a
@[simp]
theorem UInt16.neg_sub {a b : UInt16} :
-(a - b) = b - a
@[simp]
theorem UInt32.neg_sub {a b : UInt32} :
-(a - b) = b - a
@[simp]
theorem UInt64.neg_sub {a b : UInt64} :
-(a - b) = b - a
@[simp]
theorem USize.neg_sub {a b : USize} :
-(a - b) = b - a
@[simp]
theorem UInt8.add_left_inj {a b : UInt8} (c : UInt8) :
a + c = b + c a = b
@[simp]
theorem UInt16.add_left_inj {a b : UInt16} (c : UInt16) :
a + c = b + c a = b
@[simp]
theorem UInt32.add_left_inj {a b : UInt32} (c : UInt32) :
a + c = b + c a = b
@[simp]
theorem UInt64.add_left_inj {a b : UInt64} (c : UInt64) :
a + c = b + c a = b
@[simp]
theorem USize.add_left_inj {a b : USize} (c : USize) :
a + c = b + c a = b
@[simp]
theorem UInt8.add_right_inj {a b : UInt8} (c : UInt8) :
c + a = c + b a = b
@[simp]
theorem UInt16.add_right_inj {a b : UInt16} (c : UInt16) :
c + a = c + b a = b
@[simp]
theorem UInt32.add_right_inj {a b : UInt32} (c : UInt32) :
c + a = c + b a = b
@[simp]
theorem UInt64.add_right_inj {a b : UInt64} (c : UInt64) :
c + a = c + b a = b
@[simp]
theorem USize.add_right_inj {a b : USize} (c : USize) :
c + a = c + b a = b
@[simp]
theorem UInt8.sub_left_inj {a b : UInt8} (c : UInt8) :
a - c = b - c a = b
@[simp]
theorem UInt16.sub_left_inj {a b : UInt16} (c : UInt16) :
a - c = b - c a = b
@[simp]
theorem UInt32.sub_left_inj {a b : UInt32} (c : UInt32) :
a - c = b - c a = b
@[simp]
theorem UInt64.sub_left_inj {a b : UInt64} (c : UInt64) :
a - c = b - c a = b
@[simp]
theorem USize.sub_left_inj {a b : USize} (c : USize) :
a - c = b - c a = b
@[simp]
theorem UInt8.sub_right_inj {a b : UInt8} (c : UInt8) :
c - a = c - b a = b
@[simp]
theorem UInt16.sub_right_inj {a b : UInt16} (c : UInt16) :
c - a = c - b a = b
@[simp]
theorem UInt32.sub_right_inj {a b : UInt32} (c : UInt32) :
c - a = c - b a = b
@[simp]
theorem UInt64.sub_right_inj {a b : UInt64} (c : UInt64) :
c - a = c - b a = b
@[simp]
theorem USize.sub_right_inj {a b : USize} (c : USize) :
c - a = c - b a = b
@[simp]
theorem UInt8.add_eq_right {a b : UInt8} :
a + b = b a = 0
@[simp]
theorem UInt16.add_eq_right {a b : UInt16} :
a + b = b a = 0
@[simp]
theorem UInt32.add_eq_right {a b : UInt32} :
a + b = b a = 0
@[simp]
theorem UInt64.add_eq_right {a b : UInt64} :
a + b = b a = 0
@[simp]
theorem USize.add_eq_right {a b : USize} :
a + b = b a = 0
@[simp]
theorem UInt8.add_eq_left {a b : UInt8} :
a + b = a b = 0
@[simp]
theorem UInt16.add_eq_left {a b : UInt16} :
a + b = a b = 0
@[simp]
theorem UInt32.add_eq_left {a b : UInt32} :
a + b = a b = 0
@[simp]
theorem UInt64.add_eq_left {a b : UInt64} :
a + b = a b = 0
@[simp]
theorem USize.add_eq_left {a b : USize} :
a + b = a b = 0
@[simp]
theorem UInt8.right_eq_add {a b : UInt8} :
b = a + b a = 0
@[simp]
theorem UInt16.right_eq_add {a b : UInt16} :
b = a + b a = 0
@[simp]
theorem UInt32.right_eq_add {a b : UInt32} :
b = a + b a = 0
@[simp]
theorem UInt64.right_eq_add {a b : UInt64} :
b = a + b a = 0
@[simp]
theorem USize.right_eq_add {a b : USize} :
b = a + b a = 0
@[simp]
theorem UInt8.left_eq_add {a b : UInt8} :
a = a + b b = 0
@[simp]
theorem UInt16.left_eq_add {a b : UInt16} :
a = a + b b = 0
@[simp]
theorem UInt32.left_eq_add {a b : UInt32} :
a = a + b b = 0
@[simp]
theorem UInt64.left_eq_add {a b : UInt64} :
a = a + b b = 0
@[simp]
theorem USize.left_eq_add {a b : USize} :
a = a + b b = 0
theorem UInt8.mul_comm (a b : UInt8) :
a * b = b * a
theorem UInt16.mul_comm (a b : UInt16) :
a * b = b * a
theorem UInt32.mul_comm (a b : UInt32) :
a * b = b * a
theorem UInt64.mul_comm (a b : UInt64) :
a * b = b * a
theorem USize.mul_comm (a b : USize) :
a * b = b * a
instance instCommutativeUInt8HMul :
Std.Commutative fun (x1 x2 : UInt8) => x1 * x2
instance instCommutativeUInt16HMul :
Std.Commutative fun (x1 x2 : UInt16) => x1 * x2
instance instCommutativeUInt32HMul :
Std.Commutative fun (x1 x2 : UInt32) => x1 * x2
instance instCommutativeUInt64HMul :
Std.Commutative fun (x1 x2 : UInt64) => x1 * x2
instance instCommutativeUSizeHMul :
Std.Commutative fun (x1 x2 : USize) => x1 * x2
theorem UInt8.mul_assoc (a b c : UInt8) :
a * b * c = a * (b * c)
theorem UInt16.mul_assoc (a b c : UInt16) :
a * b * c = a * (b * c)
theorem UInt32.mul_assoc (a b c : UInt32) :
a * b * c = a * (b * c)
theorem UInt64.mul_assoc (a b c : UInt64) :
a * b * c = a * (b * c)
theorem USize.mul_assoc (a b c : USize) :
a * b * c = a * (b * c)
instance instAssociativeUInt8HMul :
Std.Associative fun (x1 x2 : UInt8) => x1 * x2
instance instAssociativeUInt16HMul :
Std.Associative fun (x1 x2 : UInt16) => x1 * x2
instance instAssociativeUInt32HMul :
Std.Associative fun (x1 x2 : UInt32) => x1 * x2
instance instAssociativeUInt64HMul :
Std.Associative fun (x1 x2 : UInt64) => x1 * x2
instance instAssociativeUSizeHMul :
Std.Associative fun (x1 x2 : USize) => x1 * x2
@[simp]
theorem UInt8.mul_one (a : UInt8) :
a * 1 = a
@[simp]
theorem UInt16.mul_one (a : UInt16) :
a * 1 = a
@[simp]
theorem UInt32.mul_one (a : UInt32) :
a * 1 = a
@[simp]
theorem UInt64.mul_one (a : UInt64) :
a * 1 = a
@[simp]
theorem USize.mul_one (a : USize) :
a * 1 = a
@[simp]
theorem UInt8.one_mul (a : UInt8) :
1 * a = a
@[simp]
theorem UInt16.one_mul (a : UInt16) :
1 * a = a
@[simp]
theorem UInt32.one_mul (a : UInt32) :
1 * a = a
@[simp]
theorem UInt64.one_mul (a : UInt64) :
1 * a = a
@[simp]
theorem USize.one_mul (a : USize) :
1 * a = a
@[simp]
theorem UInt8.mul_zero {a : UInt8} :
a * 0 = 0
@[simp]
theorem UInt16.mul_zero {a : UInt16} :
a * 0 = 0
@[simp]
theorem UInt32.mul_zero {a : UInt32} :
a * 0 = 0
@[simp]
theorem UInt64.mul_zero {a : UInt64} :
a * 0 = 0
@[simp]
theorem USize.mul_zero {a : USize} :
a * 0 = 0
@[simp]
theorem UInt8.zero_mul {a : UInt8} :
0 * a = 0
@[simp]
theorem UInt16.zero_mul {a : UInt16} :
0 * a = 0
@[simp]
theorem UInt32.zero_mul {a : UInt32} :
0 * a = 0
@[simp]
theorem UInt64.zero_mul {a : UInt64} :
0 * a = 0
@[simp]
theorem USize.zero_mul {a : USize} :
0 * a = 0
theorem UInt8.mul_add {a b c : UInt8} :
a * (b + c) = a * b + a * c
theorem UInt16.mul_add {a b c : UInt16} :
a * (b + c) = a * b + a * c
theorem UInt32.mul_add {a b c : UInt32} :
a * (b + c) = a * b + a * c
theorem UInt64.mul_add {a b c : UInt64} :
a * (b + c) = a * b + a * c
theorem USize.mul_add {a b c : USize} :
a * (b + c) = a * b + a * c
theorem UInt8.add_mul {a b c : UInt8} :
(a + b) * c = a * c + b * c
theorem UInt16.add_mul {a b c : UInt16} :
(a + b) * c = a * c + b * c
theorem UInt32.add_mul {a b c : UInt32} :
(a + b) * c = a * c + b * c
theorem UInt64.add_mul {a b c : UInt64} :
(a + b) * c = a * c + b * c
theorem USize.add_mul {a b c : USize} :
(a + b) * c = a * c + b * c
theorem UInt8.mul_succ {a b : UInt8} :
a * (b + 1) = a * b + a
theorem UInt16.mul_succ {a b : UInt16} :
a * (b + 1) = a * b + a
theorem UInt32.mul_succ {a b : UInt32} :
a * (b + 1) = a * b + a
theorem UInt64.mul_succ {a b : UInt64} :
a * (b + 1) = a * b + a
theorem USize.mul_succ {a b : USize} :
a * (b + 1) = a * b + a
theorem UInt8.succ_mul {a b : UInt8} :
(a + 1) * b = a * b + b
theorem UInt16.succ_mul {a b : UInt16} :
(a + 1) * b = a * b + b
theorem UInt32.succ_mul {a b : UInt32} :
(a + 1) * b = a * b + b
theorem UInt64.succ_mul {a b : UInt64} :
(a + 1) * b = a * b + b
theorem USize.succ_mul {a b : USize} :
(a + 1) * b = a * b + b
theorem UInt8.two_mul {a : UInt8} :
2 * a = a + a
theorem UInt16.two_mul {a : UInt16} :
2 * a = a + a
theorem UInt32.two_mul {a : UInt32} :
2 * a = a + a
theorem UInt64.two_mul {a : UInt64} :
2 * a = a + a
theorem USize.two_mul {a : USize} :
2 * a = a + a
theorem UInt8.mul_two {a : UInt8} :
a * 2 = a + a
theorem UInt16.mul_two {a : UInt16} :
a * 2 = a + a
theorem UInt32.mul_two {a : UInt32} :
a * 2 = a + a
theorem UInt64.mul_two {a : UInt64} :
a * 2 = a + a
theorem USize.mul_two {a : USize} :
a * 2 = a + a
theorem UInt8.neg_mul (a b : UInt8) :
-a * b = -(a * b)
theorem UInt16.neg_mul (a b : UInt16) :
-a * b = -(a * b)
theorem UInt32.neg_mul (a b : UInt32) :
-a * b = -(a * b)
theorem UInt64.neg_mul (a b : UInt64) :
-a * b = -(a * b)
theorem USize.neg_mul (a b : USize) :
-a * b = -(a * b)
theorem UInt8.mul_neg (a b : UInt8) :
a * -b = -(a * b)
theorem UInt16.mul_neg (a b : UInt16) :
a * -b = -(a * b)
theorem UInt32.mul_neg (a b : UInt32) :
a * -b = -(a * b)
theorem UInt64.mul_neg (a b : UInt64) :
a * -b = -(a * b)
theorem USize.mul_neg (a b : USize) :
a * -b = -(a * b)
theorem UInt8.neg_mul_neg (a b : UInt8) :
-a * -b = a * b
theorem UInt16.neg_mul_neg (a b : UInt16) :
-a * -b = a * b
theorem UInt32.neg_mul_neg (a b : UInt32) :
-a * -b = a * b
theorem UInt64.neg_mul_neg (a b : UInt64) :
-a * -b = a * b
theorem USize.neg_mul_neg (a b : USize) :
-a * -b = a * b
theorem UInt8.neg_mul_comm (a b : UInt8) :
-a * b = a * -b
theorem UInt16.neg_mul_comm (a b : UInt16) :
-a * b = a * -b
theorem UInt32.neg_mul_comm (a b : UInt32) :
-a * b = a * -b
theorem UInt64.neg_mul_comm (a b : UInt64) :
-a * b = a * -b
theorem USize.neg_mul_comm (a b : USize) :
-a * b = a * -b
theorem UInt8.mul_sub {a b c : UInt8} :
a * (b - c) = a * b - a * c
theorem UInt16.mul_sub {a b c : UInt16} :
a * (b - c) = a * b - a * c
theorem UInt32.mul_sub {a b c : UInt32} :
a * (b - c) = a * b - a * c
theorem UInt64.mul_sub {a b c : UInt64} :
a * (b - c) = a * b - a * c
theorem USize.mul_sub {a b c : USize} :
a * (b - c) = a * b - a * c
theorem UInt8.sub_mul {a b c : UInt8} :
(a - b) * c = a * c - b * c
theorem UInt16.sub_mul {a b c : UInt16} :
(a - b) * c = a * c - b * c
theorem UInt32.sub_mul {a b c : UInt32} :
(a - b) * c = a * c - b * c
theorem UInt64.sub_mul {a b c : UInt64} :
(a - b) * c = a * c - b * c
theorem USize.sub_mul {a b c : USize} :
(a - b) * c = a * c - b * c
theorem UInt8.neg_add_mul_eq_mul_not {a b : UInt8} :
-(a + a * b) = a * ~~~b
theorem UInt16.neg_add_mul_eq_mul_not {a b : UInt16} :
-(a + a * b) = a * ~~~b
theorem UInt32.neg_add_mul_eq_mul_not {a b : UInt32} :
-(a + a * b) = a * ~~~b
theorem UInt64.neg_add_mul_eq_mul_not {a b : UInt64} :
-(a + a * b) = a * ~~~b
theorem USize.neg_add_mul_eq_mul_not {a b : USize} :
-(a + a * b) = a * ~~~b
theorem UInt8.neg_mul_not_eq_add_mul {a b : UInt8} :
-(a * ~~~b) = a + a * b
theorem UInt16.neg_mul_not_eq_add_mul {a b : UInt16} :
-(a * ~~~b) = a + a * b
theorem UInt32.neg_mul_not_eq_add_mul {a b : UInt32} :
-(a * ~~~b) = a + a * b
theorem UInt64.neg_mul_not_eq_add_mul {a b : UInt64} :
-(a * ~~~b) = a + a * b
theorem USize.neg_mul_not_eq_add_mul {a b : USize} :
-(a * ~~~b) = a + a * b
theorem UInt8.le_of_lt {a b : UInt8} :
a < ba b
theorem UInt16.le_of_lt {a b : UInt16} :
a < ba b
theorem UInt32.le_of_lt {a b : UInt32} :
a < ba b
theorem UInt64.le_of_lt {a b : UInt64} :
a < ba b
theorem USize.le_of_lt {a b : USize} :
a < ba b
theorem UInt8.lt_of_le_of_ne {a b : UInt8} :
a ba ba < b
theorem UInt16.lt_of_le_of_ne {a b : UInt16} :
a ba ba < b
theorem UInt32.lt_of_le_of_ne {a b : UInt32} :
a ba ba < b
theorem UInt64.lt_of_le_of_ne {a b : UInt64} :
a ba ba < b
theorem USize.lt_of_le_of_ne {a b : USize} :
a ba ba < b
theorem UInt8.lt_iff_le_and_ne {a b : UInt8} :
a < b a b a b
theorem UInt16.lt_iff_le_and_ne {a b : UInt16} :
a < b a b a b
theorem UInt32.lt_iff_le_and_ne {a b : UInt32} :
a < b a b a b
theorem UInt64.lt_iff_le_and_ne {a b : UInt64} :
a < b a b a b
theorem USize.lt_iff_le_and_ne {a b : USize} :
a < b a b a b
@[simp]
theorem UInt8.not_lt_zero {a : UInt8} :
¬a < 0
@[simp]
theorem UInt16.not_lt_zero {a : UInt16} :
¬a < 0
@[simp]
theorem UInt32.not_lt_zero {a : UInt32} :
¬a < 0
@[simp]
theorem UInt64.not_lt_zero {a : UInt64} :
¬a < 0
@[simp]
theorem USize.not_lt_zero {a : USize} :
¬a < 0
@[simp]
theorem UInt8.zero_le {a : UInt8} :
0 a
@[simp]
theorem UInt16.zero_le {a : UInt16} :
0 a
@[simp]
theorem UInt32.zero_le {a : UInt32} :
0 a
@[simp]
theorem UInt64.zero_le {a : UInt64} :
0 a
@[simp]
theorem USize.zero_le {a : USize} :
0 a
@[simp]
theorem UInt8.le_zero_iff {a : UInt8} :
a 0 a = 0
@[simp]
theorem UInt16.le_zero_iff {a : UInt16} :
a 0 a = 0
@[simp]
theorem UInt32.le_zero_iff {a : UInt32} :
a 0 a = 0
@[simp]
theorem UInt64.le_zero_iff {a : UInt64} :
a 0 a = 0
@[simp]
theorem USize.le_zero_iff {a : USize} :
a 0 a = 0
@[simp]
theorem UInt8.lt_one_iff {a : UInt8} :
a < 1 a = 0
@[simp]
theorem UInt16.lt_one_iff {a : UInt16} :
a < 1 a = 0
@[simp]
theorem UInt32.lt_one_iff {a : UInt32} :
a < 1 a = 0
@[simp]
theorem UInt64.lt_one_iff {a : UInt64} :
a < 1 a = 0
@[simp]
theorem USize.lt_one_iff {a : USize} :
a < 1 a = 0
@[simp]
theorem UInt8.zero_div {a : UInt8} :
0 / a = 0
@[simp]
theorem UInt16.zero_div {a : UInt16} :
0 / a = 0
@[simp]
theorem UInt32.zero_div {a : UInt32} :
0 / a = 0
@[simp]
theorem UInt64.zero_div {a : UInt64} :
0 / a = 0
@[simp]
theorem USize.zero_div {a : USize} :
0 / a = 0
@[simp]
theorem UInt8.div_zero {a : UInt8} :
a / 0 = 0
@[simp]
theorem UInt16.div_zero {a : UInt16} :
a / 0 = 0
@[simp]
theorem UInt32.div_zero {a : UInt32} :
a / 0 = 0
@[simp]
theorem UInt64.div_zero {a : UInt64} :
a / 0 = 0
@[simp]
theorem USize.div_zero {a : USize} :
a / 0 = 0
@[simp]
theorem UInt8.div_one {a : UInt8} :
a / 1 = a
@[simp]
theorem UInt16.div_one {a : UInt16} :
a / 1 = a
@[simp]
theorem UInt32.div_one {a : UInt32} :
a / 1 = a
@[simp]
theorem UInt64.div_one {a : UInt64} :
a / 1 = a
@[simp]
theorem USize.div_one {a : USize} :
a / 1 = a
theorem UInt8.div_self {a : UInt8} :
a / a = if a = 0 then 0 else 1
theorem UInt16.div_self {a : UInt16} :
a / a = if a = 0 then 0 else 1
theorem UInt32.div_self {a : UInt32} :
a / a = if a = 0 then 0 else 1
theorem UInt64.div_self {a : UInt64} :
a / a = if a = 0 then 0 else 1
theorem USize.div_self {a : USize} :
a / a = if a = 0 then 0 else 1
@[simp]
theorem UInt8.mod_zero {a : UInt8} :
a % 0 = a
@[simp]
theorem UInt16.mod_zero {a : UInt16} :
a % 0 = a
@[simp]
theorem UInt32.mod_zero {a : UInt32} :
a % 0 = a
@[simp]
theorem UInt64.mod_zero {a : UInt64} :
a % 0 = a
@[simp]
theorem USize.mod_zero {a : USize} :
a % 0 = a
@[simp]
theorem UInt8.zero_mod {a : UInt8} :
0 % a = 0
@[simp]
theorem UInt16.zero_mod {a : UInt16} :
0 % a = 0
@[simp]
theorem UInt32.zero_mod {a : UInt32} :
0 % a = 0
@[simp]
theorem UInt64.zero_mod {a : UInt64} :
0 % a = 0
@[simp]
theorem USize.zero_mod {a : USize} :
0 % a = 0
@[simp]
theorem UInt8.mod_one {a : UInt8} :
a % 1 = 0
@[simp]
theorem UInt16.mod_one {a : UInt16} :
a % 1 = 0
@[simp]
theorem UInt32.mod_one {a : UInt32} :
a % 1 = 0
@[simp]
theorem UInt64.mod_one {a : UInt64} :
a % 1 = 0
@[simp]
theorem USize.mod_one {a : USize} :
a % 1 = 0
@[simp]
theorem UInt8.mod_self {a : UInt8} :
a % a = 0
@[simp]
theorem UInt16.mod_self {a : UInt16} :
a % a = 0
@[simp]
theorem UInt32.mod_self {a : UInt32} :
a % a = 0
@[simp]
theorem UInt64.mod_self {a : UInt64} :
a % a = 0
@[simp]
theorem USize.mod_self {a : USize} :
a % a = 0
theorem UInt8.pos_iff_ne_zero {a : UInt8} :
0 < a a 0
theorem USize.pos_iff_ne_zero {a : USize} :
0 < a a 0
theorem UInt8.lt_of_le_of_lt {a b c : UInt8} :
a bb < ca < c
theorem UInt16.lt_of_le_of_lt {a b c : UInt16} :
a bb < ca < c
theorem UInt32.lt_of_le_of_lt {a b c : UInt32} :
a bb < ca < c
theorem UInt64.lt_of_le_of_lt {a b c : UInt64} :
a bb < ca < c
theorem USize.lt_of_le_of_lt {a b c : USize} :
a bb < ca < c
theorem UInt8.lt_of_lt_of_le {a b c : UInt8} :
a < bb ca < c
theorem UInt16.lt_of_lt_of_le {a b c : UInt16} :
a < bb ca < c
theorem UInt32.lt_of_lt_of_le {a b c : UInt32} :
a < bb ca < c
theorem UInt64.lt_of_lt_of_le {a b c : UInt64} :
a < bb ca < c
theorem USize.lt_of_lt_of_le {a b c : USize} :
a < bb ca < c
theorem UInt8.lt_or_lt_of_ne {a b : UInt8} :
a ba < b b < a
theorem UInt16.lt_or_lt_of_ne {a b : UInt16} :
a ba < b b < a
theorem UInt32.lt_or_lt_of_ne {a b : UInt32} :
a ba < b b < a
theorem UInt64.lt_or_lt_of_ne {a b : UInt64} :
a ba < b b < a
theorem USize.lt_or_lt_of_ne {a b : USize} :
a ba < b b < a
theorem UInt8.lt_or_le (a b : UInt8) :
a < b b a
theorem UInt16.lt_or_le (a b : UInt16) :
a < b b a
theorem UInt32.lt_or_le (a b : UInt32) :
a < b b a
theorem UInt64.lt_or_le (a b : UInt64) :
a < b b a
theorem USize.lt_or_le (a b : USize) :
a < b b a
theorem UInt8.le_or_lt (a b : UInt8) :
a b b < a
theorem UInt16.le_or_lt (a b : UInt16) :
a b b < a
theorem UInt32.le_or_lt (a b : UInt32) :
a b b < a
theorem UInt64.le_or_lt (a b : UInt64) :
a b b < a
theorem USize.le_or_lt (a b : USize) :
a b b < a
theorem UInt8.le_of_eq {a b : UInt8} :
a = ba b
theorem UInt16.le_of_eq {a b : UInt16} :
a = ba b
theorem UInt32.le_of_eq {a b : UInt32} :
a = ba b
theorem UInt64.le_of_eq {a b : UInt64} :
a = ba b
theorem USize.le_of_eq {a b : USize} :
a = ba b
theorem UInt8.le_iff_lt_or_eq {a b : UInt8} :
a b a < b a = b
theorem UInt16.le_iff_lt_or_eq {a b : UInt16} :
a b a < b a = b
theorem UInt32.le_iff_lt_or_eq {a b : UInt32} :
a b a < b a = b
theorem UInt64.le_iff_lt_or_eq {a b : UInt64} :
a b a < b a = b
theorem USize.le_iff_lt_or_eq {a b : USize} :
a b a < b a = b
theorem UInt8.lt_or_eq_of_le {a b : UInt8} :
a ba < b a = b
theorem UInt16.lt_or_eq_of_le {a b : UInt16} :
a ba < b a = b
theorem UInt32.lt_or_eq_of_le {a b : UInt32} :
a ba < b a = b
theorem UInt64.lt_or_eq_of_le {a b : UInt64} :
a ba < b a = b
theorem USize.lt_or_eq_of_le {a b : USize} :
a ba < b a = b
theorem UInt8.sub_le {a b : UInt8} (hab : b a) :
a - b a
theorem UInt16.sub_le {a b : UInt16} (hab : b a) :
a - b a
theorem UInt32.sub_le {a b : UInt32} (hab : b a) :
a - b a
theorem UInt64.sub_le {a b : UInt64} (hab : b a) :
a - b a
theorem USize.sub_le {a b : USize} (hab : b a) :
a - b a
theorem UInt8.sub_lt {a b : UInt8} (hb : 0 < b) (hab : b a) :
a - b < a
theorem UInt16.sub_lt {a b : UInt16} (hb : 0 < b) (hab : b a) :
a - b < a
theorem UInt32.sub_lt {a b : UInt32} (hb : 0 < b) (hab : b a) :
a - b < a
theorem UInt64.sub_lt {a b : UInt64} (hb : 0 < b) (hab : b a) :
a - b < a
theorem USize.sub_lt {a b : USize} (hb : 0 < b) (hab : b a) :
a - b < a