Documentation

Init.Data.SInt.Lemmas

Equations
  • One or more equations did not get rendered due to their size.
@[simp]
theorem Int8.toBitVec_div {a b : Int8} :
@[simp]
theorem Int8.toBitVec_sub {a b : Int8} :
@[simp]
theorem Int8.toBitVec_mod {a b : Int8} :
@[simp]
theorem Int8.toBitVec_mul {a b : Int8} :
@[simp]
theorem Int8.toBitVec_add {a b : Int8} :
@[simp]
@[simp]
@[simp]
theorem Int16.toBitVec_mul {a b : Int16} :
@[simp]
theorem Int16.toBitVec_add {a b : Int16} :
@[simp]
theorem Int16.toBitVec_sub {a b : Int16} :
@[simp]
@[simp]
@[simp]
theorem Int32.toBitVec_sub {a b : Int32} :
@[simp]
theorem Int32.toBitVec_mul {a b : Int32} :
@[simp]
theorem Int32.toBitVec_add {a b : Int32} :
@[simp]
@[simp]
theorem Int64.toBitVec_sub {a b : Int64} :
@[simp]
@[simp]
theorem Int64.toBitVec_add {a b : Int64} :
@[simp]
theorem Int64.toBitVec_mul {a b : Int64} :
@[simp]
theorem ISize.toBitVec_mul {a b : ISize} :
@[simp]
theorem ISize.toBitVec_sub {a b : ISize} :
@[simp]
theorem ISize.toBitVec_add {a b : ISize} :
@[simp]
@[simp]
@[deprecated Int8.le_iff_toBitVec_sle (since := "2025-03-20")]
theorem Int8.le_def {a b : Int8} :
@[deprecated Int16.le_iff_toBitVec_sle (since := "2025-03-20")]
theorem Int16.le_def {a b : Int16} :
@[deprecated Int32.le_iff_toBitVec_sle (since := "2025-03-20")]
theorem Int32.le_def {a b : Int32} :
@[deprecated Int64.le_iff_toBitVec_sle (since := "2025-03-20")]
theorem Int64.le_def {a b : Int64} :
@[deprecated ISize.le_iff_toBitVec_sle (since := "2025-03-20")]
theorem ISize.le_def {a b : ISize} :
@[deprecated Int8.lt_iff_toBitVec_slt (since := "2025-03-20")]
theorem Int8.lt_def {a b : Int8} :
@[deprecated Int16.lt_iff_toBitVec_slt (since := "2025-03-20")]
theorem Int16.lt_def {a b : Int16} :
@[deprecated Int32.lt_iff_toBitVec_slt (since := "2025-03-20")]
theorem Int32.lt_def {a b : Int32} :
@[deprecated Int64.lt_iff_toBitVec_slt (since := "2025-03-20")]
theorem Int64.lt_def {a b : Int64} :
@[deprecated ISize.lt_iff_toBitVec_slt (since := "2025-03-20")]
theorem ISize.lt_def {a b : ISize} :
theorem Int8.toInt.inj {x y : Int8} (h : x.toInt = y.toInt) :
x = y
theorem Int8.toInt_inj {x y : Int8} :
x.toInt = y.toInt x = y
theorem Int16.toInt.inj {x y : Int16} (h : x.toInt = y.toInt) :
x = y
theorem Int16.toInt_inj {x y : Int16} :
x.toInt = y.toInt x = y
theorem Int32.toInt.inj {x y : Int32} (h : x.toInt = y.toInt) :
x = y
theorem Int32.toInt_inj {x y : Int32} :
x.toInt = y.toInt x = y
theorem Int64.toInt.inj {x y : Int64} (h : x.toInt = y.toInt) :
x = y
theorem Int64.toInt_inj {x y : Int64} :
x.toInt = y.toInt x = y
theorem ISize.toInt.inj {x y : ISize} (h : x.toInt = y.toInt) :
x = y
theorem ISize.toInt_inj {x y : ISize} :
x.toInt = y.toInt x = y
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.neg_zero :
-0 = 0
@[simp]
theorem Int16.neg_zero :
-0 = 0
@[simp]
theorem Int32.neg_zero :
-0 = 0
@[simp]
theorem Int64.neg_zero :
-0 = 0
@[simp]
theorem ISize.neg_zero :
-0 = 0
@[simp]
theorem Int8.toInt_ofInt {n : Int} :
@[simp]
theorem Int16.toInt_ofInt {n : Int} :
@[simp]
theorem Int32.toInt_ofInt {n : Int} :
@[simp]
theorem Int64.toInt_ofInt {n : Int} :
theorem Int8.toInt_ofInt_of_le {n : Int} (hn : -2 ^ 7 n) (hn' : n < 2 ^ 7) :
(ofInt n).toInt = n
theorem Int16.toInt_ofInt_of_le {n : Int} (hn : -2 ^ 15 n) (hn' : n < 2 ^ 15) :
(ofInt n).toInt = n
theorem Int32.toInt_ofInt_of_le {n : Int} (hn : -2 ^ 31 n) (hn' : n < 2 ^ 31) :
(ofInt n).toInt = n
theorem Int64.toInt_ofInt_of_le {n : Int} (hn : -2 ^ 63 n) (hn' : n < 2 ^ 63) :
(ofInt n).toInt = n
theorem ISize.toInt_ofInt_of_le {n : Int} (hn : -2 ^ 31 n) (hn' : n < 2 ^ 31) :
(ofInt n).toInt = n
theorem ISize.toNatClampNeg_ofInt_eq_zero {n : Int} (hn : -2 ^ 31 n) (hn' : n 0) :
theorem Int8.neg_ofInt {n : Int} :
theorem Int16.neg_ofInt {n : Int} :
theorem Int32.neg_ofInt {n : Int} :
theorem Int64.neg_ofInt {n : Int} :
theorem ISize.neg_ofInt {n : Int} :
theorem Int8.ofInt_eq_ofNat {n : Nat} :
ofInt n = ofNat n
@[simp]
theorem Int8.toInt_ofNat {n : Nat} :
(ofNat n).toInt = (↑n).bmod size
@[simp]
theorem Int16.toInt_ofNat {n : Nat} :
(ofNat n).toInt = (↑n).bmod size
@[simp]
theorem Int32.toInt_ofNat {n : Nat} :
(ofNat n).toInt = (↑n).bmod size
@[simp]
theorem Int64.toInt_ofNat {n : Nat} :
(ofNat n).toInt = (↑n).bmod size
@[simp]
theorem ISize.toInt_ofNat {n : Nat} :
(ofNat n).toInt = (↑n).bmod size
theorem Int8.neg_ofNat {n : Nat} :
-ofNat n = ofInt (-n)
theorem Int16.neg_ofNat {n : Nat} :
-ofNat n = ofInt (-n)
theorem Int32.neg_ofNat {n : Nat} :
-ofNat n = ofInt (-n)
theorem Int64.neg_ofNat {n : Nat} :
-ofNat n = ofInt (-n)
theorem ISize.neg_ofNat {n : Nat} :
-ofNat n = ofInt (-n)
theorem Int8.toInt_ofNat_of_lt {n : Nat} (h : n < 2 ^ 7) :
(ofNat n).toInt = n
theorem Int16.toInt_ofNat_of_lt {n : Nat} (h : n < 2 ^ 15) :
(ofNat n).toInt = n
theorem Int32.toInt_ofNat_of_lt {n : Nat} (h : n < 2 ^ 31) :
(ofNat n).toInt = n
theorem Int64.toInt_ofNat_of_lt {n : Nat} (h : n < 2 ^ 63) :
(ofNat n).toInt = n
theorem ISize.toInt_ofNat_of_lt {n : Nat} (h : n < 2 ^ 31) :
(ofNat n).toInt = n
theorem Int64.toInt_neg_ofNat_of_le {n : Nat} (h : n 2 ^ 63) :
(-ofNat n).toInt = -n
theorem ISize.toInt_neg_ofNat_of_le {n : Nat} (h : n 2 ^ 31) :
(-ofNat n).toInt = -n
@[simp]
@[simp]
theorem Int8.toInt_lt (x : Int8) :
x.toInt < 2 ^ 7
theorem Int8.le_toInt (x : Int8) :
-2 ^ 7 x.toInt
theorem Int16.toInt_lt (x : Int16) :
x.toInt < 2 ^ 15
theorem Int16.le_toInt (x : Int16) :
-2 ^ 15 x.toInt
theorem Int32.toInt_lt (x : Int32) :
x.toInt < 2 ^ 31
theorem Int32.le_toInt (x : Int32) :
-2 ^ 31 x.toInt
theorem Int64.toInt_lt (x : Int64) :
x.toInt < 2 ^ 63
theorem Int64.le_toInt (x : Int64) :
-2 ^ 63 x.toInt
theorem ISize.toInt_lt (x : ISize) :
x.toInt < 2 ^ 63
theorem ISize.le_toInt (x : ISize) :
-2 ^ 63 x.toInt
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int16.toInt_toInt8 (x : Int16) :
x.toInt8.toInt = x.toInt.bmod (2 ^ 8)
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int32.toInt_toInt8 (x : Int32) :
x.toInt8.toInt = x.toInt.bmod (2 ^ 8)
@[simp]
theorem Int32.toInt_toInt16 (x : Int32) :
x.toInt16.toInt = x.toInt.bmod (2 ^ 16)
@[simp]
@[simp]
@[simp]
theorem Int64.toInt_toInt8 (x : Int64) :
x.toInt8.toInt = x.toInt.bmod (2 ^ 8)
@[simp]
theorem Int64.toInt_toInt16 (x : Int64) :
x.toInt16.toInt = x.toInt.bmod (2 ^ 16)
@[simp]
theorem Int64.toInt_toInt32 (x : Int64) :
x.toInt32.toInt = x.toInt.bmod (2 ^ 32)
@[simp]
theorem ISize.toInt_toInt8 (x : ISize) :
x.toInt8.toInt = x.toInt.bmod (2 ^ 8)
@[simp]
theorem ISize.toInt_toInt16 (x : ISize) :
x.toInt16.toInt = x.toInt.bmod (2 ^ 16)
@[simp]
theorem ISize.toInt_toInt32 (x : ISize) :
x.toInt32.toInt = x.toInt.bmod (2 ^ 32)
@[simp]
@[simp]
@[simp]
theorem UInt8.ofBitVec_int8ToBitVec (x : Int8) :
{ toBitVec := x.toBitVec } = x.toUInt8
@[simp]
theorem UInt16.ofBitVec_int16ToBitVec (x : Int16) :
{ toBitVec := x.toBitVec } = x.toUInt16
@[simp]
theorem UInt32.ofBitVec_int32ToBitVec (x : Int32) :
{ toBitVec := x.toBitVec } = x.toUInt32
@[simp]
theorem UInt64.ofBitVec_int64ToBitVec (x : Int64) :
{ toBitVec := x.toBitVec } = x.toUInt64
@[simp]
theorem USize.ofBitVec_iSizeToBitVec (x : ISize) :
{ toBitVec := x.toBitVec } = x.toUSize
@[simp]
theorem Int8.toBitVec_ofIntLE (x : Int) (h₁ : minValue.toInt x) (h₂ : x maxValue.toInt) :
(ofIntLE x h₁ h₂).toBitVec = BitVec.ofInt 8 x
@[simp]
theorem Int16.toBitVec_ofIntLE (x : Int) (h₁ : minValue.toInt x) (h₂ : x maxValue.toInt) :
(ofIntLE x h₁ h₂).toBitVec = BitVec.ofInt 16 x
@[simp]
theorem Int32.toBitVec_ofIntLE (x : Int) (h₁ : minValue.toInt x) (h₂ : x maxValue.toInt) :
(ofIntLE x h₁ h₂).toBitVec = BitVec.ofInt 32 x
@[simp]
theorem Int64.toBitVec_ofIntLE (x : Int) (h₁ : minValue.toInt x) (h₂ : x maxValue.toInt) :
(ofIntLE x h₁ h₂).toBitVec = BitVec.ofInt 64 x
@[simp]
theorem Int8.toInt_bmod (x : Int8) :
x.toInt.bmod 256 = x.toInt
@[simp]
theorem Int16.toInt_bmod (x : Int16) :
x.toInt.bmod 65536 = x.toInt
@[simp]
theorem Int32.toInt_bmod (x : Int32) :
x.toInt.bmod 4294967296 = x.toInt
@[simp]
theorem Int64.toInt_bmod (x : Int64) :
x.toInt.bmod 18446744073709551616 = x.toInt
@[simp]
theorem Int8.toInt_bmod_65536 (x : Int8) :
x.toInt.bmod 65536 = x.toInt
@[simp]
theorem Int8.toInt_bmod_4294967296 (x : Int8) :
x.toInt.bmod 4294967296 = x.toInt
@[simp]
theorem Int16.toInt_bmod_4294967296 (x : Int16) :
x.toInt.bmod 4294967296 = x.toInt
@[simp]
theorem Int8.toInt_bmod_18446744073709551616 (x : Int8) :
x.toInt.bmod 18446744073709551616 = x.toInt
@[simp]
theorem Int16.toInt_bmod_18446744073709551616 (x : Int16) :
x.toInt.bmod 18446744073709551616 = x.toInt
@[simp]
theorem Int32.toInt_bmod_18446744073709551616 (x : Int32) :
x.toInt.bmod 18446744073709551616 = x.toInt
@[simp]
theorem ISize.toInt_bmod_18446744073709551616 (x : ISize) :
x.toInt.bmod 18446744073709551616 = x.toInt
@[simp]
theorem Int8.ofIntLE_toInt (x : Int8) :
ofIntLE x.toInt = x
@[simp]
theorem Int16.ofIntLE_toInt (x : Int16) :
ofIntLE x.toInt = x
@[simp]
theorem Int32.ofIntLE_toInt (x : Int32) :
ofIntLE x.toInt = x
@[simp]
theorem Int64.ofIntLE_toInt (x : Int64) :
ofIntLE x.toInt = x
@[simp]
theorem ISize.ofIntLE_toInt (x : ISize) :
ofIntLE x.toInt = x
theorem Int8.ofIntLE_int16ToInt (x : Int16) {h₁ : minValue.toInt x.toInt} {h₂ : x.toInt maxValue.toInt} :
ofIntLE x.toInt h₁ h₂ = x.toInt8
theorem Int8.ofIntLE_int32ToInt (x : Int32) {h₁ : minValue.toInt x.toInt} {h₂ : x.toInt maxValue.toInt} :
ofIntLE x.toInt h₁ h₂ = x.toInt8
theorem Int8.ofIntLE_int64ToInt (x : Int64) {h₁ : minValue.toInt x.toInt} {h₂ : x.toInt maxValue.toInt} :
ofIntLE x.toInt h₁ h₂ = x.toInt8
theorem Int8.ofIntLE_iSizeToInt (x : ISize) {h₁ : minValue.toInt x.toInt} {h₂ : x.toInt maxValue.toInt} :
ofIntLE x.toInt h₁ h₂ = x.toInt8
@[simp]
theorem Int16.ofIntLE_int8ToInt (x : Int8) :
ofIntLE x.toInt = x.toInt16
@[simp]
theorem Int32.ofIntLE_int8ToInt (x : Int8) :
ofIntLE x.toInt = x.toInt32
@[simp]
@[simp]
theorem Int64.ofIntLE_int8ToInt (x : Int8) :
ofIntLE x.toInt = x.toInt64
@[simp]
@[simp]
@[simp]
@[simp]
theorem ISize.ofIntLE_int8ToInt (x : Int8) :
ofIntLE x.toInt = x.toISize
@[simp]
@[simp]
@[simp]
theorem Int8.ofInt_toInt (x : Int8) :
@[simp]
theorem Int16.ofInt_toInt (x : Int16) :
@[simp]
theorem Int32.ofInt_toInt (x : Int32) :
@[simp]
theorem Int64.ofInt_toInt (x : Int64) :
@[simp]
theorem ISize.ofInt_toInt (x : ISize) :
@[simp]
theorem Int8.toInt_ofIntLE {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
(ofIntLE x h₁ h₂).toInt = x
@[simp]
theorem Int16.toInt_ofIntLE {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
(ofIntLE x h₁ h₂).toInt = x
@[simp]
theorem Int32.toInt_ofIntLE {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
(ofIntLE x h₁ h₂).toInt = x
@[simp]
theorem Int64.toInt_ofIntLE {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
(ofIntLE x h₁ h₂).toInt = x
@[simp]
theorem ISize.toInt_ofIntLE {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
(ofIntLE x h₁ h₂).toInt = x
theorem Int8.ofIntLE_eq_ofIntTruncate {x : Int} {h₁ : minValue.toInt x} {h₂ : x maxValue.toInt} :
ofIntLE x h₁ h₂ = ofIntTruncate x
theorem Int8.ofIntLE_eq_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
ofIntLE n h₁ h₂ = ofInt n
theorem Int16.ofIntLE_eq_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
ofIntLE n h₁ h₂ = ofInt n
theorem Int32.ofIntLE_eq_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
ofIntLE n h₁ h₂ = ofInt n
theorem Int64.ofIntLE_eq_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
ofIntLE n h₁ h₂ = ofInt n
theorem ISize.ofIntLE_eq_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
ofIntLE n h₁ h₂ = ofInt n
theorem Int8.lt_iff_toInt_lt {x y : Int8} :
x < y x.toInt < y.toInt
theorem Int8.cast_toNatClampNeg (x : Int8) (hx : 0 x) :
theorem Int16.cast_toNatClampNeg (x : Int16) (hx : 0 x) :
theorem Int32.cast_toNatClampNeg (x : Int32) (hx : 0 x) :
theorem Int64.cast_toNatClampNeg (x : Int64) (hx : 0 x) :
theorem ISize.cast_toNatClampNeg (x : ISize) (hx : 0 x) :
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.toInt8_ofNatLT {n : Nat} (hn : n < size) :
@[simp]
@[simp]
theorem UInt8.toInt8_ofBitVec (b : BitVec 8) :
{ toBitVec := b }.toInt8 = Int8.ofBitVec b
@[simp]
theorem UInt16.toInt16_ofBitVec (b : BitVec 16) :
{ toBitVec := b }.toInt16 = Int16.ofBitVec b
@[simp]
theorem UInt32.toInt32_ofBitVec (b : BitVec 32) :
{ toBitVec := b }.toInt32 = Int32.ofBitVec b
@[simp]
theorem UInt64.toInt64_ofBitVec (b : BitVec 64) :
{ toBitVec := b }.toInt64 = Int64.ofBitVec b
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.toNatClampNeg_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toNatClampNeg = n.toNat
@[simp]
theorem Int16.toNatClampNeg_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toNatClampNeg = n.toNat
@[simp]
theorem Int32.toNatClampNeg_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toNatClampNeg = n.toNat
@[simp]
theorem Int64.toNatClampNeg_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toNatClampNeg = n.toNat
@[simp]
theorem ISize.toNatClampNeg_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toNatClampNeg = n.toNat
theorem Int8.toNatClampNeg_ofInt_of_le {n : Int} (h₁ : -2 ^ 7 n) (h₂ : n < 2 ^ 7) :
theorem Int16.toNatClampNeg_ofInt_of_le {n : Int} (h₁ : -2 ^ 15 n) (h₂ : n < 2 ^ 15) :
theorem Int32.toNatClampNeg_ofInt_of_le {n : Int} (h₁ : -2 ^ 31 n) (h₂ : n < 2 ^ 31) :
theorem Int64.toNatClampNeg_ofInt_of_le {n : Int} (h₁ : -2 ^ 63 n) (h₂ : n < 2 ^ 63) :
theorem ISize.toNatClampNeg_ofInt_of_le {n : Int} (h₁ : -2 ^ 31 n) (h₂ : n < 2 ^ 31) :
@[simp]
theorem Int8.toUInt8_ofBitVec (b : BitVec 8) :
(ofBitVec b).toUInt8 = { toBitVec := b }
@[simp]
theorem Int16.toUInt16_ofBitVec (b : BitVec 16) :
(ofBitVec b).toUInt16 = { toBitVec := b }
@[simp]
theorem Int32.toUInt32_ofBitVec (b : BitVec 32) :
(ofBitVec b).toUInt32 = { toBitVec := b }
@[simp]
theorem Int64.toUInt64_ofBitVec (b : BitVec 64) :
(ofBitVec b).toUInt64 = { toBitVec := b }
@[simp]
theorem Int16.toInt8_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt8 = Int8.ofInt n
theorem Int32.toInt8_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt8 = Int8.ofInt n
theorem Int64.toInt8_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt8 = Int8.ofInt n
theorem ISize.toInt8_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt8 = Int8.ofInt n
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int16.toInt8_ofIntTruncate {n : Int} (h₁ : -2 ^ 15 n) (h₂ : n < 2 ^ 15) :
theorem Int32.toInt8_ofIntTruncate {n : Int} (h₁ : -2 ^ 31 n) (h₂ : n < 2 ^ 31) :
theorem Int64.toInt8_ofIntTruncate {n : Int} (h₁ : -2 ^ 63 n) (h₂ : n < 2 ^ 63) :
theorem Int32.toInt16_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt16 = Int16.ofInt n
theorem Int64.toInt16_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt16 = Int16.ofInt n
theorem ISize.toInt16_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt16 = Int16.ofInt n
theorem Int32.toInt16_ofIntTruncate {n : Int} (h₁ : -2 ^ 31 n) (h₂ : n < 2 ^ 31) :
theorem Int64.toInt16_ofIntTruncate {n : Int} (h₁ : -2 ^ 63 n) (h₂ : n < 2 ^ 63) :
theorem Int64.toInt32_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt32 = Int32.ofInt n
theorem ISize.toInt32_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt32 = Int32.ofInt n
theorem Int64.toInt32_ofIntTruncate {n : Int} (h₁ : -2 ^ 63 n) (h₂ : n < 2 ^ 63) :
theorem Int64.toISize_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toISize = ISize.ofInt n
theorem Int64.toISize_ofIntTruncate {n : Int} (h₁ : -2 ^ 63 n) (h₂ : n < 2 ^ 63) :
@[simp]
theorem Int16.toInt8_neg (x : Int16) :
@[simp]
theorem Int32.toInt8_neg (x : Int32) :
@[simp]
theorem Int64.toInt8_neg (x : Int64) :
@[simp]
theorem ISize.toInt8_neg (x : ISize) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.toInt16_neg_of_ne {x : Int8} (hx : x -128) :
@[simp]
theorem Int8.toInt32_neg_of_ne {x : Int8} (hx : x -128) :
@[simp]
theorem Int16.toInt32_neg_of_ne {x : Int16} (hx : x -32768) :
@[simp]
theorem Int8.toISize_neg_of_ne {x : Int8} (hx : x -128) :
@[simp]
theorem Int16.toISize_neg_of_ne {x : Int16} (hx : x -32768) :
@[simp]
theorem Int32.toISize_neg_of_ne {x : Int32} (hx : x -2147483648) :
@[simp]
theorem Int8.toInt64_neg_of_ne {x : Int8} (hx : x -128) :
@[simp]
theorem Int16.toInt64_neg_of_ne {x : Int16} (hx : x -32768) :
@[simp]
theorem Int32.toInt64_neg_of_ne {x : Int32} (hx : x -2147483648) :
@[simp]
theorem Int8.toInt16_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt16 = Int16.ofIntLE n
theorem Int8.toInt32_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt32 = Int32.ofIntLE n
theorem Int8.toInt64_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt64 = Int64.ofIntLE n
theorem Int8.toISize_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toISize = ISize.ofIntLE n
@[simp]
theorem Int8.toInt16_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int8.toInt32_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int8.toInt64_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int8.toISize_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.toInt16_ofNat {n : Nat} (h : n 127) :
@[simp]
theorem Int8.toInt32_ofNat {n : Nat} (h : n 127) :
@[simp]
theorem Int8.toInt64_ofNat {n : Nat} (h : n 127) :
@[simp]
theorem Int8.toISize_ofNat {n : Nat} (h : n 127) :
theorem Int16.toInt32_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt32 = Int32.ofIntLE n
theorem Int16.toInt64_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt64 = Int64.ofIntLE n
theorem Int16.toISize_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toISize = ISize.ofIntLE n
@[simp]
theorem Int16.toInt32_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int16.toInt64_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int16.toISize_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int16.toInt32_ofNat {n : Nat} (h : n 32767) :
@[simp]
theorem Int16.toInt64_ofNat {n : Nat} (h : n 32767) :
@[simp]
theorem Int16.toISize_ofNat {n : Nat} (h : n 32767) :
theorem Int32.toInt64_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt64 = Int64.ofIntLE n
theorem Int32.toISize_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toISize = ISize.ofIntLE n
@[simp]
theorem Int32.toInt64_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
theorem Int32.toISize_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
@[simp]
@[simp]
theorem Int32.toInt64_ofNat {n : Nat} (h : n 2147483647) :
@[simp]
theorem Int32.toISize_ofNat {n : Nat} (h : n 2147483647) :
theorem ISize.toInt64_ofIntLE {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
(ofIntLE n h₁ h₂).toInt64 = Int64.ofIntLE n
@[simp]
theorem ISize.toInt64_ofInt {n : Int} (h₁ : minValue.toInt n) (h₂ : n maxValue.toInt) :
@[simp]
@[simp]
theorem ISize.toInt64_ofNat {n : Nat} (h : n 2147483647) :
@[simp]
theorem Int8.ofIntLE_bitVecToInt (n : BitVec 8) :
ofIntLE n.toInt = ofBitVec n
@[simp]
theorem Int16.ofIntLE_bitVecToInt (n : BitVec 16) :
ofIntLE n.toInt = ofBitVec n
@[simp]
theorem Int32.ofIntLE_bitVecToInt (n : BitVec 32) :
ofIntLE n.toInt = ofBitVec n
@[simp]
theorem Int64.ofIntLE_bitVecToInt (n : BitVec 64) :
ofIntLE n.toInt = ofBitVec n
theorem Int8.ofBitVec_ofNatLT (n : Nat) (hn : n < 2 ^ 8) :
theorem Int16.ofBitVec_ofNatLT (n : Nat) (hn : n < 2 ^ 16) :
theorem Int32.ofBitVec_ofNatLT (n : Nat) (hn : n < 2 ^ 32) :
theorem Int64.ofBitVec_ofNatLT (n : Nat) (hn : n < 2 ^ 64) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.toInt_neg (n : Int8) :
(-n).toInt = (-n.toInt).bmod (2 ^ 8)
@[simp]
theorem Int16.toInt_neg (n : Int16) :
(-n).toInt = (-n.toInt).bmod (2 ^ 16)
@[simp]
theorem Int32.toInt_neg (n : Int32) :
(-n).toInt = (-n.toInt).bmod (2 ^ 32)
@[simp]
theorem Int64.toInt_neg (n : Int64) :
(-n).toInt = (-n.toInt).bmod (2 ^ 64)
@[simp]
theorem Int8.not_le {n m : Int8} :
¬n m m < n
@[simp]
theorem Int16.not_le {n m : Int16} :
¬n m m < n
@[simp]
theorem Int32.not_le {n m : Int32} :
¬n m m < n
@[simp]
theorem Int64.not_le {n m : Int64} :
¬n m m < n
@[simp]
theorem ISize.not_le {n m : ISize} :
¬n m m < n
@[simp]
theorem Int8.neg_nonpos_iff (n : Int8) :
-n 0 n = minValue 0 n
@[simp]
theorem Int16.neg_nonpos_iff (n : Int16) :
-n 0 n = minValue 0 n
@[simp]
theorem Int32.neg_nonpos_iff (n : Int32) :
-n 0 n = minValue 0 n
@[simp]
theorem Int64.neg_nonpos_iff (n : Int64) :
-n 0 n = minValue 0 n
@[simp]
theorem ISize.neg_nonpos_iff (n : ISize) :
-n 0 n = minValue 0 n
@[simp]
@[simp]
theorem Int8.toInt_div (a b : Int8) :
(a / b).toInt = (a.toInt.tdiv b.toInt).bmod (2 ^ 8)
@[simp]
theorem Int16.toInt_div (a b : Int16) :
(a / b).toInt = (a.toInt.tdiv b.toInt).bmod (2 ^ 16)
@[simp]
theorem Int32.toInt_div (a b : Int32) :
(a / b).toInt = (a.toInt.tdiv b.toInt).bmod (2 ^ 32)
@[simp]
theorem Int64.toInt_div (a b : Int64) :
(a / b).toInt = (a.toInt.tdiv b.toInt).bmod (2 ^ 64)
@[simp]
theorem Int8.toInt_div_of_ne_right (a b : Int8) (h : b -1) :
(a / b).toInt = a.toInt.tdiv b.toInt
theorem Int16.toInt_div_of_ne_right (a b : Int16) (h : b -1) :
(a / b).toInt = a.toInt.tdiv b.toInt
theorem Int32.toInt_div_of_ne_right (a b : Int32) (h : b -1) :
(a / b).toInt = a.toInt.tdiv b.toInt
theorem Int64.toInt_div_of_ne_right (a b : Int64) (h : b -1) :
(a / b).toInt = a.toInt.tdiv b.toInt
theorem ISize.toInt_div_of_ne_right (a b : ISize) (h : b -1) :
(a / b).toInt = a.toInt.tdiv b.toInt
theorem Int8.toInt16_ne_neg_one (a : Int8) (ha : a -1) :
theorem Int8.toInt32_ne_neg_one (a : Int8) (ha : a -1) :
theorem Int8.toInt64_ne_neg_one (a : Int8) (ha : a -1) :
theorem Int8.toISize_ne_neg_one (a : Int8) (ha : a -1) :
theorem Int16.toInt32_ne_neg_one (a : Int16) (ha : a -1) :
theorem Int16.toInt64_ne_neg_one (a : Int16) (ha : a -1) :
theorem Int16.toISize_ne_neg_one (a : Int16) (ha : a -1) :
theorem Int32.toInt64_ne_neg_one (a : Int32) (ha : a -1) :
theorem Int32.toISize_ne_neg_one (a : Int32) (ha : a -1) :
theorem ISize.toInt64_ne_neg_one (a : ISize) (ha : a -1) :
theorem Int8.toInt16_div_of_ne_right (a b : Int8) (hb : b -1) :
theorem Int8.toInt32_div_of_ne_right (a b : Int8) (hb : b -1) :
theorem Int8.toInt64_div_of_ne_right (a b : Int8) (hb : b -1) :
theorem Int8.toISize_div_of_ne_right (a b : Int8) (hb : b -1) :
theorem Int16.toInt32_div_of_ne_right (a b : Int16) (hb : b -1) :
theorem Int16.toInt64_div_of_ne_right (a b : Int16) (hb : b -1) :
theorem Int16.toISize_div_of_ne_right (a b : Int16) (hb : b -1) :
theorem Int32.toInt64_div_of_ne_right (a b : Int32) (hb : b -1) :
theorem Int32.toISize_div_of_ne_right (a b : Int32) (hb : b -1) :
theorem ISize.toInt64_div_of_ne_right (a b : ISize) (hb : b -1) :
@[simp]
theorem Int8.toInt_add (a b : Int8) :
(a + b).toInt = (a.toInt + b.toInt).bmod (2 ^ 8)
@[simp]
theorem Int16.toInt_add (a b : Int16) :
(a + b).toInt = (a.toInt + b.toInt).bmod (2 ^ 16)
@[simp]
theorem Int32.toInt_add (a b : Int32) :
(a + b).toInt = (a.toInt + b.toInt).bmod (2 ^ 32)
@[simp]
theorem Int64.toInt_add (a b : Int64) :
(a + b).toInt = (a.toInt + b.toInt).bmod (2 ^ 64)
@[simp]
@[simp]
theorem Int16.toInt8_add (a b : Int16) :
(a + b).toInt8 = a.toInt8 + b.toInt8
@[simp]
theorem Int32.toInt8_add (a b : Int32) :
(a + b).toInt8 = a.toInt8 + b.toInt8
@[simp]
theorem Int32.toInt16_add (a b : Int32) :
@[simp]
theorem ISize.toInt8_add (a b : ISize) :
(a + b).toInt8 = a.toInt8 + b.toInt8
@[simp]
theorem ISize.toInt16_add (a b : ISize) :
@[simp]
theorem ISize.toInt32_add (a b : ISize) :
@[simp]
theorem Int64.toInt8_add (a b : Int64) :
(a + b).toInt8 = a.toInt8 + b.toInt8
@[simp]
theorem Int64.toInt16_add (a b : Int64) :
@[simp]
theorem Int64.toInt32_add (a b : Int64) :
@[simp]
theorem Int64.toISize_add (a b : Int64) :
@[simp]
theorem Int8.toInt_mul (a b : Int8) :
(a * b).toInt = (a.toInt * b.toInt).bmod (2 ^ 8)
@[simp]
theorem Int16.toInt_mul (a b : Int16) :
(a * b).toInt = (a.toInt * b.toInt).bmod (2 ^ 16)
@[simp]
theorem Int32.toInt_mul (a b : Int32) :
(a * b).toInt = (a.toInt * b.toInt).bmod (2 ^ 32)
@[simp]
theorem Int64.toInt_mul (a b : Int64) :
(a * b).toInt = (a.toInt * b.toInt).bmod (2 ^ 64)
@[simp]
@[simp]
theorem Int16.toInt8_mul (a b : Int16) :
(a * b).toInt8 = a.toInt8 * b.toInt8
@[simp]
theorem Int32.toInt8_mul (a b : Int32) :
(a * b).toInt8 = a.toInt8 * b.toInt8
@[simp]
theorem Int32.toInt16_mul (a b : Int32) :
@[simp]
theorem ISize.toInt8_mul (a b : ISize) :
(a * b).toInt8 = a.toInt8 * b.toInt8
@[simp]
theorem ISize.toInt16_mul (a b : ISize) :
@[simp]
theorem ISize.toInt32_mul (a b : ISize) :
@[simp]
theorem Int64.toInt8_mul (a b : Int64) :
(a * b).toInt8 = a.toInt8 * b.toInt8
@[simp]
theorem Int64.toInt16_mul (a b : Int64) :
@[simp]
theorem Int64.toInt32_mul (a b : Int64) :
@[simp]
theorem Int64.toISize_mul (a b : Int64) :
theorem Int8.sub_eq_add_neg (a b : Int8) :
a - b = a + -b
theorem Int16.sub_eq_add_neg (a b : Int16) :
a - b = a + -b
theorem Int32.sub_eq_add_neg (a b : Int32) :
a - b = a + -b
theorem Int64.sub_eq_add_neg (a b : Int64) :
a - b = a + -b
theorem ISize.sub_eq_add_neg (a b : ISize) :
a - b = a + -b
@[simp]
theorem Int8.toInt_sub (a b : Int8) :
(a - b).toInt = (a.toInt - b.toInt).bmod (2 ^ 8)
@[simp]
theorem Int16.toInt_sub (a b : Int16) :
(a - b).toInt = (a.toInt - b.toInt).bmod (2 ^ 16)
@[simp]
theorem Int32.toInt_sub (a b : Int32) :
(a - b).toInt = (a.toInt - b.toInt).bmod (2 ^ 32)
@[simp]
theorem Int64.toInt_sub (a b : Int64) :
(a - b).toInt = (a.toInt - b.toInt).bmod (2 ^ 64)
@[simp]
@[simp]
theorem Int16.toInt8_sub (a b : Int16) :
(a - b).toInt8 = a.toInt8 - b.toInt8
@[simp]
theorem Int32.toInt8_sub (a b : Int32) :
(a - b).toInt8 = a.toInt8 - b.toInt8
@[simp]
theorem Int32.toInt16_sub (a b : Int32) :
@[simp]
theorem ISize.toInt8_sub (a b : ISize) :
(a - b).toInt8 = a.toInt8 - b.toInt8
@[simp]
theorem ISize.toInt16_sub (a b : ISize) :
@[simp]
theorem ISize.toInt32_sub (a b : ISize) :
@[simp]
theorem Int64.toInt8_sub (a b : Int64) :
(a - b).toInt8 = a.toInt8 - b.toInt8
@[simp]
theorem Int64.toInt16_sub (a b : Int64) :
@[simp]
theorem Int64.toInt32_sub (a b : Int64) :
@[simp]
theorem Int64.toISize_sub (a b : Int64) :
@[simp]
theorem Int8.toInt16_lt {a b : Int8} :
@[simp]
theorem Int8.toInt32_lt {a b : Int8} :
@[simp]
theorem Int8.toInt64_lt {a b : Int8} :
@[simp]
theorem Int8.toISize_lt {a b : Int8} :
@[simp]
theorem Int16.toInt32_lt {a b : Int16} :
@[simp]
theorem Int16.toInt64_lt {a b : Int16} :
@[simp]
theorem Int16.toISize_lt {a b : Int16} :
@[simp]
theorem Int32.toInt64_lt {a b : Int32} :
@[simp]
theorem Int32.toISize_lt {a b : Int32} :
@[simp]
theorem ISize.toInt64_lt {a b : ISize} :
@[simp]
theorem Int8.toInt16_le {a b : Int8} :
@[simp]
theorem Int8.toInt32_le {a b : Int8} :
@[simp]
theorem Int8.toInt64_le {a b : Int8} :
@[simp]
theorem Int8.toISize_le {a b : Int8} :
@[simp]
theorem Int16.toInt32_le {a b : Int16} :
@[simp]
theorem Int16.toInt64_le {a b : Int16} :
@[simp]
theorem Int16.toISize_le {a b : Int16} :
@[simp]
theorem Int32.toInt64_le {a b : Int32} :
@[simp]
theorem Int32.toISize_le {a b : Int32} :
@[simp]
theorem ISize.toInt64_le {a b : ISize} :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.ofInt_neg (a : Int) :
@[simp]
theorem Int16.ofInt_neg (a : Int) :
@[simp]
theorem Int32.ofInt_neg (a : Int) :
@[simp]
theorem Int64.ofInt_neg (a : Int) :
@[simp]
theorem ISize.ofInt_neg (a : Int) :
theorem Int8.ofInt_eq_iff_bmod_eq_toInt (a : Int) (b : Int8) :
ofInt a = b a.bmod (2 ^ 8) = b.toInt
theorem Int16.ofInt_eq_iff_bmod_eq_toInt (a : Int) (b : Int16) :
ofInt a = b a.bmod (2 ^ 16) = b.toInt
theorem Int32.ofInt_eq_iff_bmod_eq_toInt (a : Int) (b : Int32) :
ofInt a = b a.bmod (2 ^ 32) = b.toInt
theorem Int64.ofInt_eq_iff_bmod_eq_toInt (a : Int) (b : Int64) :
ofInt a = b a.bmod (2 ^ 64) = b.toInt
@[simp]
theorem Int8.ofBitVec_add (a b : BitVec 8) :
@[simp]
theorem Int16.ofBitVec_add (a b : BitVec 16) :
@[simp]
theorem Int32.ofBitVec_add (a b : BitVec 32) :
@[simp]
theorem Int64.ofBitVec_add (a b : BitVec 64) :
@[simp]
theorem Int8.ofInt_add (a b : Int) :
ofInt (a + b) = ofInt a + ofInt b
@[simp]
theorem Int16.ofInt_add (a b : Int) :
ofInt (a + b) = ofInt a + ofInt b
@[simp]
theorem Int32.ofInt_add (a b : Int) :
ofInt (a + b) = ofInt a + ofInt b
@[simp]
theorem Int64.ofInt_add (a b : Int) :
ofInt (a + b) = ofInt a + ofInt b
@[simp]
theorem ISize.ofInt_add (a b : Int) :
ofInt (a + b) = ofInt a + ofInt b
@[simp]
theorem Int8.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem Int16.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem Int32.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem Int64.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
@[simp]
theorem ISize.ofNat_add (a b : Nat) :
ofNat (a + b) = ofNat a + ofNat b
theorem Int8.ofIntLE_add {a b : Int} {hab₁ : minValue.toInt a + b} {hab₂ : a + b maxValue.toInt} :
ofIntLE (a + b) hab₁ hab₂ = ofInt a + ofInt b
theorem Int16.ofIntLE_add {a b : Int} {hab₁ : minValue.toInt a + b} {hab₂ : a + b maxValue.toInt} :
ofIntLE (a + b) hab₁ hab₂ = ofInt a + ofInt b
theorem Int32.ofIntLE_add {a b : Int} {hab₁ : minValue.toInt a + b} {hab₂ : a + b maxValue.toInt} :
ofIntLE (a + b) hab₁ hab₂ = ofInt a + ofInt b
theorem Int64.ofIntLE_add {a b : Int} {hab₁ : minValue.toInt a + b} {hab₂ : a + b maxValue.toInt} :
ofIntLE (a + b) hab₁ hab₂ = ofInt a + ofInt b
theorem ISize.ofIntLE_add {a b : Int} {hab₁ : minValue.toInt a + b} {hab₂ : a + b maxValue.toInt} :
ofIntLE (a + b) hab₁ hab₂ = ofInt a + ofInt b
@[simp]
theorem Int8.ofBitVec_sub (a b : BitVec 8) :
@[simp]
theorem Int16.ofBitVec_sub (a b : BitVec 16) :
@[simp]
theorem Int32.ofBitVec_sub (a b : BitVec 32) :
@[simp]
theorem Int64.ofBitVec_sub (a b : BitVec 64) :
@[simp]
theorem Int8.ofInt_sub (a b : Int) :
ofInt (a - b) = ofInt a - ofInt b
@[simp]
theorem Int16.ofInt_sub (a b : Int) :
ofInt (a - b) = ofInt a - ofInt b
@[simp]
theorem Int32.ofInt_sub (a b : Int) :
ofInt (a - b) = ofInt a - ofInt b
@[simp]
theorem Int64.ofInt_sub (a b : Int) :
ofInt (a - b) = ofInt a - ofInt b
@[simp]
theorem ISize.ofInt_sub (a b : Int) :
ofInt (a - b) = ofInt a - ofInt b
@[simp]
theorem Int8.ofNat_sub (a b : Nat) (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
@[simp]
theorem Int16.ofNat_sub (a b : Nat) (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
@[simp]
theorem Int32.ofNat_sub (a b : Nat) (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
@[simp]
theorem Int64.ofNat_sub (a b : Nat) (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
@[simp]
theorem ISize.ofNat_sub (a b : Nat) (hab : b a) :
ofNat (a - b) = ofNat a - ofNat b
theorem Int8.ofIntLE_sub {a b : Int} {hab₁ : minValue.toInt a - b} {hab₂ : a - b maxValue.toInt} :
ofIntLE (a - b) hab₁ hab₂ = ofInt a - ofInt b
theorem Int16.ofIntLE_sub {a b : Int} {hab₁ : minValue.toInt a - b} {hab₂ : a - b maxValue.toInt} :
ofIntLE (a - b) hab₁ hab₂ = ofInt a - ofInt b
theorem Int32.ofIntLE_sub {a b : Int} {hab₁ : minValue.toInt a - b} {hab₂ : a - b maxValue.toInt} :
ofIntLE (a - b) hab₁ hab₂ = ofInt a - ofInt b
theorem Int64.ofIntLE_sub {a b : Int} {hab₁ : minValue.toInt a - b} {hab₂ : a - b maxValue.toInt} :
ofIntLE (a - b) hab₁ hab₂ = ofInt a - ofInt b
theorem ISize.ofIntLE_sub {a b : Int} {hab₁ : minValue.toInt a - b} {hab₂ : a - b maxValue.toInt} :
ofIntLE (a - b) hab₁ hab₂ = ofInt a - ofInt b
@[simp]
theorem Int8.ofBitVec_mul (a b : BitVec 8) :
@[simp]
theorem Int16.ofBitVec_mul (a b : BitVec 16) :
@[simp]
theorem Int32.ofBitVec_mul (a b : BitVec 32) :
@[simp]
theorem Int64.ofBitVec_mul (a b : BitVec 64) :
@[simp]
theorem Int8.ofInt_mul (a b : Int) :
ofInt (a * b) = ofInt a * ofInt b
@[simp]
theorem Int16.ofInt_mul (a b : Int) :
ofInt (a * b) = ofInt a * ofInt b
@[simp]
theorem Int32.ofInt_mul (a b : Int) :
ofInt (a * b) = ofInt a * ofInt b
@[simp]
theorem Int64.ofInt_mul (a b : Int) :
ofInt (a * b) = ofInt a * ofInt b
@[simp]
theorem ISize.ofInt_mul (a b : Int) :
ofInt (a * b) = ofInt a * ofInt b
@[simp]
theorem Int8.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem Int16.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem Int32.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem Int64.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
@[simp]
theorem ISize.ofNat_mul (a b : Nat) :
ofNat (a * b) = ofNat a * ofNat b
theorem Int8.ofIntLE_mul {a b : Int} {hab₁ : minValue.toInt a * b} {hab₂ : a * b maxValue.toInt} :
ofIntLE (a * b) hab₁ hab₂ = ofInt a * ofInt b
theorem Int16.ofIntLE_mul {a b : Int} {hab₁ : minValue.toInt a * b} {hab₂ : a * b maxValue.toInt} :
ofIntLE (a * b) hab₁ hab₂ = ofInt a * ofInt b
theorem Int32.ofIntLE_mul {a b : Int} {hab₁ : minValue.toInt a * b} {hab₂ : a * b maxValue.toInt} :
ofIntLE (a * b) hab₁ hab₂ = ofInt a * ofInt b
theorem Int64.ofIntLE_mul {a b : Int} {hab₁ : minValue.toInt a * b} {hab₂ : a * b maxValue.toInt} :
ofIntLE (a * b) hab₁ hab₂ = ofInt a * ofInt b
theorem ISize.ofIntLE_mul {a b : Int} {hab₁ : minValue.toInt a * b} {hab₂ : a * b maxValue.toInt} :
ofIntLE (a * b) hab₁ hab₂ = ofInt a * ofInt b
@[simp]
theorem Int8.ofBitVec_sdiv (a b : BitVec 8) :
@[simp]
theorem Int16.ofBitVec_sdiv (a b : BitVec 16) :
@[simp]
theorem Int32.ofBitVec_sdiv (a b : BitVec 32) :
@[simp]
theorem Int64.ofBitVec_sdiv (a b : BitVec 64) :
theorem Int8.ofInt_tdiv {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofInt a / ofInt b
theorem Int16.ofInt_tdiv {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofInt a / ofInt b
theorem Int32.ofInt_tdiv {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofInt a / ofInt b
theorem Int64.ofInt_tdiv {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofInt a / ofInt b
theorem ISize.ofInt_tdiv {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofInt a / ofInt b
theorem Int8.ofInt_eq_ofIntLE_div {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofIntLE a ha₁ ha₂ / ofIntLE b hb₁ hb₂
theorem Int16.ofInt_eq_ofIntLE_div {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofIntLE a ha₁ ha₂ / ofIntLE b hb₁ hb₂
theorem Int32.ofInt_eq_ofIntLE_div {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofIntLE a ha₁ ha₂ / ofIntLE b hb₁ hb₂
theorem Int64.ofInt_eq_ofIntLE_div {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofIntLE a ha₁ ha₂ / ofIntLE b hb₁ hb₂
theorem ISize.ofInt_eq_ofIntLE_div {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tdiv b) = ofIntLE a ha₁ ha₂ / ofIntLE b hb₁ hb₂
theorem Int8.ofNat_div {a b : Nat} (ha : a < 2 ^ 7) (hb : b < 2 ^ 7) :
ofNat (a / b) = ofNat a / ofNat b
theorem Int16.ofNat_div {a b : Nat} (ha : a < 2 ^ 15) (hb : b < 2 ^ 15) :
ofNat (a / b) = ofNat a / ofNat b
theorem Int32.ofNat_div {a b : Nat} (ha : a < 2 ^ 31) (hb : b < 2 ^ 31) :
ofNat (a / b) = ofNat a / ofNat b
theorem Int64.ofNat_div {a b : Nat} (ha : a < 2 ^ 63) (hb : b < 2 ^ 63) :
ofNat (a / b) = ofNat a / ofNat b
theorem ISize.ofNat_div {a b : Nat} (ha : a < 2 ^ (System.Platform.numBits - 1)) (hb : b < 2 ^ (System.Platform.numBits - 1)) :
ofNat (a / b) = ofNat a / ofNat b
@[simp]
theorem Int8.ofBitVec_srem (a b : BitVec 8) :
@[simp]
theorem Int16.ofBitVec_srem (a b : BitVec 16) :
@[simp]
theorem Int32.ofBitVec_srem (a b : BitVec 32) :
@[simp]
theorem Int64.ofBitVec_srem (a b : BitVec 64) :
@[simp]
theorem Int8.ofIntLE_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ ofIntLE b hb₁ hb₂ a b
theorem Int16.ofIntLE_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ ofIntLE b hb₁ hb₂ a b
theorem Int32.ofIntLE_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ ofIntLE b hb₁ hb₂ a b
theorem Int64.ofIntLE_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ ofIntLE b hb₁ hb₂ a b
theorem ISize.ofIntLE_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ ofIntLE b hb₁ hb₂ a b
theorem Int8.ofInt_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
theorem Int16.ofInt_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
theorem Int32.ofInt_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
theorem Int64.ofInt_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
theorem ISize.ofInt_le_iff_le {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
theorem Int8.ofNat_le_iff_le {a b : Nat} (ha : a < 2 ^ 7) (hb : b < 2 ^ 7) :
theorem Int16.ofNat_le_iff_le {a b : Nat} (ha : a < 2 ^ 15) (hb : b < 2 ^ 15) :
theorem Int32.ofNat_le_iff_le {a b : Nat} (ha : a < 2 ^ 31) (hb : b < 2 ^ 31) :
theorem Int64.ofNat_le_iff_le {a b : Nat} (ha : a < 2 ^ 63) (hb : b < 2 ^ 63) :
theorem ISize.ofNat_le_iff_le {a b : Nat} (ha : a < 2 ^ (System.Platform.numBits - 1)) (hb : b < 2 ^ (System.Platform.numBits - 1)) :
theorem Int8.ofIntLE_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ < ofIntLE b hb₁ hb₂ a < b
theorem Int16.ofIntLE_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ < ofIntLE b hb₁ hb₂ a < b
theorem Int32.ofIntLE_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ < ofIntLE b hb₁ hb₂ a < b
theorem Int64.ofIntLE_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ < ofIntLE b hb₁ hb₂ a < b
theorem ISize.ofIntLE_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofIntLE a ha₁ ha₂ < ofIntLE b hb₁ hb₂ a < b
theorem Int8.ofInt_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt a < ofInt b a < b
theorem Int16.ofInt_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt a < ofInt b a < b
theorem Int32.ofInt_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt a < ofInt b a < b
theorem Int64.ofInt_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt a < ofInt b a < b
theorem ISize.ofInt_lt_iff_lt {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt a < ofInt b a < b
theorem Int8.ofNat_lt_iff_lt {a b : Nat} (ha : a < 2 ^ 7) (hb : b < 2 ^ 7) :
ofNat a < ofNat b a < b
theorem Int16.ofNat_lt_iff_lt {a b : Nat} (ha : a < 2 ^ 15) (hb : b < 2 ^ 15) :
ofNat a < ofNat b a < b
theorem Int32.ofNat_lt_iff_lt {a b : Nat} (ha : a < 2 ^ 31) (hb : b < 2 ^ 31) :
ofNat a < ofNat b a < b
theorem Int64.ofNat_lt_iff_lt {a b : Nat} (ha : a < 2 ^ 63) (hb : b < 2 ^ 63) :
ofNat a < ofNat b a < b
theorem ISize.ofNat_lt_iff_lt {a b : Nat} (ha : a < 2 ^ (System.Platform.numBits - 1)) (hb : b < 2 ^ (System.Platform.numBits - 1)) :
ofNat a < ofNat b a < b
theorem Int8.add_assoc (a b c : Int8) :
a + b + c = a + (b + c)
theorem Int16.add_assoc (a b c : Int16) :
a + b + c = a + (b + c)
theorem Int32.add_assoc (a b c : Int32) :
a + b + c = a + (b + c)
theorem Int64.add_assoc (a b c : Int64) :
a + b + c = a + (b + c)
theorem ISize.add_assoc (a b c : ISize) :
a + b + c = a + (b + c)
instance instAssociativeInt8HAdd :
Std.Associative fun (x1 x2 : Int8) => x1 + x2
instance instAssociativeInt16HAdd :
Std.Associative fun (x1 x2 : Int16) => x1 + x2
instance instAssociativeInt32HAdd :
Std.Associative fun (x1 x2 : Int32) => x1 + x2
instance instAssociativeInt64HAdd :
Std.Associative fun (x1 x2 : Int64) => x1 + x2
instance instAssociativeISizeHAdd :
Std.Associative fun (x1 x2 : ISize) => x1 + x2
theorem Int8.add_comm (a b : Int8) :
a + b = b + a
theorem Int16.add_comm (a b : Int16) :
a + b = b + a
theorem Int32.add_comm (a b : Int32) :
a + b = b + a
theorem Int64.add_comm (a b : Int64) :
a + b = b + a
theorem ISize.add_comm (a b : ISize) :
a + b = b + a
instance instCommutativeInt8HAdd :
Std.Commutative fun (x1 x2 : Int8) => x1 + x2
instance instCommutativeInt16HAdd :
Std.Commutative fun (x1 x2 : Int16) => x1 + x2
instance instCommutativeInt32HAdd :
Std.Commutative fun (x1 x2 : Int32) => x1 + x2
instance instCommutativeInt64HAdd :
Std.Commutative fun (x1 x2 : Int64) => x1 + x2
instance instCommutativeISizeHAdd :
Std.Commutative fun (x1 x2 : ISize) => x1 + x2
@[simp]
theorem Int8.add_zero (a : Int8) :
a + 0 = a
@[simp]
theorem Int16.add_zero (a : Int16) :
a + 0 = a
@[simp]
theorem Int32.add_zero (a : Int32) :
a + 0 = a
@[simp]
theorem Int64.add_zero (a : Int64) :
a + 0 = a
@[simp]
theorem ISize.add_zero (a : ISize) :
a + 0 = a
@[simp]
theorem Int8.zero_add (a : Int8) :
0 + a = a
@[simp]
theorem Int16.zero_add (a : Int16) :
0 + a = a
@[simp]
theorem Int32.zero_add (a : Int32) :
0 + a = a
@[simp]
theorem Int64.zero_add (a : Int64) :
0 + a = a
@[simp]
theorem ISize.zero_add (a : ISize) :
0 + a = a
instance instLawfulIdentityInt8HAddOfNat :
Std.LawfulIdentity (fun (x1 x2 : Int8) => x1 + x2) 0
@[simp]
theorem Int8.sub_zero (a : Int8) :
a - 0 = a
@[simp]
theorem Int16.sub_zero (a : Int16) :
a - 0 = a
@[simp]
theorem Int32.sub_zero (a : Int32) :
a - 0 = a
@[simp]
theorem Int64.sub_zero (a : Int64) :
a - 0 = a
@[simp]
theorem ISize.sub_zero (a : ISize) :
a - 0 = a
@[simp]
theorem Int8.zero_sub (a : Int8) :
0 - a = -a
@[simp]
theorem Int16.zero_sub (a : Int16) :
0 - a = -a
@[simp]
theorem Int32.zero_sub (a : Int32) :
0 - a = -a
@[simp]
theorem Int64.zero_sub (a : Int64) :
0 - a = -a
@[simp]
theorem ISize.zero_sub (a : ISize) :
0 - a = -a
@[simp]
theorem Int8.sub_self (a : Int8) :
a - a = 0
@[simp]
theorem Int16.sub_self (a : Int16) :
a - a = 0
@[simp]
theorem Int32.sub_self (a : Int32) :
a - a = 0
@[simp]
theorem Int64.sub_self (a : Int64) :
a - a = 0
@[simp]
theorem ISize.sub_self (a : ISize) :
a - a = 0
@[simp]
theorem Int8.sub_add_cancel (a b : Int8) :
a - b + b = a
@[simp]
theorem Int16.sub_add_cancel (a b : Int16) :
a - b + b = a
@[simp]
theorem Int32.sub_add_cancel (a b : Int32) :
a - b + b = a
@[simp]
theorem Int64.sub_add_cancel (a b : Int64) :
a - b + b = a
@[simp]
theorem ISize.sub_add_cancel (a b : ISize) :
a - b + b = a
theorem Int8.eq_sub_iff_add_eq {a b c : Int8} :
a = c - b a + b = c
theorem Int16.eq_sub_iff_add_eq {a b c : Int16} :
a = c - b a + b = c
theorem Int32.eq_sub_iff_add_eq {a b c : Int32} :
a = c - b a + b = c
theorem Int64.eq_sub_iff_add_eq {a b c : Int64} :
a = c - b a + b = c
theorem ISize.eq_sub_iff_add_eq {a b c : ISize} :
a = c - b a + b = c
theorem Int8.sub_eq_iff_eq_add {a b c : Int8} :
a - b = c a = c + b
theorem Int16.sub_eq_iff_eq_add {a b c : Int16} :
a - b = c a = c + b
theorem Int32.sub_eq_iff_eq_add {a b c : Int32} :
a - b = c a = c + b
theorem Int64.sub_eq_iff_eq_add {a b c : Int64} :
a - b = c a = c + b
theorem ISize.sub_eq_iff_eq_add {a b c : ISize} :
a - b = c a = c + b
@[simp]
theorem Int8.neg_neg {a : Int8} :
- -a = a
@[simp]
theorem Int16.neg_neg {a : Int16} :
- -a = a
@[simp]
theorem Int32.neg_neg {a : Int32} :
- -a = a
@[simp]
theorem Int64.neg_neg {a : Int64} :
- -a = a
@[simp]
theorem ISize.neg_neg {a : ISize} :
- -a = a
@[simp]
theorem Int8.neg_inj {a b : Int8} :
-a = -b a = b
@[simp]
theorem Int16.neg_inj {a b : Int16} :
-a = -b a = b
@[simp]
theorem Int32.neg_inj {a b : Int32} :
-a = -b a = b
@[simp]
theorem Int64.neg_inj {a b : Int64} :
-a = -b a = b
@[simp]
theorem ISize.neg_inj {a b : ISize} :
-a = -b a = b
@[simp]
theorem Int8.neg_ne_zero {a : Int8} :
-a 0 a 0
@[simp]
theorem Int16.neg_ne_zero {a : Int16} :
-a 0 a 0
@[simp]
theorem Int32.neg_ne_zero {a : Int32} :
-a 0 a 0
@[simp]
theorem Int64.neg_ne_zero {a : Int64} :
-a 0 a 0
@[simp]
theorem ISize.neg_ne_zero {a : ISize} :
-a 0 a 0
theorem Int8.neg_add {a b : Int8} :
-(a + b) = -a - b
theorem Int16.neg_add {a b : Int16} :
-(a + b) = -a - b
theorem Int32.neg_add {a b : Int32} :
-(a + b) = -a - b
theorem Int64.neg_add {a b : Int64} :
-(a + b) = -a - b
theorem ISize.neg_add {a b : ISize} :
-(a + b) = -a - b
@[simp]
theorem Int8.sub_neg {a b : Int8} :
a - -b = a + b
@[simp]
theorem Int16.sub_neg {a b : Int16} :
a - -b = a + b
@[simp]
theorem Int32.sub_neg {a b : Int32} :
a - -b = a + b
@[simp]
theorem Int64.sub_neg {a b : Int64} :
a - -b = a + b
@[simp]
theorem ISize.sub_neg {a b : ISize} :
a - -b = a + b
@[simp]
theorem Int8.neg_sub {a b : Int8} :
-(a - b) = b - a
@[simp]
theorem Int16.neg_sub {a b : Int16} :
-(a - b) = b - a
@[simp]
theorem Int32.neg_sub {a b : Int32} :
-(a - b) = b - a
@[simp]
theorem Int64.neg_sub {a b : Int64} :
-(a - b) = b - a
@[simp]
theorem ISize.neg_sub {a b : ISize} :
-(a - b) = b - a
@[simp]
theorem Int8.add_left_inj {a b : Int8} (c : Int8) :
a + c = b + c a = b
@[simp]
theorem Int16.add_left_inj {a b : Int16} (c : Int16) :
a + c = b + c a = b
@[simp]
theorem Int32.add_left_inj {a b : Int32} (c : Int32) :
a + c = b + c a = b
@[simp]
theorem Int64.add_left_inj {a b : Int64} (c : Int64) :
a + c = b + c a = b
@[simp]
theorem ISize.add_left_inj {a b : ISize} (c : ISize) :
a + c = b + c a = b
@[simp]
theorem Int8.add_right_inj {a b : Int8} (c : Int8) :
c + a = c + b a = b
@[simp]
theorem Int16.add_right_inj {a b : Int16} (c : Int16) :
c + a = c + b a = b
@[simp]
theorem Int32.add_right_inj {a b : Int32} (c : Int32) :
c + a = c + b a = b
@[simp]
theorem Int64.add_right_inj {a b : Int64} (c : Int64) :
c + a = c + b a = b
@[simp]
theorem ISize.add_right_inj {a b : ISize} (c : ISize) :
c + a = c + b a = b
@[simp]
theorem Int8.sub_left_inj {a b : Int8} (c : Int8) :
a - c = b - c a = b
@[simp]
theorem Int16.sub_left_inj {a b : Int16} (c : Int16) :
a - c = b - c a = b
@[simp]
theorem Int32.sub_left_inj {a b : Int32} (c : Int32) :
a - c = b - c a = b
@[simp]
theorem Int64.sub_left_inj {a b : Int64} (c : Int64) :
a - c = b - c a = b
@[simp]
theorem ISize.sub_left_inj {a b : ISize} (c : ISize) :
a - c = b - c a = b
@[simp]
theorem Int8.sub_right_inj {a b : Int8} (c : Int8) :
c - a = c - b a = b
@[simp]
theorem Int16.sub_right_inj {a b : Int16} (c : Int16) :
c - a = c - b a = b
@[simp]
theorem Int32.sub_right_inj {a b : Int32} (c : Int32) :
c - a = c - b a = b
@[simp]
theorem Int64.sub_right_inj {a b : Int64} (c : Int64) :
c - a = c - b a = b
@[simp]
theorem ISize.sub_right_inj {a b : ISize} (c : ISize) :
c - a = c - b a = b
@[simp]
theorem Int8.add_eq_right {a b : Int8} :
a + b = b a = 0
@[simp]
theorem Int16.add_eq_right {a b : Int16} :
a + b = b a = 0
@[simp]
theorem Int32.add_eq_right {a b : Int32} :
a + b = b a = 0
@[simp]
theorem Int64.add_eq_right {a b : Int64} :
a + b = b a = 0
@[simp]
theorem ISize.add_eq_right {a b : ISize} :
a + b = b a = 0
@[simp]
theorem Int8.add_eq_left {a b : Int8} :
a + b = a b = 0
@[simp]
theorem Int16.add_eq_left {a b : Int16} :
a + b = a b = 0
@[simp]
theorem Int32.add_eq_left {a b : Int32} :
a + b = a b = 0
@[simp]
theorem Int64.add_eq_left {a b : Int64} :
a + b = a b = 0
@[simp]
theorem ISize.add_eq_left {a b : ISize} :
a + b = a b = 0
@[simp]
theorem Int8.right_eq_add {a b : Int8} :
b = a + b a = 0
@[simp]
theorem Int16.right_eq_add {a b : Int16} :
b = a + b a = 0
@[simp]
theorem Int32.right_eq_add {a b : Int32} :
b = a + b a = 0
@[simp]
theorem Int64.right_eq_add {a b : Int64} :
b = a + b a = 0
@[simp]
theorem ISize.right_eq_add {a b : ISize} :
b = a + b a = 0
@[simp]
theorem Int8.left_eq_add {a b : Int8} :
a = a + b b = 0
@[simp]
theorem Int16.left_eq_add {a b : Int16} :
a = a + b b = 0
@[simp]
theorem Int32.left_eq_add {a b : Int32} :
a = a + b b = 0
@[simp]
theorem Int64.left_eq_add {a b : Int64} :
a = a + b b = 0
@[simp]
theorem ISize.left_eq_add {a b : ISize} :
a = a + b b = 0
theorem Int8.mul_comm (a b : Int8) :
a * b = b * a
theorem Int16.mul_comm (a b : Int16) :
a * b = b * a
theorem Int32.mul_comm (a b : Int32) :
a * b = b * a
theorem Int64.mul_comm (a b : Int64) :
a * b = b * a
theorem ISize.mul_comm (a b : ISize) :
a * b = b * a
instance instCommutativeInt8HMul :
Std.Commutative fun (x1 x2 : Int8) => x1 * x2
instance instCommutativeInt16HMul :
Std.Commutative fun (x1 x2 : Int16) => x1 * x2
instance instCommutativeInt32HMul :
Std.Commutative fun (x1 x2 : Int32) => x1 * x2
instance instCommutativeInt64HMul :
Std.Commutative fun (x1 x2 : Int64) => x1 * x2
instance instCommutativeISizeHMul :
Std.Commutative fun (x1 x2 : ISize) => x1 * x2
theorem Int8.mul_assoc (a b c : Int8) :
a * b * c = a * (b * c)
theorem Int16.mul_assoc (a b c : Int16) :
a * b * c = a * (b * c)
theorem Int32.mul_assoc (a b c : Int32) :
a * b * c = a * (b * c)
theorem Int64.mul_assoc (a b c : Int64) :
a * b * c = a * (b * c)
theorem ISize.mul_assoc (a b c : ISize) :
a * b * c = a * (b * c)
instance instAssociativeInt8HMul :
Std.Associative fun (x1 x2 : Int8) => x1 * x2
instance instAssociativeInt16HMul :
Std.Associative fun (x1 x2 : Int16) => x1 * x2
instance instAssociativeInt32HMul :
Std.Associative fun (x1 x2 : Int32) => x1 * x2
instance instAssociativeInt64HMul :
Std.Associative fun (x1 x2 : Int64) => x1 * x2
instance instAssociativeISizeHMul :
Std.Associative fun (x1 x2 : ISize) => x1 * x2
@[simp]
theorem Int8.mul_one (a : Int8) :
a * 1 = a
@[simp]
theorem Int16.mul_one (a : Int16) :
a * 1 = a
@[simp]
theorem Int32.mul_one (a : Int32) :
a * 1 = a
@[simp]
theorem Int64.mul_one (a : Int64) :
a * 1 = a
@[simp]
theorem ISize.mul_one (a : ISize) :
a * 1 = a
@[simp]
theorem Int8.one_mul (a : Int8) :
1 * a = a
@[simp]
theorem Int16.one_mul (a : Int16) :
1 * a = a
@[simp]
theorem Int32.one_mul (a : Int32) :
1 * a = a
@[simp]
theorem Int64.one_mul (a : Int64) :
1 * a = a
@[simp]
theorem ISize.one_mul (a : ISize) :
1 * a = a
@[simp]
theorem Int8.mul_zero {a : Int8} :
a * 0 = 0
@[simp]
theorem Int16.mul_zero {a : Int16} :
a * 0 = 0
@[simp]
theorem Int32.mul_zero {a : Int32} :
a * 0 = 0
@[simp]
theorem Int64.mul_zero {a : Int64} :
a * 0 = 0
@[simp]
theorem ISize.mul_zero {a : ISize} :
a * 0 = 0
@[simp]
theorem Int8.zero_mul {a : Int8} :
0 * a = 0
@[simp]
theorem Int16.zero_mul {a : Int16} :
0 * a = 0
@[simp]
theorem Int32.zero_mul {a : Int32} :
0 * a = 0
@[simp]
theorem Int64.zero_mul {a : Int64} :
0 * a = 0
@[simp]
theorem ISize.zero_mul {a : ISize} :
0 * a = 0
theorem Int8.mul_add {a b c : Int8} :
a * (b + c) = a * b + a * c
theorem Int16.mul_add {a b c : Int16} :
a * (b + c) = a * b + a * c
theorem Int32.mul_add {a b c : Int32} :
a * (b + c) = a * b + a * c
theorem Int64.mul_add {a b c : Int64} :
a * (b + c) = a * b + a * c
theorem ISize.mul_add {a b c : ISize} :
a * (b + c) = a * b + a * c
theorem Int8.add_mul {a b c : Int8} :
(a + b) * c = a * c + b * c
theorem Int16.add_mul {a b c : Int16} :
(a + b) * c = a * c + b * c
theorem Int32.add_mul {a b c : Int32} :
(a + b) * c = a * c + b * c
theorem Int64.add_mul {a b c : Int64} :
(a + b) * c = a * c + b * c
theorem ISize.add_mul {a b c : ISize} :
(a + b) * c = a * c + b * c
theorem Int8.mul_succ {a b : Int8} :
a * (b + 1) = a * b + a
theorem Int16.mul_succ {a b : Int16} :
a * (b + 1) = a * b + a
theorem Int32.mul_succ {a b : Int32} :
a * (b + 1) = a * b + a
theorem Int64.mul_succ {a b : Int64} :
a * (b + 1) = a * b + a
theorem ISize.mul_succ {a b : ISize} :
a * (b + 1) = a * b + a
theorem Int8.succ_mul {a b : Int8} :
(a + 1) * b = a * b + b
theorem Int16.succ_mul {a b : Int16} :
(a + 1) * b = a * b + b
theorem Int32.succ_mul {a b : Int32} :
(a + 1) * b = a * b + b
theorem Int64.succ_mul {a b : Int64} :
(a + 1) * b = a * b + b
theorem ISize.succ_mul {a b : ISize} :
(a + 1) * b = a * b + b
theorem Int8.two_mul {a : Int8} :
2 * a = a + a
theorem Int16.two_mul {a : Int16} :
2 * a = a + a
theorem Int32.two_mul {a : Int32} :
2 * a = a + a
theorem Int64.two_mul {a : Int64} :
2 * a = a + a
theorem ISize.two_mul {a : ISize} :
2 * a = a + a
theorem Int8.mul_two {a : Int8} :
a * 2 = a + a
theorem Int16.mul_two {a : Int16} :
a * 2 = a + a
theorem Int32.mul_two {a : Int32} :
a * 2 = a + a
theorem Int64.mul_two {a : Int64} :
a * 2 = a + a
theorem ISize.mul_two {a : ISize} :
a * 2 = a + a
theorem Int8.neg_mul (a b : Int8) :
-a * b = -(a * b)
theorem Int16.neg_mul (a b : Int16) :
-a * b = -(a * b)
theorem Int32.neg_mul (a b : Int32) :
-a * b = -(a * b)
theorem Int64.neg_mul (a b : Int64) :
-a * b = -(a * b)
theorem ISize.neg_mul (a b : ISize) :
-a * b = -(a * b)
theorem Int8.mul_neg (a b : Int8) :
a * -b = -(a * b)
theorem Int16.mul_neg (a b : Int16) :
a * -b = -(a * b)
theorem Int32.mul_neg (a b : Int32) :
a * -b = -(a * b)
theorem Int64.mul_neg (a b : Int64) :
a * -b = -(a * b)
theorem ISize.mul_neg (a b : ISize) :
a * -b = -(a * b)
theorem Int8.neg_mul_neg (a b : Int8) :
-a * -b = a * b
theorem Int16.neg_mul_neg (a b : Int16) :
-a * -b = a * b
theorem Int32.neg_mul_neg (a b : Int32) :
-a * -b = a * b
theorem Int64.neg_mul_neg (a b : Int64) :
-a * -b = a * b
theorem ISize.neg_mul_neg (a b : ISize) :
-a * -b = a * b
theorem Int8.neg_mul_comm (a b : Int8) :
-a * b = a * -b
theorem Int16.neg_mul_comm (a b : Int16) :
-a * b = a * -b
theorem Int32.neg_mul_comm (a b : Int32) :
-a * b = a * -b
theorem Int64.neg_mul_comm (a b : Int64) :
-a * b = a * -b
theorem ISize.neg_mul_comm (a b : ISize) :
-a * b = a * -b
theorem Int8.mul_sub {a b c : Int8} :
a * (b - c) = a * b - a * c
theorem Int16.mul_sub {a b c : Int16} :
a * (b - c) = a * b - a * c
theorem Int32.mul_sub {a b c : Int32} :
a * (b - c) = a * b - a * c
theorem Int64.mul_sub {a b c : Int64} :
a * (b - c) = a * b - a * c
theorem ISize.mul_sub {a b c : ISize} :
a * (b - c) = a * b - a * c
theorem Int8.sub_mul {a b c : Int8} :
(a - b) * c = a * c - b * c
theorem Int16.sub_mul {a b c : Int16} :
(a - b) * c = a * c - b * c
theorem Int32.sub_mul {a b c : Int32} :
(a - b) * c = a * c - b * c
theorem Int64.sub_mul {a b c : Int64} :
(a - b) * c = a * c - b * c
theorem ISize.sub_mul {a b c : ISize} :
(a - b) * c = a * c - b * c
theorem Int8.neg_add_mul_eq_mul_not {a b : Int8} :
-(a + a * b) = a * ~~~b
theorem Int16.neg_add_mul_eq_mul_not {a b : Int16} :
-(a + a * b) = a * ~~~b
theorem Int32.neg_add_mul_eq_mul_not {a b : Int32} :
-(a + a * b) = a * ~~~b
theorem Int64.neg_add_mul_eq_mul_not {a b : Int64} :
-(a + a * b) = a * ~~~b
theorem ISize.neg_add_mul_eq_mul_not {a b : ISize} :
-(a + a * b) = a * ~~~b
theorem Int8.neg_mul_not_eq_add_mul {a b : Int8} :
-(a * ~~~b) = a + a * b
theorem Int16.neg_mul_not_eq_add_mul {a b : Int16} :
-(a * ~~~b) = a + a * b
theorem Int32.neg_mul_not_eq_add_mul {a b : Int32} :
-(a * ~~~b) = a + a * b
theorem Int64.neg_mul_not_eq_add_mul {a b : Int64} :
-(a * ~~~b) = a + a * b
theorem ISize.neg_mul_not_eq_add_mul {a b : ISize} :
-(a * ~~~b) = a + a * b
theorem Int8.le_of_lt {a b : Int8} :
a < ba b
theorem Int16.le_of_lt {a b : Int16} :
a < ba b
theorem Int32.le_of_lt {a b : Int32} :
a < ba b
theorem Int64.le_of_lt {a b : Int64} :
a < ba b
theorem ISize.le_of_lt {a b : ISize} :
a < ba b
theorem Int8.lt_of_le_of_ne {a b : Int8} :
a ba ba < b
theorem Int16.lt_of_le_of_ne {a b : Int16} :
a ba ba < b
theorem Int32.lt_of_le_of_ne {a b : Int32} :
a ba ba < b
theorem Int64.lt_of_le_of_ne {a b : Int64} :
a ba ba < b
theorem ISize.lt_of_le_of_ne {a b : ISize} :
a ba ba < b
theorem Int8.lt_iff_le_and_ne {a b : Int8} :
a < b a b a b
theorem Int16.lt_iff_le_and_ne {a b : Int16} :
a < b a b a b
theorem Int32.lt_iff_le_and_ne {a b : Int32} :
a < b a b a b
theorem Int64.lt_iff_le_and_ne {a b : Int64} :
a < b a b a b
theorem ISize.lt_iff_le_and_ne {a b : ISize} :
a < b a b a b
@[simp]
theorem Int8.lt_irrefl {a : Int8} :
¬a < a
@[simp]
theorem Int16.lt_irrefl {a : Int16} :
¬a < a
@[simp]
theorem Int32.lt_irrefl {a : Int32} :
¬a < a
@[simp]
theorem Int64.lt_irrefl {a : Int64} :
¬a < a
@[simp]
theorem ISize.lt_irrefl {a : ISize} :
¬a < a
theorem Int8.lt_of_le_of_lt {a b c : Int8} :
a bb < ca < c
theorem Int16.lt_of_le_of_lt {a b c : Int16} :
a bb < ca < c
theorem Int32.lt_of_le_of_lt {a b c : Int32} :
a bb < ca < c
theorem Int64.lt_of_le_of_lt {a b c : Int64} :
a bb < ca < c
theorem ISize.lt_of_le_of_lt {a b c : ISize} :
a bb < ca < c
theorem Int8.lt_of_lt_of_le {a b c : Int8} :
a < bb ca < c
theorem Int16.lt_of_lt_of_le {a b c : Int16} :
a < bb ca < c
theorem Int32.lt_of_lt_of_le {a b c : Int32} :
a < bb ca < c
theorem Int64.lt_of_lt_of_le {a b c : Int64} :
a < bb ca < c
theorem ISize.lt_of_lt_of_le {a b c : ISize} :
a < bb ca < c
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.le_refl (a : Int8) :
a a
@[simp]
theorem Int16.le_refl (a : Int16) :
a a
@[simp]
theorem Int32.le_refl (a : Int32) :
a a
@[simp]
theorem Int64.le_refl (a : Int64) :
a a
@[simp]
theorem ISize.le_refl (a : ISize) :
a a
theorem Int8.le_rfl {a : Int8} :
a a
theorem Int16.le_rfl {a : Int16} :
a a
theorem Int32.le_rfl {a : Int32} :
a a
theorem Int64.le_rfl {a : Int64} :
a a
theorem ISize.le_rfl {a : ISize} :
a a
theorem Int8.le_antisymm_iff {a b : Int8} :
a = b a b b a
theorem Int16.le_antisymm_iff {a b : Int16} :
a = b a b b a
theorem Int32.le_antisymm_iff {a b : Int32} :
a = b a b b a
theorem Int64.le_antisymm_iff {a b : Int64} :
a = b a b b a
theorem ISize.le_antisymm_iff {a b : ISize} :
a = b a b b a
theorem Int8.le_antisymm {a b : Int8} :
a bb aa = b
theorem Int16.le_antisymm {a b : Int16} :
a bb aa = b
theorem Int32.le_antisymm {a b : Int32} :
a bb aa = b
theorem Int64.le_antisymm {a b : Int64} :
a bb aa = b
theorem ISize.le_antisymm {a b : ISize} :
a bb aa = b
@[simp]
theorem Int8.zero_div {a : Int8} :
0 / a = 0
@[simp]
theorem Int16.zero_div {a : Int16} :
0 / a = 0
@[simp]
theorem Int32.zero_div {a : Int32} :
0 / a = 0
@[simp]
theorem Int64.zero_div {a : Int64} :
0 / a = 0
@[simp]
theorem ISize.zero_div {a : ISize} :
0 / a = 0
@[simp]
theorem Int8.div_zero {a : Int8} :
a / 0 = 0
@[simp]
theorem Int16.div_zero {a : Int16} :
a / 0 = 0
@[simp]
theorem Int32.div_zero {a : Int32} :
a / 0 = 0
@[simp]
theorem Int64.div_zero {a : Int64} :
a / 0 = 0
@[simp]
theorem ISize.div_zero {a : ISize} :
a / 0 = 0
@[simp]
theorem Int8.div_one {a : Int8} :
a / 1 = a
@[simp]
theorem Int16.div_one {a : Int16} :
a / 1 = a
@[simp]
theorem Int32.div_one {a : Int32} :
a / 1 = a
@[simp]
theorem Int64.div_one {a : Int64} :
a / 1 = a
@[simp]
theorem ISize.div_one {a : ISize} :
a / 1 = a
theorem Int8.div_self {a : Int8} :
a / a = if a = 0 then 0 else 1
theorem Int16.div_self {a : Int16} :
a / a = if a = 0 then 0 else 1
theorem Int32.div_self {a : Int32} :
a / a = if a = 0 then 0 else 1
theorem Int64.div_self {a : Int64} :
a / a = if a = 0 then 0 else 1
theorem ISize.div_self {a : ISize} :
a / a = if a = 0 then 0 else 1
@[simp]
theorem Int8.mod_zero {a : Int8} :
a % 0 = a
@[simp]
theorem Int16.mod_zero {a : Int16} :
a % 0 = a
@[simp]
theorem Int32.mod_zero {a : Int32} :
a % 0 = a
@[simp]
theorem Int64.mod_zero {a : Int64} :
a % 0 = a
@[simp]
theorem ISize.mod_zero {a : ISize} :
a % 0 = a
@[simp]
theorem Int8.zero_mod {a : Int8} :
0 % a = 0
@[simp]
theorem Int16.zero_mod {a : Int16} :
0 % a = 0
@[simp]
theorem Int32.zero_mod {a : Int32} :
0 % a = 0
@[simp]
theorem Int64.zero_mod {a : Int64} :
0 % a = 0
@[simp]
theorem ISize.zero_mod {a : ISize} :
0 % a = 0
@[simp]
theorem Int8.mod_one {a : Int8} :
a % 1 = 0
@[simp]
theorem Int16.mod_one {a : Int16} :
a % 1 = 0
@[simp]
theorem Int32.mod_one {a : Int32} :
a % 1 = 0
@[simp]
theorem Int64.mod_one {a : Int64} :
a % 1 = 0
@[simp]
theorem ISize.mod_one {a : ISize} :
a % 1 = 0
@[simp]
theorem Int8.mod_self {a : Int8} :
a % a = 0
@[simp]
theorem Int16.mod_self {a : Int16} :
a % a = 0
@[simp]
theorem Int32.mod_self {a : Int32} :
a % a = 0
@[simp]
theorem Int64.mod_self {a : Int64} :
a % a = 0
@[simp]
theorem ISize.mod_self {a : ISize} :
a % a = 0
@[simp]
theorem Int8.not_lt {a b : Int8} :
¬a < b b a
@[simp]
theorem Int16.not_lt {a b : Int16} :
¬a < b b a
@[simp]
theorem Int32.not_lt {a b : Int32} :
¬a < b b a
@[simp]
theorem Int64.not_lt {a b : Int64} :
¬a < b b a
@[simp]
theorem ISize.not_lt {a b : ISize} :
¬a < b b a
theorem Int8.le_trans {a b c : Int8} :
a bb ca c
theorem Int16.le_trans {a b c : Int16} :
a bb ca c
theorem Int32.le_trans {a b c : Int32} :
a bb ca c
theorem Int64.le_trans {a b c : Int64} :
a bb ca c
theorem ISize.le_trans {a b c : ISize} :
a bb ca c
theorem Int8.lt_trans {a b c : Int8} :
a < bb < ca < c
theorem Int16.lt_trans {a b c : Int16} :
a < bb < ca < c
theorem Int32.lt_trans {a b c : Int32} :
a < bb < ca < c
theorem Int64.lt_trans {a b c : Int64} :
a < bb < ca < c
theorem ISize.lt_trans {a b c : ISize} :
a < bb < ca < c
theorem Int8.le_total (a b : Int8) :
a b b a
theorem Int16.le_total (a b : Int16) :
a b b a
theorem Int32.le_total (a b : Int32) :
a b b a
theorem Int64.le_total (a b : Int64) :
a b b a
theorem ISize.le_total (a b : ISize) :
a b b a
theorem Int8.lt_asymm {a b : Int8} :
a < b¬b < a
theorem Int16.lt_asymm {a b : Int16} :
a < b¬b < a
theorem Int32.lt_asymm {a b : Int32} :
a < b¬b < a
theorem Int64.lt_asymm {a b : Int64} :
a < b¬b < a
theorem ISize.lt_asymm {a b : ISize} :
a < b¬b < a
theorem Int8.add_neg_eq_sub {a b : Int8} :
a + -b = a - b
theorem Int16.add_neg_eq_sub {a b : Int16} :
a + -b = a - b
theorem Int32.add_neg_eq_sub {a b : Int32} :
a + -b = a - b
theorem Int64.add_neg_eq_sub {a b : Int64} :
a + -b = a - b
theorem ISize.add_neg_eq_sub {a b : ISize} :
a + -b = a - b
theorem Int8.neg_eq_neg_one_mul (a : Int8) :
-a = -1 * a
@[simp]
theorem Int8.add_sub_cancel (a b : Int8) :
a + b - b = a
@[simp]
theorem Int16.add_sub_cancel (a b : Int16) :
a + b - b = a
@[simp]
theorem Int32.add_sub_cancel (a b : Int32) :
a + b - b = a
@[simp]
theorem Int64.add_sub_cancel (a b : Int64) :
a + b - b = a
@[simp]
theorem ISize.add_sub_cancel (a b : ISize) :
a + b - b = a
theorem Int8.lt_or_lt_of_ne {a b : Int8} :
a ba < b b < a
theorem Int16.lt_or_lt_of_ne {a b : Int16} :
a ba < b b < a
theorem Int32.lt_or_lt_of_ne {a b : Int32} :
a ba < b b < a
theorem Int64.lt_or_lt_of_ne {a b : Int64} :
a ba < b b < a
theorem ISize.lt_or_lt_of_ne {a b : ISize} :
a ba < b b < a
theorem Int8.lt_or_le (a b : Int8) :
a < b b a
theorem Int16.lt_or_le (a b : Int16) :
a < b b a
theorem Int32.lt_or_le (a b : Int32) :
a < b b a
theorem Int64.lt_or_le (a b : Int64) :
a < b b a
theorem ISize.lt_or_le (a b : ISize) :
a < b b a
theorem Int8.le_or_lt (a b : Int8) :
a b b < a
theorem Int16.le_or_lt (a b : Int16) :
a b b < a
theorem Int32.le_or_lt (a b : Int32) :
a b b < a
theorem Int64.le_or_lt (a b : Int64) :
a b b < a
theorem ISize.le_or_lt (a b : ISize) :
a b b < a
theorem Int8.le_of_eq {a b : Int8} :
a = ba b
theorem Int16.le_of_eq {a b : Int16} :
a = ba b
theorem Int32.le_of_eq {a b : Int32} :
a = ba b
theorem Int64.le_of_eq {a b : Int64} :
a = ba b
theorem ISize.le_of_eq {a b : ISize} :
a = ba b
theorem Int8.le_iff_lt_or_eq {a b : Int8} :
a b a < b a = b
theorem Int16.le_iff_lt_or_eq {a b : Int16} :
a b a < b a = b
theorem Int32.le_iff_lt_or_eq {a b : Int32} :
a b a < b a = b
theorem Int64.le_iff_lt_or_eq {a b : Int64} :
a b a < b a = b
theorem ISize.le_iff_lt_or_eq {a b : ISize} :
a b a < b a = b
theorem Int8.lt_or_eq_of_le {a b : Int8} :
a ba < b a = b
theorem Int16.lt_or_eq_of_le {a b : Int16} :
a ba < b a = b
theorem Int32.lt_or_eq_of_le {a b : Int32} :
a ba < b a = b
theorem Int64.lt_or_eq_of_le {a b : Int64} :
a ba < b a = b
theorem ISize.lt_or_eq_of_le {a b : ISize} :
a ba < b a = b
@[simp]
theorem UInt8.toInt8_add (a b : UInt8) :
(a + b).toInt8 = a.toInt8 + b.toInt8
@[simp]
theorem UInt16.toInt16_add (a b : UInt16) :
@[simp]
theorem UInt32.toInt32_add (a b : UInt32) :
@[simp]
theorem UInt64.toInt64_add (a b : UInt64) :
@[simp]
theorem USize.toISize_add (a b : USize) :
@[simp]
theorem UInt8.toInt8_neg (a : UInt8) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem UInt8.toInt8_sub (a b : UInt8) :
(a - b).toInt8 = a.toInt8 - b.toInt8
@[simp]
theorem UInt16.toInt16_sub (a b : UInt16) :
@[simp]
theorem UInt32.toInt32_sub (a b : UInt32) :
@[simp]
theorem UInt64.toInt64_sub (a b : UInt64) :
@[simp]
theorem USize.toISize_sub (a b : USize) :
@[simp]
theorem UInt8.toInt8_mul (a b : UInt8) :
(a * b).toInt8 = a.toInt8 * b.toInt8
@[simp]
theorem UInt16.toInt16_mul (a b : UInt16) :
@[simp]
theorem UInt32.toInt32_mul (a b : UInt32) :
@[simp]
theorem UInt64.toInt64_mul (a b : UInt64) :
@[simp]
theorem USize.toISize_mul (a b : USize) :
@[simp]
theorem Int8.toUInt8_add (a b : Int8) :
@[simp]
theorem Int16.toUInt16_add (a b : Int16) :
@[simp]
theorem Int32.toUInt32_add (a b : Int32) :
@[simp]
theorem Int64.toUInt64_add (a b : Int64) :
@[simp]
theorem ISize.toUSize_add (a b : ISize) :
@[simp]
theorem Int8.toUInt8_neg (a : Int8) :
@[simp]
@[simp]
@[simp]
@[simp]
@[simp]
theorem Int8.toUInt8_sub (a b : Int8) :
@[simp]
theorem Int16.toUInt16_sub (a b : Int16) :
@[simp]
theorem Int32.toUInt32_sub (a b : Int32) :
@[simp]
theorem Int64.toUInt64_sub (a b : Int64) :
@[simp]
theorem ISize.toUSize_sub (a b : ISize) :
@[simp]
theorem Int8.toUInt8_mul (a b : Int8) :
@[simp]
theorem Int16.toUInt16_mul (a b : Int16) :
@[simp]
theorem Int32.toUInt32_mul (a b : Int32) :
@[simp]
theorem Int64.toUInt64_mul (a b : Int64) :
@[simp]
theorem ISize.toUSize_mul (a b : ISize) :
theorem Int8.toUInt8_le {a b : Int8} (ha : 0 a) (hab : a b) :
theorem Int16.toUInt16_le {a b : Int16} (ha : 0 a) (hab : a b) :
theorem Int32.toUInt32_le {a b : Int32} (ha : 0 a) (hab : a b) :
theorem Int64.toUInt64_le {a b : Int64} (ha : 0 a) (hab : a b) :
theorem ISize.toUSize_le {a b : ISize} (ha : 0 a) (hab : a b) :
theorem Int8.zero_le_ofNat_of_lt {a : Nat} (ha : a < 2 ^ 7) :
theorem Int16.zero_le_ofNat_of_lt {a : Nat} (ha : a < 2 ^ 15) :
theorem Int32.zero_le_ofNat_of_lt {a : Nat} (ha : a < 2 ^ 31) :
theorem Int64.zero_le_ofNat_of_lt {a : Nat} (ha : a < 2 ^ 63) :
theorem Int8.sub_nonneg_of_le {a b : Int8} (hb : 0 b) (hab : b a) :
0 a - b
theorem Int16.sub_nonneg_of_le {a b : Int16} (hb : 0 b) (hab : b a) :
0 a - b
theorem Int32.sub_nonneg_of_le {a b : Int32} (hb : 0 b) (hab : b a) :
0 a - b
theorem Int64.sub_nonneg_of_le {a b : Int64} (hb : 0 b) (hab : b a) :
0 a - b
theorem ISize.sub_nonneg_of_le {a b : ISize} (hb : 0 b) (hab : b a) :
0 a - b
theorem Int8.toNatClampNeg_sub_of_le {a b : Int8} (hb : 0 b) (hab : b a) :
theorem Int16.toNatClampNeg_sub_of_le {a b : Int16} (hb : 0 b) (hab : b a) :
theorem Int32.toNatClampNeg_sub_of_le {a b : Int32} (hb : 0 b) (hab : b a) :
theorem Int64.toNatClampNeg_sub_of_le {a b : Int64} (hb : 0 b) (hab : b a) :
theorem ISize.toNatClampNeg_sub_of_le {a b : ISize} (hb : 0 b) (hab : b a) :
theorem Int8.toInt_sub_of_le (a b : Int8) (hb : 0 b) (h : b a) :
(a - b).toInt = a.toInt - b.toInt
theorem Int16.toInt_sub_of_le (a b : Int16) (hb : 0 b) (h : b a) :
(a - b).toInt = a.toInt - b.toInt
theorem Int32.toInt_sub_of_le (a b : Int32) (hb : 0 b) (h : b a) :
(a - b).toInt = a.toInt - b.toInt
theorem Int64.toInt_sub_of_le (a b : Int64) (hb : 0 b) (h : b a) :
(a - b).toInt = a.toInt - b.toInt
theorem ISize.toInt_sub_of_le (a b : ISize) (hb : 0 b) (h : b a) :
(a - b).toInt = a.toInt - b.toInt
theorem Int8.sub_le {a b : Int8} (hb : 0 b) (hab : b a) :
a - b a
theorem Int16.sub_le {a b : Int16} (hb : 0 b) (hab : b a) :
a - b a
theorem Int32.sub_le {a b : Int32} (hb : 0 b) (hab : b a) :
a - b a
theorem Int64.sub_le {a b : Int64} (hb : 0 b) (hab : b a) :
a - b a
theorem ISize.sub_le {a b : ISize} (hb : 0 b) (hab : b a) :
a - b a
theorem Int8.sub_lt {a b : Int8} (hb : 0 < b) (hab : b a) :
a - b < a
theorem Int16.sub_lt {a b : Int16} (hb : 0 < b) (hab : b a) :
a - b < a
theorem Int32.sub_lt {a b : Int32} (hb : 0 < b) (hab : b a) :
a - b < a
theorem Int64.sub_lt {a b : Int64} (hb : 0 < b) (hab : b a) :
a - b < a
theorem ISize.sub_lt {a b : ISize} (hb : 0 < b) (hab : b a) :
a - b < a
theorem Int8.ne_of_lt {a b : Int8} :
a < ba b
theorem Int16.ne_of_lt {a b : Int16} :
a < ba b
theorem Int32.ne_of_lt {a b : Int32} :
a < ba b
theorem Int64.ne_of_lt {a b : Int64} :
a < ba b
theorem ISize.ne_of_lt {a b : ISize} :
a < ba b
@[simp]
theorem Int8.toInt_mod (a b : Int8) :
(a % b).toInt = a.toInt.tmod b.toInt
@[simp]
theorem Int16.toInt_mod (a b : Int16) :
(a % b).toInt = a.toInt.tmod b.toInt
@[simp]
theorem Int32.toInt_mod (a b : Int32) :
(a % b).toInt = a.toInt.tmod b.toInt
@[simp]
theorem Int64.toInt_mod (a b : Int64) :
(a % b).toInt = a.toInt.tmod b.toInt
@[simp]
theorem ISize.toInt_mod (a b : ISize) :
(a % b).toInt = a.toInt.tmod b.toInt
@[simp]
theorem Int8.toInt16_mod (a b : Int8) :
@[simp]
theorem Int8.toInt32_mod (a b : Int8) :
@[simp]
theorem Int8.toInt64_mod (a b : Int8) :
@[simp]
theorem Int8.toISize_mod (a b : Int8) :
@[simp]
theorem Int16.toInt32_mod (a b : Int16) :
@[simp]
theorem Int16.toInt64_mod (a b : Int16) :
@[simp]
theorem Int16.toISize_mod (a b : Int16) :
@[simp]
theorem Int32.toInt64_mod (a b : Int32) :
@[simp]
theorem Int32.toISize_mod (a b : Int32) :
@[simp]
theorem ISize.toInt64_mod (a b : ISize) :
theorem Int8.ofInt_tmod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofInt a % ofInt b
theorem Int16.ofInt_tmod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofInt a % ofInt b
theorem Int32.ofInt_tmod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofInt a % ofInt b
theorem Int64.ofInt_tmod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofInt a % ofInt b
theorem ISize.ofInt_tmod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofInt a % ofInt b
theorem Int8.ofInt_eq_ofIntLE_mod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofIntLE a ha₁ ha₂ % ofIntLE b hb₁ hb₂
theorem Int16.ofInt_eq_ofIntLE_mod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofIntLE a ha₁ ha₂ % ofIntLE b hb₁ hb₂
theorem Int32.ofInt_eq_ofIntLE_mod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofIntLE a ha₁ ha₂ % ofIntLE b hb₁ hb₂
theorem Int64.ofInt_eq_ofIntLE_mod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofIntLE a ha₁ ha₂ % ofIntLE b hb₁ hb₂
theorem ISize.ofInt_eq_ofIntLE_mod {a b : Int} (ha₁ : minValue.toInt a) (ha₂ : a maxValue.toInt) (hb₁ : minValue.toInt b) (hb₂ : b maxValue.toInt) :
ofInt (a.tmod b) = ofIntLE a ha₁ ha₂ % ofIntLE b hb₁ hb₂
theorem Int8.ofNat_mod {a b : Nat} (ha : a < 2 ^ 7) (hb : b < 2 ^ 7) :
ofNat (a % b) = ofNat a % ofNat b
theorem Int16.ofNat_mod {a b : Nat} (ha : a < 2 ^ 15) (hb : b < 2 ^ 15) :
ofNat (a % b) = ofNat a % ofNat b
theorem Int32.ofNat_mod {a b : Nat} (ha : a < 2 ^ 31) (hb : b < 2 ^ 31) :
ofNat (a % b) = ofNat a % ofNat b
theorem Int64.ofNat_mod {a b : Nat} (ha : a < 2 ^ 63) (hb : b < 2 ^ 63) :
ofNat (a % b) = ofNat a % ofNat b
theorem ISize.ofNat_mod {a b : Nat} (ha : a < 2 ^ (System.Platform.numBits - 1)) (hb : b < 2 ^ (System.Platform.numBits - 1)) :
ofNat (a % b) = ofNat a % ofNat b