HepLean Documentation

Mathlib.Algebra.Ring.Int.Parity

Basic parity lemmas for the ring #

See note [foundational algebra order theory].

Parity #

theorem Int.odd_iff {n : } :
Odd n n % 2 = 1
theorem Int.not_odd_iff {n : } :
¬Odd n n % 2 = 0
@[simp]
@[simp]
@[simp]
@[deprecated Int.not_odd_iff_even]
@[deprecated Int.not_even_iff_odd]
theorem Int.even_or_odd (n : ) :
theorem Int.even_or_odd' (n : ) :
∃ (k : ), n = 2 * k n = 2 * k + 1
theorem Int.even_xor'_odd (n : ) :
Xor' (Even n) (Odd n)
theorem Int.even_xor'_odd' (n : ) :
∃ (k : ), Xor' (n = 2 * k) (n = 2 * k + 1)
Equations
theorem Int.even_add' {m n : } :
Even (m + n) (Odd m Odd n)
theorem Int.even_sub' {m n : } :
Even (m - n) (Odd m Odd n)
theorem Int.odd_mul {m n : } :
Odd (m * n) Odd m Odd n
theorem Int.Odd.of_mul_left {m n : } (h : Odd (m * n)) :
Odd m
theorem Int.Odd.of_mul_right {m n : } (h : Odd (m * n)) :
Odd n
theorem Int.odd_pow {m : } {n : } :
Odd (m ^ n) Odd m n = 0
theorem Int.odd_pow' {m : } {n : } (h : n 0) :
Odd (m ^ n) Odd m
theorem Int.odd_add {m n : } :
Odd (m + n) (Odd m Even n)
theorem Int.odd_add' {m n : } :
Odd (m + n) (Odd n Even m)
theorem Int.ne_of_odd_add {m n : } (h : Odd (m + n)) :
m n
theorem Int.odd_sub {m n : } :
Odd (m - n) (Odd m Even n)
theorem Int.odd_sub' {m n : } :
Odd (m - n) (Odd n Even m)
theorem Int.even_mul_succ_self (n : ) :
Even (n * (n + 1))
theorem Int.even_mul_pred_self (n : ) :
Even (n * (n - 1))
@[simp]
theorem Int.odd_coe_nat (n : ) :
Odd n Odd n
@[simp]
theorem Int.natAbs_even {n : } :
Even n.natAbs Even n
@[simp]
theorem Int.natAbs_odd {n : } :
Odd n.natAbs Odd n
theorem Even.natAbs {n : } :
Even nEven n.natAbs

Alias of the reverse direction of Int.natAbs_even.

theorem Odd.natAbs {n : } :
Odd nOdd n.natAbs

Alias of the reverse direction of Int.natAbs_odd.

theorem Int.four_dvd_add_or_sub_of_odd {a b : } (ha : Odd a) (hb : Odd b) :
4 a + b 4 a - b
theorem Int.two_mul_ediv_two_add_one_of_odd {n : } :
Odd n2 * (n / 2) + 1 = n
theorem Int.ediv_two_mul_two_add_one_of_odd {n : } :
Odd nn / 2 * 2 + 1 = n
theorem Int.add_one_ediv_two_mul_two_of_odd {n : } :
Odd n1 + n / 2 * 2 = n
theorem Int.two_mul_ediv_two_of_odd {n : } (h : Odd n) :
2 * (n / 2) = n - 1