Structures involving *
and 0
on WithTop
and WithBot
#
The main results of this section are WithTop.instOrderedCommSemiring
and
WithBot.instOrderedCommSemiring
.
instance
WithTop.instMulZeroClass
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
:
MulZeroClass (WithTop α)
Equations
@[simp]
@[simp]
theorem
WithTop.mul_top
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a : WithTop α}
(h : a ≠ 0)
:
@[simp]
theorem
WithTop.top_mul
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{b : WithTop α}
(hb : b ≠ 0)
:
@[simp]
theorem
WithTop.mul_coe_eq_bind
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{b : α}
(hb : b ≠ 0)
(a : WithTop α)
:
a * ↑b = Option.bind a fun (a : α) => some (a * b)
theorem
WithTop.coe_mul_eq_bind
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a : α}
(ha : a ≠ 0)
(b : WithTop α)
:
↑a * b = Option.bind b fun (b : α) => some (a * b)
@[simp]
theorem
WithTop.untop'_zero_mul
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
(a b : WithTop α)
:
WithTop.untop' 0 (a * b) = WithTop.untop' 0 a * WithTop.untop' 0 b
theorem
WithTop.mul_ne_top
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a b : WithTop α}
(ha : a ≠ ⊤)
(hb : b ≠ ⊤)
:
theorem
WithTop.mul_lt_top
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[LT α]
{a b : WithTop α}
(ha : a < ⊤)
(hb : b < ⊤)
:
@[deprecated WithTop.mul_lt_top (since := "2024-08-25")]
theorem
WithTop.mul_lt_top'
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[LT α]
{a b : WithTop α}
(ha : a < ⊤)
(hb : b < ⊤)
:
Alias of WithTop.mul_lt_top
.
instance
WithTop.instNoZeroDivisors
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[NoZeroDivisors α]
:
instance
WithTop.instMulZeroOneClass
{α : Type u_1}
[DecidableEq α]
[MulZeroOneClass α]
[Nontrivial α]
:
Nontrivial α
is needed here as otherwise we have 1 * ⊤ = ⊤
but also 0 * ⊤ = 0
.
Equations
def
MonoidWithZeroHom.withTopMap
{R : Type u_2}
{S : Type u_3}
[MulZeroOneClass R]
[DecidableEq R]
[Nontrivial R]
[MulZeroOneClass S]
[DecidableEq S]
[Nontrivial S]
(f : R →*₀ S)
(hf : Function.Injective ⇑f)
:
A version of WithTop.map
for MonoidWithZeroHom
s.
Equations
- f.withTopMap hf = { toFun := WithTop.map ⇑f, map_zero' := ⋯, map_one' := ⋯, map_mul' := ⋯ }
Instances For
@[simp]
theorem
MonoidWithZeroHom.withTopMap_apply
{R : Type u_2}
{S : Type u_3}
[MulZeroOneClass R]
[DecidableEq R]
[Nontrivial R]
[MulZeroOneClass S]
[DecidableEq S]
[Nontrivial S]
(f : R →*₀ S)
(hf : Function.Injective ⇑f)
:
⇑(f.withTopMap hf) = WithTop.map ⇑f
instance
WithTop.instSemigroupWithZero
{α : Type u_1}
[DecidableEq α]
[SemigroupWithZero α]
[NoZeroDivisors α]
:
Equations
instance
WithTop.instMonoidWithZero
{α : Type u_1}
[DecidableEq α]
[MonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
:
Equations
@[simp]
theorem
WithTop.coe_pow
{α : Type u_1}
[DecidableEq α]
[MonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
(a : α)
(n : ℕ)
:
theorem
WithTop.top_pow
{α : Type u_1}
[DecidableEq α]
[MonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
{n : ℕ}
(n_pos : 0 < n)
:
instance
WithTop.instCommMonoidWithZero
{α : Type u_1}
[DecidableEq α]
[CommMonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
:
Equations
instance
WithTop.instNonUnitalNonAssocSemiring
{α : Type u_1}
[DecidableEq α]
[NonUnitalNonAssocSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
:
Equations
instance
WithTop.instNonAssocSemiring
{α : Type u_1}
[DecidableEq α]
[NonAssocSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[Nontrivial α]
:
Equations
instance
WithTop.instNonUnitalSemiring
{α : Type u_1}
[DecidableEq α]
[NonUnitalSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
:
Equations
instance
WithTop.instSemiring
{α : Type u_1}
[DecidableEq α]
[Semiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
[Nontrivial α]
:
Equations
- WithTop.instSemiring = Semiring.mk ⋯ ⋯ ⋯ ⋯ Monoid.npow ⋯ ⋯
instance
WithTop.instCommSemiring
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
[Nontrivial α]
:
CommSemiring (WithTop α)
Equations
instance
WithTop.instOrderedCommSemiring
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
[Nontrivial α]
:
def
RingHom.withTopMap
{R : Type u_2}
{S : Type u_3}
[NonAssocSemiring R]
[PartialOrder R]
[CanonicallyOrderedAdd R]
[DecidableEq R]
[Nontrivial R]
[NonAssocSemiring S]
[PartialOrder S]
[CanonicallyOrderedAdd S]
[DecidableEq S]
[Nontrivial S]
(f : R →+* S)
(hf : Function.Injective ⇑f)
:
A version of WithTop.map
for RingHom
s.
Equations
- f.withTopMap hf = { toFun := (↑(f.toMonoidWithZeroHom.withTopMap hf)).toFun, map_one' := ⋯, map_mul' := ⋯, map_zero' := ⋯, map_add' := ⋯ }
Instances For
@[simp]
theorem
RingHom.withTopMap_apply
{R : Type u_2}
{S : Type u_3}
[NonAssocSemiring R]
[PartialOrder R]
[CanonicallyOrderedAdd R]
[DecidableEq R]
[Nontrivial R]
[NonAssocSemiring S]
[PartialOrder S]
[CanonicallyOrderedAdd S]
[DecidableEq S]
[Nontrivial S]
(f : R →+* S)
(hf : Function.Injective ⇑f)
:
⇑(f.withTopMap hf) = (↑(f.toMonoidWithZeroHom.withTopMap hf)).toFun
theorem
WithTop.mul_lt_mul
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[PosMulStrictMono α]
{a₁ a₂ b₁ b₂ : WithTop α}
(ha : a₁ < a₂)
(hb : b₁ < b₂)
:
theorem
WithTop.pow_right_strictMono
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[PosMulStrictMono α]
[NoZeroDivisors α]
[Nontrivial α]
{n : ℕ}
:
n ≠ 0 → StrictMono fun (a : WithTop α) => a ^ n
theorem
WithTop.pow_lt_pow_left
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[PosMulStrictMono α]
[NoZeroDivisors α]
[Nontrivial α]
{a b : WithTop α}
(hab : a < b)
{n : ℕ}
(hn : n ≠ 0)
:
instance
WithBot.instMulZeroClass
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
:
MulZeroClass (WithBot α)
@[simp]
@[simp]
theorem
WithBot.mul_bot
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a : WithBot α}
(h : a ≠ 0)
:
@[simp]
theorem
WithBot.bot_mul
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{b : WithBot α}
(hb : b ≠ 0)
:
@[simp]
theorem
WithBot.mul_coe_eq_bind
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{b : α}
(hb : b ≠ 0)
(a : WithBot α)
:
a * ↑b = Option.bind a fun (a : α) => some (a * b)
theorem
WithBot.coe_mul_eq_bind
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a : α}
(ha : a ≠ 0)
(b : WithBot α)
:
↑a * b = Option.bind b fun (b : α) => some (a * b)
@[simp]
theorem
WithBot.unbot'_zero_mul
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
(a b : WithBot α)
:
WithBot.unbot' 0 (a * b) = WithBot.unbot' 0 a * WithBot.unbot' 0 b
theorem
WithBot.mul_ne_bot
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
{a b : WithBot α}
(ha : a ≠ ⊥)
(hb : b ≠ ⊥)
:
theorem
WithBot.bot_lt_mul
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[LT α]
{a b : WithBot α}
(ha : ⊥ < a)
(hb : ⊥ < b)
:
@[deprecated WithBot.bot_lt_mul (since := "2024-08-25")]
theorem
WithBot.bot_lt_mul'
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[LT α]
{a b : WithBot α}
(ha : ⊥ < a)
(hb : ⊥ < b)
:
Alias of WithBot.bot_lt_mul
.
instance
WithBot.instNoZeroDivisors
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[NoZeroDivisors α]
:
instance
WithBot.instMulZeroOneClass
{α : Type u_1}
[DecidableEq α]
[MulZeroOneClass α]
[Nontrivial α]
:
Nontrivial α
is needed here as otherwise we have 1 * ⊥ = ⊥
but also = 0 * ⊥ = 0
.
instance
WithBot.instSemigroupWithZero
{α : Type u_1}
[DecidableEq α]
[SemigroupWithZero α]
[NoZeroDivisors α]
:
instance
WithBot.instMonoidWithZero
{α : Type u_1}
[DecidableEq α]
[MonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
:
@[simp]
theorem
WithBot.coe_pow
{α : Type u_1}
[DecidableEq α]
[MonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
(a : α)
(n : ℕ)
:
instance
WithBot.instCommMonoidWithZero
{α : Type u_1}
[DecidableEq α]
[CommMonoidWithZero α]
[NoZeroDivisors α]
[Nontrivial α]
:
instance
WithBot.instCommSemiring
{α : Type u_1}
[DecidableEq α]
[CommSemiring α]
[PartialOrder α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
[Nontrivial α]
:
CommSemiring (WithBot α)
instance
WithBot.instPosMulMono
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[PosMulMono α]
:
PosMulMono (WithBot α)
instance
WithBot.instMulPosMono
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[MulPosMono α]
:
MulPosMono (WithBot α)
instance
WithBot.instPosMulStrictMono
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[PosMulStrictMono α]
:
instance
WithBot.instMulPosStrictMono
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[MulPosStrictMono α]
:
instance
WithBot.instPosMulReflectLT
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[PosMulReflectLT α]
:
instance
WithBot.instMulPosReflectLT
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[MulPosReflectLT α]
:
instance
WithBot.instPosMulReflectLE
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[PosMulReflectLE α]
:
instance
WithBot.instMulPosReflectLE
{α : Type u_1}
[DecidableEq α]
[MulZeroClass α]
[Preorder α]
[MulPosReflectLE α]
:
instance
WithBot.instOrderedCommSemiring
{α : Type u_1}
[DecidableEq α]
[OrderedCommSemiring α]
[CanonicallyOrderedAdd α]
[NoZeroDivisors α]
[Nontrivial α]
: