Loogle!
Result
Found 1551 declarations mentioning Nat.succ. Of these, only the first 200 are shown.
- Nat.succ π Init.Prelude
(n : β) : β - Nat.le_succ π Init.Prelude
(n : β) : n β€ n.succ - Nat.lt_succ_self π Init.Prelude
(n : β) : n < n.succ - Nat.not_succ_le_self π Init.Prelude
(n : β) : Β¬n.succ β€ n - Nat.le.step π Init.Prelude
{n m : β} : n.le m β n.le m.succ - Nat.succ_pos π Init.Prelude
(n : β) : 0 < n.succ - Nat.zero_lt_succ π Init.Prelude
(n : β) : 0 < n.succ - Nat.not_succ_le_zero π Init.Prelude
(n : β) : n.succ β€ 0 β False - Nat.le_of_lt_succ π Init.Prelude
{m n : β} : m < n.succ β m β€ n - Nat.le_succ_of_le π Init.Prelude
{n m : β} (h : n β€ m) : n β€ m.succ - Nat.lt_succ_of_le π Init.Prelude
{n m : β} : n β€ m β n < m.succ - Nat.le_of_succ_le_succ π Init.Prelude
{n m : β} : n.succ β€ m.succ β n β€ m - Nat.succ_le_succ π Init.Prelude
{n m : β} : n β€ m β n.succ β€ m.succ - Nat.ble_succ_eq_true π Init.Prelude
{n m : β} : n.ble m = true β n.ble m.succ = true - Nat.succ_sub_succ_eq_sub π Init.Prelude
(n m : β) : n.succ - m.succ = n - m - Nat.le.below.step π Init.Prelude
{n : β} {motive : (a : β) β n.le a β Prop} {m : β} (aβ : n.le m) : Nat.le.below aβ β motive m aβ β Nat.le.below β― - Nat.succ.injEq π Init.Core
(u v : β) : (u.succ = v.succ) = (u = v) - Nat.succ_ne_self π Init.Data.Nat.Basic
(n : β) : n.succ β n - Nat.pred_succ π Init.Data.Nat.Basic
(n : β) : n.succ.pred = n - Nat.lt.base π Init.Data.Nat.Basic
(n : β) : n < n.succ - Nat.beq.eq_2 π Init.Data.Nat.Basic
(n : β) : Nat.zero.beq n.succ = false - Nat.beq.eq_3 π Init.Data.Nat.Basic
(n : β) : n.succ.beq Nat.zero = false - Nat.succ_ne_zero π Init.Data.Nat.Basic
(n : β) : n.succ β 0 - Nat.succ_succ_ne_one π Init.Data.Nat.Basic
(a : β) : a.succ.succ β 1 - Nat.beq.eq_4 π Init.Data.Nat.Basic
(n m : β) : n.succ.beq m.succ = n.beq m - Nat.le_of_succ_le π Init.Data.Nat.Basic
{n m : β} (h : n.succ β€ m) : n β€ m - Nat.le_step π Init.Data.Nat.Basic
{n m : β} (h : n β€ m) : n β€ m.succ - Nat.lt_of_succ_le π Init.Data.Nat.Basic
{n m : β} (h : n.succ β€ m) : n < m - Nat.lt_of_succ_lt π Init.Data.Nat.Basic
{n m : β} : n.succ < m β n < m - Nat.lt_succ_of_lt π Init.Data.Nat.Basic
{a b : β} (h : a < b) : a < b.succ - Nat.recCompiled π Init.Data.Nat.Basic
{motive : β β Sort u} (zero : motive Nat.zero) (succ : (n : β) β motive n β motive n.succ) (t : β) : motive t - Nat.succ_inj π Init.Data.Nat.Basic
{a b : β} : a.succ = b.succ β a = b - Nat.succ_le_of_lt π Init.Data.Nat.Basic
{n m : β} (h : n < m) : n.succ β€ m - Nat.succ_ne_succ_iff π Init.Data.Nat.Basic
{a b : β} : a.succ β b.succ β a β b - Nat.lt.step π Init.Data.Nat.Basic
{n m : β} : n < m β n < m.succ - Nat.lt_of_succ_lt_succ π Init.Data.Nat.Basic
{n m : β} : n.succ < m.succ β n < m - Nat.lt_pred_of_succ_lt π Init.Data.Nat.Basic
{n m : β} : n.succ < m β n < m.pred - Nat.lt_succ π Init.Data.Nat.Basic
{m n : β} : m < n.succ β m β€ n - Nat.lt_succ_iff π Init.Data.Nat.Basic
{m n : β} : m < n.succ β m β€ n - Nat.pred_le_of_le_succ π Init.Data.Nat.Basic
{n m : β} : n β€ m.succ β n.pred β€ m - Nat.succ_le_iff π Init.Data.Nat.Basic
{m n : β} : m.succ β€ n β m < n - Nat.succ_lt_succ π Init.Data.Nat.Basic
{n m : β} : n < m β n.succ < m.succ - Nat.succ_lt_of_lt_pred π Init.Data.Nat.Basic
{n : β} {m : β} : n < m.pred β n.succ < m - Nat.le_succ_of_pred_le π Init.Data.Nat.Basic
{n : β} {m : β} : n.pred β€ m β n β€ m.succ - Nat.succ_le_succ_iff π Init.Data.Nat.Basic
{a b : β} : a.succ β€ b.succ β a β€ b - Nat.succ_lt_succ_iff π Init.Data.Nat.Basic
{a b : β} : a.succ < b.succ β a < b - Nat.succ_pred π Init.Data.Nat.Basic
{a : β} (h : a β 0) : a.pred.succ = a - Nat.lt_pred_iff π Init.Data.Nat.Basic
{n : β} {m : β} : n < m.pred β n.succ < m - Nat.lt_pred_iff_succ_lt π Init.Data.Nat.Basic
{n : β} {m : β} : n < m.pred β n.succ < m - Nat.pred_le_iff π Init.Data.Nat.Basic
{n : β} {m : β} : n.pred β€ m β n β€ m.succ - Nat.pred_le_iff_le_succ π Init.Data.Nat.Basic
{n : β} {m : β} : n.pred β€ m β n β€ m.succ - Nat.rec_eq_recCompiled π Init.Data.Nat.Basic
: @Nat.rec = @Nat.recCompiled - Nat.succ_pred_eq_of_ne_zero π Init.Data.Nat.Basic
{n : β} : n β 0 β n.pred.succ = n - Nat.exists_eq_succ_of_ne_zero π Init.Data.Nat.Basic
{n : β} : n β 0 β β k, n = k.succ - Nat.succ_pred_eq_of_pos π Init.Data.Nat.Basic
{n : β} : 0 < n β n.pred.succ = n - Nat.add_one π Init.Data.Nat.Basic
(n : β) : n + 1 = n.succ - Nat.eq_zero_or_eq_succ_pred π Init.Data.Nat.Basic
(n : β) : n = 0 β¨ n = n.pred.succ - Nat.succ_eq_add_one π Init.Data.Nat.Basic
(n : β) : n.succ = n + 1 - Nat.le_or_eq_of_le_succ π Init.Data.Nat.Basic
{m n : β} (h : m β€ n.succ) : m β€ n β¨ m = n.succ - Nat.lt_succ_iff_lt_or_eq π Init.Data.Nat.Basic
{m n : β} : m < n.succ β m < n β¨ m = n - Nat.lt_of_sub_eq_succ π Init.Data.Nat.Basic
{m n l : β} (h : m - n = l.succ) : n < m - Nat.add_succ π Init.Data.Nat.Basic
(n m : β) : n + m.succ = (n + m).succ - Nat.sub_le_succ_sub π Init.Data.Nat.Basic
(a i : β) : a - i β€ a.succ - i - Nat.sub_succ π Init.Data.Nat.Basic
(n m : β) : n - m.succ = (n - m).pred - Nat.succ_add π Init.Data.Nat.Basic
(n m : β) : n.succ + m = (n + m).succ - Nat.succ_sub_succ π Init.Data.Nat.Basic
(n m : β) : n.succ - m.succ = n - m - Nat.succ_sub π Init.Data.Nat.Basic
{m n : β} (h : n β€ m) : m.succ - n = (m - n).succ - Nat.mul_succ π Init.Data.Nat.Basic
(n m : β) : n * m.succ = n * m + n - Nat.succ_mul π Init.Data.Nat.Basic
(n m : β) : n.succ * m = n * m + m - Nat.pow_succ π Init.Data.Nat.Basic
(n m : β) : n ^ m.succ = n ^ m * n - Nat.caseStrongRecOn π Init.WF
{motive : β β Sort u} (a : β) (zero : motive 0) (ind : (n : β) β ((m : β) β m β€ n β motive m) β motive n.succ) : motive a - Nat.mod.eq_2 π Init.Data.Nat.Div.Basic
(xβ n : β) : n.succ.mod xβ = if xβ β€ n.succ then n.succ.modCore xβ else n.succ - Nat.modCore.go.eq_1 π Init.Data.Nat.Div.Basic
(y : β) (hy : 0 < y) (x fuel_2 : β) (hfuel_2 : x < fuel_2.succ) : Nat.modCore.go y hy fuel_2.succ x hfuel_2 = if h : y β€ x then Nat.modCore.go y hy fuel_2 (x - y) β― else x - Nat.div.go.eq_1 π Init.Data.Nat.Div.Basic
(y : β) (hy : 0 < y) (x fuel_2 : β) (hfuel_2 : x < fuel_2.succ) : Nat.div.go y hy fuel_2.succ x hfuel_2 = if h : y β€ x then Nat.div.go y hy fuel_2 (x - y) β― + 1 else 0 - Nat.modCore.go.eq_def π Init.Data.Nat.Div.Basic
(y : β) (hy : 0 < y) (fuel x : β) (hfuel : x < fuel) : Nat.modCore.go y hy fuel x hfuel = match fuel, hfuel with | fuel.succ, hfuel => if h : y β€ x then Nat.modCore.go y hy fuel (x - y) β― else x - Nat.div.go.eq_def π Init.Data.Nat.Div.Basic
(y : β) (hy : 0 < y) (fuel x : β) (hfuel : x < fuel) : Nat.div.go y hy fuel x hfuel = match fuel, hfuel with | fuel.succ, hfuel => if h : y β€ x then Nat.div.go y hy fuel (x - y) β― + 1 else 0 - List.replicate.eq_2 π Init.Data.List.Basic
{Ξ± : Type u} (xβ : Ξ±) (n : β) : List.replicate n.succ xβ = xβ :: List.replicate n xβ - List.lengthTRAux.eq_2 π Init.Data.List.Basic
{Ξ± : Type u_1} (xβ : β) (head : Ξ±) (as : List Ξ±) : (head :: as).lengthTRAux xβ = as.lengthTRAux xβ.succ - List.replicateTR.loop.eq_2 π Init.Data.List.Basic
{Ξ± : Type u} (a : Ξ±) (xβ : List Ξ±) (n : β) : List.replicateTR.loop a n.succ xβ = List.replicateTR.loop a n (a :: xβ) - List.set.eq_2 π Init.Data.List.Basic
{Ξ± : Type u_1} (xβ a : Ξ±) (as : List Ξ±) (n : β) : (a :: as).set n.succ xβ = a :: as.set n xβ - List.lengthTRAux.eq_def π Init.Data.List.Basic
{Ξ± : Type u_1} (xβ : List Ξ±) (xβΒΉ : β) : xβ.lengthTRAux xβΒΉ = match xβ, xβΒΉ with | [], n => n | head :: as, n => as.lengthTRAux n.succ - List.range'TR.go.eq_2 π Init.Data.List.Basic
(step xβ : β) (xβΒΉ : List β) (n : β) : List.range'TR.go step n.succ xβ xβΒΉ = List.range'TR.go step n (xβ - step) ((xβ - step) :: xβΒΉ) - List.drop.eq_2 π Init.Data.Array.GetLit
{Ξ± : Type u} (n : β) : List.drop n.succ [] = [] - List.drop.eq_3 π Init.Data.Array.GetLit
{Ξ± : Type u} (n : β) (a : Ξ±) (as : List Ξ±) : List.drop n.succ (a :: as) = List.drop n as - Array.toListLitAux.eq_2 π Init.Data.Array.GetLit
{Ξ± : Type u_1} (xs : Array Ξ±) (n : β) (hsz : xs.size = n) (x : List Ξ±) (i : β) (hi : i + 1 β€ xs.size) : xs.toListLitAux n hsz i.succ hi x = xs.toListLitAux n hsz i β― (xs.getLit i hsz β― :: x) - Nat.Linear.Poly.cancelAux.eq_2 π Init.Data.Nat.Linear
(mβ rβ rβ : Nat.Linear.Poly) (fuel_2 : β) : Nat.Linear.Poly.cancelAux fuel_2.succ mβ [] rβ rβ = (List.reverse rβ ++ mβ, List.reverse rβ) - Nat.Linear.Poly.cancelAux.eq_3 π Init.Data.Nat.Linear
(mβ rβ rβ : Nat.Linear.Poly) (fuel_2 : β) (x : mβ = [] β False) : Nat.Linear.Poly.cancelAux fuel_2.succ [] mβ rβ rβ = (List.reverse rβ, List.reverse rβ ++ mβ) - Nat.Linear.Poly.cancelAux.eq_4 π Init.Data.Nat.Linear
(rβ rβ : Nat.Linear.Poly) (fuel_2 kβ : β) (vβ : Nat.Linear.Var) (mβ_2 : List (β Γ Nat.Linear.Var)) (kβ : β) (vβ : Nat.Linear.Var) (mβ_2 : List (β Γ Nat.Linear.Var)) : Nat.Linear.Poly.cancelAux fuel_2.succ ((kβ, vβ) :: mβ_2) ((kβ, vβ) :: mβ_2) rβ rβ = bif Nat.blt vβ vβ then Nat.Linear.Poly.cancelAux fuel_2 mβ_2 ((kβ, vβ) :: mβ_2) ((kβ, vβ) :: rβ) rβ else bif Nat.blt vβ vβ then Nat.Linear.Poly.cancelAux fuel_2 ((kβ, vβ) :: mβ_2) mβ_2 rβ ((kβ, vβ) :: rβ) else bif kβ.blt kβ then Nat.Linear.Poly.cancelAux fuel_2 mβ_2 mβ_2 rβ ((kβ.sub kβ, vβ) :: rβ) else bif kβ.blt kβ then Nat.Linear.Poly.cancelAux fuel_2 mβ_2 mβ_2 ((kβ.sub kβ, vβ) :: rβ) rβ else Nat.Linear.Poly.cancelAux fuel_2 mβ_2 mβ_2 rβ rβ - Nat.log2.eq_1 π Init.Data.Nat.Log2
(n : β) : n.log2 = Nat.rec (motive := fun x => β β β) (fun x => 0) (fun x ih n => Bool.rec 0 (ih (n.div 2)).succ (Nat.ble 2 n)) n n - Int.fdiv.eq_3 π Init.Data.Int.DivMod.Basic
(m n : β) : (Int.ofNat m.succ).fdiv (Int.negSucc n) = Int.negSucc (m / n.succ) - Int.fdiv.eq_5 π Init.Data.Int.DivMod.Basic
(m n : β) : (Int.negSucc m).fdiv (Int.ofNat n.succ) = Int.negSucc (m / n.succ) - Int.fdiv.eq_6 π Init.Data.Int.DivMod.Basic
(m n : β) : (Int.negSucc m).fdiv (Int.negSucc n) = Int.ofNat (m.succ / n.succ) - Int.negSucc_emod_ofNat π Init.Data.Int.DivMod.Basic
{a b : β} : Int.negSucc a % βb = Int.subNatNat b (a % b).succ - Int.negSucc_ediv_ofNat_succ π Init.Data.Int.DivMod.Basic
{a b : β} : Int.negSucc a / β(b + 1) = Int.negSucc (a / b.succ) - Int.negSucc_emod_negSucc π Init.Data.Int.DivMod.Basic
{a b : β} : Int.negSucc a % Int.negSucc b = Int.subNatNat (b + 1) (a % (b + 1)).succ - Int.neg_ofNat_succ π Init.Data.Int.Lemmas
(n : β) : -βn.succ = Int.negSucc n - Int.negSucc_add_ofNat π Init.Data.Int.Lemmas
(m n : β) : Int.negSucc m + βn = Int.subNatNat n m.succ - Int.ofNat_add_negSucc π Init.Data.Int.Lemmas
(m n : β) : βm + Int.negSucc n = Int.subNatNat m n.succ - Int.subNatNat_of_sub_eq_succ π Init.Data.Int.Lemmas
{m n k : β} (h : n - m = k.succ) : Int.subNatNat m n = Int.negSucc k - Int.natCast_succ π Init.Data.Int.Lemmas
(n : β) : βn.succ = βn + 1 - Int.negOfNat_mul_negSucc π Init.Data.Int.Lemmas
(m n : β) : Int.negOfNat n * Int.negSucc m = Int.ofNat (n * m.succ) - Int.negSucc_add_negSucc π Init.Data.Int.Lemmas
(m n : β) : Int.negSucc m + Int.negSucc n = Int.negSucc (m + n).succ - Int.negSucc_mul_negOfNat π Init.Data.Int.Lemmas
(m n : β) : Int.negSucc m * Int.negOfNat n = Int.ofNat (m.succ * n) - Int.subNatNat_add_negSucc π Init.Data.Int.Lemmas
(m n k : β) : Int.subNatNat m n + Int.negSucc k = Int.subNatNat m (n + k.succ) - Int.ofNat_add_negSucc_of_lt π Init.Data.Int.Lemmas
{m n : β} (h : m < n.succ) : Int.ofNat m + Int.negSucc n = Int.negSucc (n - m) - Int.negSucc_mul_negSucc π Init.Data.Int.Lemmas
(m n : β) : Int.negSucc m * Int.negSucc n = βm.succ * βn.succ - Int.negSucc_mul_ofNat π Init.Data.Int.Lemmas
(m n : β) : Int.negSucc m * βn = -β(m.succ * n) - Int.ofNat_mul_negSucc π Init.Data.Int.Lemmas
(m n : β) : βm * Int.negSucc n = -β(m * n.succ) - Int.negSucc_mul_subNatNat π Init.Data.Int.Lemmas
(m n k : β) : Int.negSucc m * Int.subNatNat n k = Int.subNatNat (m.succ * k) (m.succ * n) - Int.natAbs_negSucc π Init.Data.Int.Order
(n : β) : (Int.negSucc n).natAbs = n.succ - Int.natAbs.eq_2 π Init.Data.Int.Order
(n_1 : β) : (Int.negSucc n_1).natAbs = n_1.succ - Int.sign.eq_1 π Init.Data.Int.Order
(n : β) : (Int.ofNat n.succ).sign = 1 - Int.ofNat_succ_pos π Init.Data.Int.Order
(n : β) : 0 < βn.succ - Int.natAbs.eq_def π Init.Data.Int.Order
(m : β€) : m.natAbs = match m with | Int.ofNat m => m | Int.negSucc m => m.succ - Int.mul.eq_2 π Init.Data.Int.Order
(m_2 n_2 : β) : (Int.ofNat m_2).mul (Int.negSucc n_2) = Int.negOfNat (m_2 * n_2.succ) - Int.mul.eq_3 π Init.Data.Int.Order
(m_2 n_2 : β) : (Int.negSucc m_2).mul (Int.ofNat n_2) = Int.negOfNat (m_2.succ * n_2) - Int.mul.eq_4 π Init.Data.Int.Order
(m_2 n_2 : β) : (Int.negSucc m_2).mul (Int.negSucc n_2) = Int.ofNat (m_2.succ * n_2.succ) - Int.lt.dest π Init.Data.Int.Order
{a b : β€} (h : a < b) : β n, a + βn.succ = b - Int.ediv.eq_4 π Init.Data.Int.DivMod.Bootstrap
(m n : β) : (Int.negSucc m).ediv (Int.ofNat n.succ) = Int.negSucc (m / n.succ) - Int.ediv.eq_5 π Init.Data.Int.DivMod.Bootstrap
(m n : β) : (Int.negSucc m).ediv (Int.negSucc n) = Int.ofNat (m / n.succ).succ - Int.ediv.eq_2 π Init.Data.Int.DivMod.Bootstrap
(m n : β) : (Int.ofNat m).ediv (Int.negSucc n) = -Int.ofNat (m / n.succ) - Nat.gcd_succ π Init.Data.Nat.Gcd
(x y : β) : x.succ.gcd y = (y % x.succ).gcd x.succ - Nat.not_succ_lt_self π Init.Data.Nat.Lemmas
{n : β} : Β¬n.succ < n - Nat.one_lt_succ_succ π Init.Data.Nat.Lemmas
(n : β) : 1 < n.succ.succ - Nat.pred_eq_of_eq_succ π Init.Data.Nat.Lemmas
{m n : β} (H : m = n.succ) : m.pred = n - Nat.succ_ne_succ π Init.Data.Nat.Lemmas
{m n : β} : m.succ β n.succ β m β n - Nat.mod_succ π Init.Data.Nat.Lemmas
(n : β) : n % n.succ = n - Nat.succ_le π Init.Data.Nat.Lemmas
{n m : β} : n.succ β€ m β n < m - Nat.sub_lt_succ π Init.Data.Nat.Lemmas
(a b : β) : a - b < a.succ - Nat.succ_max_succ π Init.Data.Nat.Lemmas
(x y : β) : max x.succ y.succ = (max x y).succ - Nat.succ_min_succ π Init.Data.Nat.Lemmas
(x y : β) : min x.succ y.succ = (min x y).succ - Nat.one_add π Init.Data.Nat.Lemmas
(n : β) : 1 + n = n.succ - Nat.succ_eq_one_add π Init.Data.Nat.Lemmas
(n : β) : n.succ = 1 + n - Nat.succ_sub_one π Init.Data.Nat.Lemmas
(n : β) : n.succ - 1 = n - Nat.le_succ_iff π Init.Data.Nat.Lemmas
{m n : β} : m β€ n.succ β m β€ n β¨ m = n.succ - Nat.mod_succ_eq_iff_lt π Init.Data.Nat.Lemmas
{m n : β} : m % n.succ = m β m < n.succ - Nat.succ_add_eq_add_succ π Init.Data.Nat.Lemmas
(a b : β) : a.succ + b = a + b.succ - Nat.succ_mul_pos π Init.Data.Nat.Lemmas
{n : β} (m : β) (hn : 0 < n) : 0 < m.succ * n - Nat.add_succ_sub_one π Init.Data.Nat.Lemmas
(m n : β) : m + n.succ - 1 = m + n - Nat.sub_succ' π Init.Data.Nat.Lemmas
(m n : β) : m - n.succ = m - n - 1 - Nat.succ_add_sub_one π Init.Data.Nat.Lemmas
(n m : β) : m.succ + n - 1 = m + n - Nat.pow_succ' π Init.Data.Nat.Lemmas
{m n : β} : m ^ n.succ = m * m ^ n - Nat.succ_sub_sub_succ π Init.Data.Nat.Lemmas
(n m k : β) : n.succ - m - k.succ = n - m - k - Nat.succ_mul_succ π Init.Data.Nat.Lemmas
(a b : β) : a.succ * b.succ = a * b + a + b + 1 - Nat.succ_mul_succ_eq π Init.Data.Nat.Lemmas
(a b : β) : a.succ * b.succ = a * b + a + b + 1 - Int.pow_succ π Init.Data.Int.Pow
(m : β€) (n : β) : m ^ n.succ = m ^ n * m - Int.negSucc_pow π Init.Data.Int.Pow
(m n : β) : Int.negSucc m ^ n = if n % 2 = 0 then Int.ofNat (m.succ ^ n) else Int.negOfNat (m.succ ^ n) - Nat.testBit_succ π Init.Data.Nat.Bitwise.Lemmas
(x i : β) : x.testBit i.succ = (x / 2).testBit i - List.get.eq_2 π Init.Data.List.BasicAux
{Ξ± : Type u} (head : Ξ±) (as : List Ξ±) (i : β) (h : i.succ < (head :: as).length) : (head :: as).get β¨i.succ, hβ© = as.get β¨i, β―β© - List.get.eq_def π Init.Data.List.BasicAux
{Ξ± : Type u} (xβ : List Ξ±) (xβΒΉ : Fin xβ.length) : xβ.get xβΒΉ = match xβ, xβΒΉ with | a :: tail, β¨0, isLtβ© => a | head :: as, β¨i.succ, hβ© => as.get β¨i, β―β© - Fin.cast_succ_eq π Init.Data.Fin.Lemmas
{n n' : β} (i : Fin n) (h : n.succ = n'.succ) : Fin.cast h i.succ = (Fin.cast β― i).succ - Fin.castLE_zero π Init.Data.Fin.Lemmas
{n m : β} (h : n.succ β€ m.succ) : Fin.castLE h 0 = 0 - Fin.succ_eq_last_succ π Init.Data.Fin.Lemmas
{n : β} {i : Fin n.succ} : i.succ = Fin.last (n + 1) β i = Fin.last n - Fin.succ_last π Init.Data.Fin.Lemmas
(n : β) : (Fin.last n).succ = Fin.last n.succ - Fin.pred_le_pred_iff π Init.Data.Fin.Lemmas
{n : β} {a b : Fin n.succ} {ha : a β 0} {hb : b β 0} : a.pred ha β€ b.pred hb β a β€ b - Fin.pred_lt_pred_iff π Init.Data.Fin.Lemmas
{n : β} {a b : Fin n.succ} {ha : a β 0} {hb : b β 0} : a.pred ha < b.pred hb β a < b - Fin.val_add_one_of_lt π Init.Data.Fin.Lemmas
{n : β} {i : Fin n.succ} (h : i < Fin.last n) : β(i + 1) = βi + 1 - Fin.succRec π Init.Data.Fin.Lemmas
{motive : (n : β) β Fin n β Sort u_1} (zero : (n : β) β motive n.succ 0) (succ : (n : β) β (i : Fin n) β motive n i β motive n.succ i.succ) {n : β} (i : Fin n) : motive n i - Fin.succRecOn π Init.Data.Fin.Lemmas
{n : β} (i : Fin n) {motive : (n : β) β Fin n β Sort u_1} (zero : (n : β) β motive (n + 1) 0) (succ : (n : β) β (i : Fin n) β motive n i β motive n.succ i.succ) : motive n i - Fin.castLE_succ π Init.Data.Fin.Lemmas
{m n : β} (h : m + 1 β€ n + 1) (i : Fin m) : Fin.castLE h i.succ = (Fin.castLE β― i).succ - Fin.mk_succ_pos π Init.Data.Fin.Lemmas
{n : β} (i : β) (h : i < n) : 0 < β¨i.succ, β―β© - Fin.succRecOn_succ π Init.Data.Fin.Lemmas
{motive : (n : β) β Fin n β Sort u_1} {zero : (n : β) β motive (n + 1) 0} {succ : (n : β) β (i : Fin n) β motive n i β motive n.succ i.succ} {n : β} (i : Fin n) : i.succ.succRecOn zero succ = succ n i (i.succRecOn zero succ) - Fin.cases_succ' π Init.Data.Fin.Lemmas
{n : β} {motive : Fin (n + 1) β Sort u_1} {zero : motive 0} {succ : (i : Fin n) β motive i.succ} {i : β} (h : i + 1 < n + 1) : Fin.cases zero succ β¨i.succ, hβ© = succ β¨i, β―β© - Fin.succRecOn_zero π Init.Data.Fin.Lemmas
{motive : (n : β) β Fin n β Sort u_1} {zero : (n : β) β motive (n + 1) 0} {succ : (n : β) β (i : Fin n) β motive n i β motive n.succ i.succ} (n : β) : Fin.succRecOn 0 zero succ = zero n - Fin.foldr.loop.eq_2 π Init.Data.Fin.Fold
{Ξ± : Sort u_1} (n : β) (f : Fin n β Ξ± β Ξ±) (x : Ξ±) (i : β) (h : i + 1 β€ n) : Fin.foldr.loop n f i.succ h x = Fin.foldr.loop n f i β― (f β¨i, hβ© x) - List.splitAt.go.eq_2 π Init.Data.List.Lemmas
{Ξ± : Type u} (l xβ : List Ξ±) (x_3 : Ξ±) (xs : List Ξ±) (n : β) : List.splitAt.go l (x_3 :: xs) n.succ xβ = List.splitAt.go l xs n (x_3 :: xβ) - List.splitAt.go.eq_3 π Init.Data.List.Lemmas
{Ξ± : Type u} (l xβ : List Ξ±) (xβΒΉ : β) (xβΒ² : List Ξ±) (x_4 : xβ = [] β False) (x_5 : β (x : Ξ±) (xs : List Ξ±) (n : β), xβ = x :: xs β xβΒΉ = n.succ β False) : List.splitAt.go l xβ xβΒΉ xβΒ² = (xβΒ².reverse, xβ) - List.getElem_cons π Init.Data.List.Lemmas
{Ξ± : Type u_1} {i : β} {a : Ξ±} {l : List Ξ±} (w : i < (a :: l).length) : (a :: l)[i] = if h : i = 0 then a else l[i - 1] - List.take.eq_2 π Init.Data.List.TakeDrop
{Ξ± : Type u} (n : β) : List.take n.succ [] = [] - List.take.eq_3 π Init.Data.List.TakeDrop
{Ξ± : Type u} (n : β) (a : Ξ±) (as : List Ξ±) : List.take n.succ (a :: as) = a :: List.take n as - List.IsPrefix.getElem π Init.Data.List.Sublist
{Ξ± : Type u_1} {xs ys : List Ξ±} (h : xs <+: ys) {i : β} (hi : i < xs.length) : xs[i] = ys[i] - Int.tmod.eq_2 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.ofNat m).tmod (Int.negSucc n) = Int.ofNat (m % n.succ) - Int.fmod.eq_4 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).fmod (Int.ofNat n) = Int.subNatNat n (m % n).succ - Int.tdiv.eq_4 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).tdiv (Int.negSucc n) = Int.ofNat (m.succ / n.succ) - Int.emod.eq_2 π Init.Data.Int.DivMod.Lemmas
(xβ : β€) (m : β) : (Int.negSucc m).emod xβ = Int.subNatNat xβ.natAbs (m % xβ.natAbs).succ - Int.fmod.eq_3 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.ofNat m.succ).fmod (Int.negSucc n) = Int.subNatNat (m % n.succ) n - Int.tdiv.eq_2 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.ofNat m).tdiv (Int.negSucc n) = -Int.ofNat (m / n.succ) - Int.tdiv.eq_3 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).tdiv (Int.ofNat n) = -Int.ofNat (m.succ / n) - Int.tmod.eq_3 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).tmod (Int.ofNat n) = -Int.ofNat (m.succ % n) - Int.fmod.eq_5 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).fmod (Int.negSucc n) = -Int.ofNat (m.succ % n.succ) - Int.tmod.eq_4 π Init.Data.Int.DivMod.Lemmas
(m n : β) : (Int.negSucc m).tmod (Int.negSucc n) = -Int.ofNat (m.succ % n.succ) - Int.emod_negSucc π Init.Data.Int.DivMod.Lemmas
(m : β) (n : β€) : Int.negSucc m % n = Int.subNatNat n.natAbs (m % n.natAbs).succ - Int.natCast_succ_pos π Init.Data.Int.LemmasAux
(n : β) : 0 < βn.succ - Int.ofNat_add_one_out π Init.Data.Int.LemmasAux
(n : β) : βn + 1 = βn.succ - BitVec.reverse.eq_2 π Init.Data.BitVec.Lemmas
(w : β) (x_2 : BitVec (w + 1)) : x_2.reverse = (BitVec.truncate w x_2).reverse.concat x_2.msb - BitVec.replicate.eq_2 π Init.Data.BitVec.Lemmas
{w : β} (xβ : BitVec w) (n : β) : BitVec.replicate n.succ xβ = BitVec.cast β― (xβ ++ BitVec.replicate n xβ) - BitVec.sshiftRightRec.eq_2 π Init.Data.BitVec.Bitblast
{wβ wβ : β} (x : BitVec wβ) (y : BitVec wβ) (s_1 : β) : x.sshiftRightRec y s_1.succ = (x.sshiftRightRec y s_1).sshiftRight' (y &&& BitVec.twoPow wβ s_1.succ) - BitVec.shiftLeftRec.eq_2 π Init.Data.BitVec.Bitblast
{wβ wβ : β} (x : BitVec wβ) (y : BitVec wβ) (s_1 : β) : x.shiftLeftRec y s_1.succ = x.shiftLeftRec y s_1 <<< (y &&& BitVec.twoPow wβ s_1.succ) - BitVec.ushiftRightRec.eq_2 π Init.Data.BitVec.Bitblast
{wβ wβ : β} (x : BitVec wβ) (y : BitVec wβ) (s_1 : β) : x.ushiftRightRec y s_1.succ = x.ushiftRightRec y s_1 >>> (y &&& BitVec.twoPow wβ s_1.succ) - BitVec.mulRec.eq_2 π Init.Data.BitVec.Bitblast
{w : β} (x y : BitVec w) (s_2 : β) : x.mulRec y s_2.succ = x.mulRec y s_2 + if y.getLsbD s_2.succ = true then x <<< s_2.succ else 0 - BitVec.uppcRec.eq_2 π Init.Data.BitVec.Bitblast
{w : β} (x : BitVec w) (i : β) (hs_2 : i + 1 < w) : x.uppcRec i.succ hs_2 = (x[w - 1 - i] || x.uppcRec i β―) - BitVec.resRec.eq_def π Init.Data.BitVec.Bitblast
{w : β} (x y : BitVec w) (s : β) (hs : s < w) (hslt : 0 < s) : x.resRec y s hs hslt = match hs0 : s, hs, hslt with | 0, hs, hslt => β―.elim | s'.succ, hs, hslt => match hs' : s', hs, hslt, hs0 with | 0, hs, hslt, hs0 => x.aandRec y 1 hs | s''.succ, hs, hslt, hs0 => x.resRec y s' β― β― || x.aandRec y s β― - List.range_succ π Init.Data.List.Range
{n : β} : List.range n.succ = List.range n ++ [n] - List.range'.eq_2 π Init.Data.List.Range
(xβ xβΒΉ n : β) : List.range' xβ n.succ xβΒΉ = xβ :: List.range' (xβ + xβΒΉ) n xβΒΉ - List.range_succ_eq_map π Init.Data.List.Range
{n : β} : List.range (n + 1) = 0 :: List.map Nat.succ (List.range n) - List.eraseIdx.eq_3 π Init.Data.List.Impl
{Ξ± : Type u} (a : Ξ±) (as : List Ξ±) (n : β) : (a :: as).eraseIdx n.succ = a :: as.eraseIdx n - List.not_of_lt_findIdx π Init.Data.List.Find
{Ξ± : Type u_1} {p : Ξ± β Bool} {xs : List Ξ±} {i : β} (h : i < List.findIdx p xs) : p xs[i] = false - Array.forIn'.loop.eq_2 π Init.Data.List.ToArray
{Ξ± : Type u} {Ξ² : Type v} {m : Type v β Type w} [inst : Monad m] (as : Array Ξ±) (f : (a : Ξ±) β a β as β Ξ² β m (ForInStep Ξ²)) (b : Ξ²) (i_2 : β) (h_2 : i_2 + 1 β€ as.size) : Array.forIn'.loop as f i_2.succ h_2 b = do let __do_lift β f as[as.size - 1 - i_2] β― b match __do_lift with | ForInStep.done b => pure b | ForInStep.yield b => Array.forIn'.loop as f i_2 β― b - Nat.repeat.eq_2 π Init.Data.String.Basic
{Ξ± : Type u} (f : Ξ± β Ξ±) (xβ : Ξ±) (n : β) : Nat.repeat f n.succ xβ = f (Nat.repeat f n xβ) - String.Slice.Pos.nextn.induct_unfolding π Init.Data.String.Basic
{s : String.Slice} (motive : s.Pos β β β s.Pos β Prop) (case1 : β (p : s.Pos), motive p 0 p) (case2 : β (p : s.Pos) (n : β) (h : p β s.endPos), motive (p.next h) n ((p.next h).nextn n) β motive p n.succ ((p.next h).nextn n)) (case3 : β (p : s.Pos) (n : β), Β¬p β s.endPos β motive p n.succ p) (p : s.Pos) (n : β) : motive p n (p.nextn n)
About
Loogle searches Lean and Mathlib definitions and theorems.
You can use Loogle from within the Lean4 VSCode language extension
using (by default) Ctrl-K Ctrl-S. You can also try the
#loogle command from LeanSearchClient,
the CLI version, the Loogle
VS Code extension, the lean.nvim
integration or the Zulip bot.
Usage
Loogle finds definitions and lemmas in various ways:
By constant:
πReal.sin
finds all lemmas whose statement somehow mentions the sine function.By lemma name substring:
π"differ"
finds all lemmas that have"differ"somewhere in their lemma name.By subexpression:
π_ * (_ ^ _)
finds all lemmas whose statements somewhere include a product where the second argument is raised to some power.The pattern can also be non-linear, as in
πReal.sqrt ?a * Real.sqrt ?aIf the pattern has parameters, they are matched in any order. Both of these will find
List.map:
π(?a -> ?b) -> List ?a -> List ?b
πList ?a -> (?a -> ?b) -> List ?bBy main conclusion:
π|- tsum _ = _ * tsum _
finds all lemmas where the conclusion (the subexpression to the right of allβandβ) has the given shape.As before, if the pattern has parameters, they are matched against the hypotheses of the lemma in any order; for example,
π|- _ < _ β tsum _ < tsum _
will findtsum_lt_tsumeven though the hypothesisf i < g iis not the last.
If you pass more than one such search filter, separated by commas
Loogle will return lemmas which match all of them. The
search
π Real.sin, "two", tsum, _ * _, _ ^ _, |- _ < _ β _
would find all lemmas which mention the constants Real.sin
and tsum, have "two" as a substring of the
lemma name, include a product and a power somewhere in the type,
and have a hypothesis of the form _ < _ (if
there were any such lemmas). Metavariables (?a) are
assigned independently in each filter.
The #lucky button will directly send you to the
documentation of the first hit.
Source code
You can find the source code for this service at https://github.com/nomeata/loogle. The https://loogle.lean-lang.org/ service is provided by the Lean FRO.
This is Loogle revision 6ff4759 serving mathlib revision 519f454