Additively-graded multiplicative action structures #
This module provides a set of heterogeneous typeclasses for defining a multiplicative structure
over the sigma type GradedMonoid A
such that (•) : A i → M j → M (i +ᵥ j)
; that is to say, A
has an additively-graded multiplicative action on M
. The typeclasses are:
With the SigmaGraded
locale open, these respectively imbue:
For now, these typeclasses are primarily used in the construction of DirectSum.GModule.Module
and
the rest of that file.
Internally graded multiplicative actions #
In addition to the above typeclasses, in the most frequent case when A
is an indexed collection of
SetLike
subobjects (such as AddSubmonoid
s, AddSubgroup
s, or Submodule
s), this file
provides the Prop
typeclasses:
SetLike.GradedSMul A M
(which provides the obviousGradedMonoid.GSMul A
instance)
which provides the API lemma
SetLike.graded_smul_mem_graded
Note that there is no need for SetLike.graded_mul_action
or similar, as all the information it
would contain is already supplied by GradedSMul
when the objects within A
and M
have
a MulAction
instance.
Tags #
graded action
Typeclasses #
A graded version of Mul.toSMul
Equations
- GradedMonoid.GMul.toGSMul A = { smul := fun {i j : ιA} => GradedMonoid.GMul.mul }
Equations
- GradedMonoid.GSMul.toSMul A M = { smul := fun (x : GradedMonoid A) (y : GradedMonoid M) => ⟨x.fst +ᵥ y.fst, GradedMonoid.GSMul.smul x.snd y.snd⟩ }
A graded version of MulAction
.
- smul : {i : ιA} → {j : ιM} → A i → M j → M (i +ᵥ j)
- one_smul : ∀ (b : GradedMonoid M), 1 • b = b
One is the neutral element for
•
- mul_smul : ∀ (a a' : GradedMonoid A) (b : GradedMonoid M), (a * a') • b = a • a' • b
Associativity of
•
and*
Instances
One is the neutral element for •
Associativity of •
and *
The graded version of Monoid.toMulAction
.
Equations
Equations
Shorthands for creating instance of the above typeclasses for collections of subobjects #
Equations
- SetLike.toGSMul A B = { smul := fun {i : ιA} {j : ιB} (a : ↥(A i)) (b : ↥(B j)) => ⟨↑a • ↑b, ⋯⟩ }
Internally graded version of Mul.toSMul
.
Equations
- ⋯ = ⋯