Results about big operators over intervals #
We prove results about big operators over intervals.
theorem
Finset.mul_prod_Ico_eq_prod_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.add_sum_Ico_eq_sum_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.prod_Ico_mul_eq_prod_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.sum_Ico_add_eq_sum_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.mul_prod_Ioc_eq_prod_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.add_sum_Ioc_eq_sum_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.prod_Ioc_mul_eq_prod_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.sum_Ioc_add_eq_sum_Icc
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
{a b : α}
[LocallyFiniteOrder α]
(h : a ≤ b)
:
theorem
Finset.mul_prod_Ioi_eq_prod_Ici
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
[LocallyFiniteOrderTop α]
(a : α)
:
theorem
Finset.add_sum_Ioi_eq_sum_Ici
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
[LocallyFiniteOrderTop α]
(a : α)
:
theorem
Finset.prod_Ioi_mul_eq_prod_Ici
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
[LocallyFiniteOrderTop α]
(a : α)
:
theorem
Finset.sum_Ioi_add_eq_sum_Ici
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
[LocallyFiniteOrderTop α]
(a : α)
:
theorem
Finset.mul_prod_Iio_eq_prod_Iic
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
[LocallyFiniteOrderBot α]
(a : α)
:
theorem
Finset.add_sum_Iio_eq_sum_Iic
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
[LocallyFiniteOrderBot α]
(a : α)
:
theorem
Finset.prod_Iio_mul_eq_prod_Iic
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[CommMonoid M]
{f : α → M}
[LocallyFiniteOrderBot α]
(a : α)
:
theorem
Finset.sum_Iio_add_eq_sum_Iic
{α : Type u_1}
{M : Type u_2}
[PartialOrder α]
[AddCommMonoid M]
{f : α → M}
[LocallyFiniteOrderBot α]
(a : α)
:
theorem
Finset.prod_prod_Ioi_mul_eq_prod_prod_off_diag
{α : Type u_1}
{M : Type u_2}
[Fintype α]
[LinearOrder α]
[LocallyFiniteOrderTop α]
[LocallyFiniteOrderBot α]
[CommMonoid M]
(f : α → α → M)
:
theorem
Finset.sum_sum_Ioi_add_eq_sum_sum_off_diag
{α : Type u_1}
{M : Type u_2}
[Fintype α]
[LinearOrder α]
[LocallyFiniteOrderTop α]
[LocallyFiniteOrderBot α]
[AddCommMonoid M]
(f : α → α → M)
:
theorem
Finset.prod_Ico_add'
{α : Type u_1}
{M : Type u_2}
[CommMonoid M]
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
(f : α → M)
(a b c : α)
:
theorem
Finset.sum_Ico_add'
{α : Type u_1}
{M : Type u_2}
[AddCommMonoid M]
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
(f : α → M)
(a b c : α)
:
theorem
Finset.prod_Ico_add
{α : Type u_1}
{M : Type u_2}
[CommMonoid M]
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
(f : α → M)
(a b c : α)
:
theorem
Finset.sum_Ico_add
{α : Type u_1}
{M : Type u_2}
[AddCommMonoid M]
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
(f : α → M)
(a b c : α)
:
@[simp]
theorem
Finset.prod_Ico_add_right_sub_eq
{α : Type u_1}
{M : Type u_2}
[CommMonoid M]
{f : α → M}
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
[Sub α]
[OrderedSub α]
(a b c : α)
:
@[simp]
theorem
Finset.sum_Ico_add_right_sub_eq
{α : Type u_1}
{M : Type u_2}
[AddCommMonoid M]
{f : α → M}
[OrderedCancelAddCommMonoid α]
[ExistsAddOfLE α]
[LocallyFiniteOrder α]
[Sub α]
[OrderedSub α]
(a b c : α)
:
theorem
Finset.prod_Ico_succ_top
{M : Type u_2}
[CommMonoid M]
{a b : ℕ}
(hab : a ≤ b)
(f : ℕ → M)
:
theorem
Finset.sum_Ico_succ_top
{M : Type u_2}
[AddCommMonoid M]
{a b : ℕ}
(hab : a ≤ b)
(f : ℕ → M)
:
theorem
Finset.prod_Ioc_succ_top
{M : Type u_2}
[CommMonoid M]
{a b : ℕ}
(hab : a ≤ b)
(f : ℕ → M)
:
theorem
Finset.sum_Ioc_succ_top
{M : Type u_2}
[AddCommMonoid M]
{a b : ℕ}
(hab : a ≤ b)
(f : ℕ → M)
:
theorem
Finset.prod_Icc_succ_top
{M : Type u_2}
[CommMonoid M]
{a b : ℕ}
(hab : a ≤ b + 1)
(f : ℕ → M)
:
theorem
Finset.sum_Icc_succ_top
{M : Type u_2}
[AddCommMonoid M]
{a b : ℕ}
(hab : a ≤ b + 1)
(f : ℕ → M)
:
theorem
Finset.prod_range_mul_prod_Ico
{M : Type u_2}
[CommMonoid M]
(f : ℕ → M)
{m n : ℕ}
(h : m ≤ n)
:
theorem
Finset.sum_range_add_sum_Ico
{M : Type u_2}
[AddCommMonoid M]
(f : ℕ → M)
{m n : ℕ}
(h : m ≤ n)
:
theorem
Finset.prod_range_eq_mul_Ico
{M : Type u_2}
[CommMonoid M]
(f : ℕ → M)
{n : ℕ}
(hn : 0 < n)
:
theorem
Finset.sum_range_eq_add_Ico
{M : Type u_2}
[AddCommMonoid M]
(f : ℕ → M)
{n : ℕ}
(hn : 0 < n)
:
theorem
Finset.sum_Ico_eq_add_neg
{δ : Type u_3}
[AddCommGroup δ]
(f : ℕ → δ)
{m n : ℕ}
(h : m ≤ n)
:
The two ways of summing over (i, j)
in the range a ≤ i ≤ j < b
are equal.
The two ways of summing over (i, j)
in the range a ≤ i < j < b
are equal.
theorem
Finset.sum_Ico_sub_bot
{M : Type u_3}
(f : ℕ → M)
{m n : ℕ}
[AddCommGroup M]
(hmn : m < n)
:
theorem
Finset.sum_Ico_succ_sub_top
{M : Type u_3}
(f : ℕ → M)
{m n : ℕ}
[AddCommGroup M]
(hmn : m ≤ n)
: