feat(library/data/finset): add bigop for finset + commutative groups
This commit is contained in:
parent
795acc70a6
commit
a223b9b1f7
3 changed files with 28 additions and 2 deletions
|
@ -7,7 +7,7 @@ Author: Leonardo de Moura
|
||||||
|
|
||||||
Finite sets
|
Finite sets
|
||||||
-/
|
-/
|
||||||
import data.nat data.list.perm data.subtype algebra.binary algebra.function logic.identities
|
import data.nat data.list.perm data.subtype algebra.binary
|
||||||
open nat quot list subtype binary function
|
open nat quot list subtype binary function
|
||||||
open [declarations] perm
|
open [declarations] perm
|
||||||
|
|
||||||
|
|
26
library/data/finset/bigop.lean
Normal file
26
library/data/finset/bigop.lean
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
/-
|
||||||
|
Copyright (c) 2015 Microsoft Corporation. All rights reserved.
|
||||||
|
Released under Apache 2.0 license as described in the file LICENSE.
|
||||||
|
|
||||||
|
Module: data.finset
|
||||||
|
Author: Leonardo de Moura
|
||||||
|
|
||||||
|
Finite sets big operators
|
||||||
|
-/
|
||||||
|
import algebra.group data.finset.basic
|
||||||
|
open algebra finset function binary quot
|
||||||
|
|
||||||
|
namespace finset
|
||||||
|
variables {A B : Type}
|
||||||
|
variable [g : comm_group B]
|
||||||
|
include g
|
||||||
|
|
||||||
|
protected definition mulf (f : A → B) : B → A → B :=
|
||||||
|
λ b a, b * f a
|
||||||
|
|
||||||
|
protected theorem mulf_rcomm (f : A → B) : right_commutative (mulf f) :=
|
||||||
|
right_commutative_compose_right (@has_mul.mul B g) f (@mul.right_comm B g)
|
||||||
|
|
||||||
|
definition bigop (s : finset A) (f : A → B) : B :=
|
||||||
|
acc (mulf f) (mulf_rcomm f) 1 s
|
||||||
|
end finset
|
|
@ -7,4 +7,4 @@ Author: Leonardo de Moura
|
||||||
|
|
||||||
Finite sets
|
Finite sets
|
||||||
-/
|
-/
|
||||||
import data.finset.basic
|
import data.finset.basic data.finset.bigop
|
||||||
|
|
Loading…
Reference in a new issue