Unital algebras¶
- class sage.categories.unital_algebras.UnitalAlgebras(base_category)[source]¶
- Bases: - CategoryWithAxiom_over_base_ring- The category of non-associative algebras over a given base ring. - A non-associative algebra over a ring \(R\) is a module over \(R\) which is also a unital magma. - Warning - Until Issue #15043 is implemented, - Algebrasis the category of associative unital algebras; thus, unlike the name suggests,- UnitalAlgebrasis not a subcategory of- Algebrasbut of- MagmaticAlgebras.- EXAMPLES: - sage: from sage.categories.unital_algebras import UnitalAlgebras sage: C = UnitalAlgebras(ZZ); C Category of unital algebras over Integer Ring - >>> from sage.all import * >>> from sage.categories.unital_algebras import UnitalAlgebras >>> C = UnitalAlgebras(ZZ); C Category of unital algebras over Integer Ring - class CartesianProducts(category, *args)[source]¶
- Bases: - CartesianProductsCategory- The category of unital algebras constructed as Cartesian products of unital algebras. - This construction gives the direct product of algebras. See discussion on: - class ParentMethods[source]¶
- Bases: - object- one()[source]¶
- Return the multiplicative unit element. - EXAMPLES: - sage: # needs sage.graphs sage.modules sage: S2 = simplicial_complexes.Sphere(2) sage: H = S2.cohomology_ring(QQ) sage: C = cartesian_product([H, H]) sage: one = C.one() sage: one B[(0, (0, 0))] + B[(1, (0, 0))] sage: one == one * one True sage: all(b == b * one for b in C.basis()) True - >>> from sage.all import * >>> # needs sage.graphs sage.modules >>> S2 = simplicial_complexes.Sphere(Integer(2)) >>> H = S2.cohomology_ring(QQ) >>> C = cartesian_product([H, H]) >>> one = C.one() >>> one B[(0, (0, 0))] + B[(1, (0, 0))] >>> one == one * one True >>> all(b == b * one for b in C.basis()) True 
 
 - extra_super_categories()[source]¶
- A Cartesian product of algebras is endowed with a natural unital algebra structure. - EXAMPLES: - sage: from sage.categories.unital_algebras import UnitalAlgebras sage: C = UnitalAlgebras(QQ).CartesianProducts() sage: C.extra_super_categories() [Category of unital algebras over Rational Field] sage: sorted(C.super_categories(), key=str) [Category of Cartesian products of distributive magmas and additive magmas, Category of Cartesian products of unital magmas, Category of Cartesian products of vector spaces over Rational Field, Category of unital algebras over Rational Field] - >>> from sage.all import * >>> from sage.categories.unital_algebras import UnitalAlgebras >>> C = UnitalAlgebras(QQ).CartesianProducts() >>> C.extra_super_categories() [Category of unital algebras over Rational Field] >>> sorted(C.super_categories(), key=str) [Category of Cartesian products of distributive magmas and additive magmas, Category of Cartesian products of unital magmas, Category of Cartesian products of vector spaces over Rational Field, Category of unital algebras over Rational Field] 
 
 - class ParentMethods[source]¶
- Bases: - object- from_base_ring(r)[source]¶
- Return the canonical embedding of - rinto- self.- INPUT: - r– an element of- self.base_ring()
 - EXAMPLES: - sage: A = AlgebrasWithBasis(QQ).example(); A # needs sage.combinat sage.modules An example of an algebra with basis: the free algebra on the generators ('a', 'b', 'c') over Rational Field sage: A.from_base_ring(1) # needs sage.combinat sage.modules B[word: ] - >>> from sage.all import * >>> A = AlgebrasWithBasis(QQ).example(); A # needs sage.combinat sage.modules An example of an algebra with basis: the free algebra on the generators ('a', 'b', 'c') over Rational Field >>> A.from_base_ring(Integer(1)) # needs sage.combinat sage.modules B[word: ] 
 
 - class WithBasis(base_category)[source]¶
- Bases: - CategoryWithAxiom_over_base_ring- class ParentMethods[source]¶
- Bases: - object- from_base_ring_from_one_basis(r)[source]¶
- Implement the canonical embedding from the ground ring. - INPUT: - r– an element of the coefficient ring
 - EXAMPLES: - sage: # needs sage.combinat sage.modules sage: A = AlgebrasWithBasis(QQ).example() sage: A.from_base_ring_from_one_basis(3) 3*B[word: ] sage: A.from_base_ring(3) 3*B[word: ] sage: A(3) 3*B[word: ] - >>> from sage.all import * >>> # needs sage.combinat sage.modules >>> A = AlgebrasWithBasis(QQ).example() >>> A.from_base_ring_from_one_basis(Integer(3)) 3*B[word: ] >>> A.from_base_ring(Integer(3)) 3*B[word: ] >>> A(Integer(3)) 3*B[word: ] 
 - one()[source]¶
- Return the multiplicative unit element. - EXAMPLES: - sage: A = AlgebrasWithBasis(QQ).example() # needs sage.combinat sage.modules sage: A.one_basis() # needs sage.combinat sage.modules word: sage: A.one() # needs sage.combinat sage.modules B[word: ] - >>> from sage.all import * >>> A = AlgebrasWithBasis(QQ).example() # needs sage.combinat sage.modules >>> A.one_basis() # needs sage.combinat sage.modules word: >>> A.one() # needs sage.combinat sage.modules B[word: ] 
 - one_basis()[source]¶
- When the one of an algebra with basis is an element of this basis, this optional method can return the index of this element. This is used to provide a default implementation of - one(), and an optimized default implementation of- from_base_ring().- EXAMPLES: - sage: # needs sage.combinat sage.modules sage: A = AlgebrasWithBasis(QQ).example() sage: A.one_basis() word: sage: A.one() B[word: ] sage: A.from_base_ring(4) 4*B[word: ] - >>> from sage.all import * >>> # needs sage.combinat sage.modules >>> A = AlgebrasWithBasis(QQ).example() >>> A.one_basis() word: >>> A.one() B[word: ] >>> A.from_base_ring(Integer(4)) 4*B[word: ] 
 - one_from_one_basis()[source]¶
- Return the one of the algebra, as per - Monoids.ParentMethods.one()- By default, this is implemented from - one_basis(), if available.- EXAMPLES: - sage: # needs sage.combinat sage.modules sage: A = AlgebrasWithBasis(QQ).example() sage: A.one_basis() word: sage: A.one_from_one_basis() B[word: ] sage: A.one() B[word: ] - >>> from sage.all import * >>> # needs sage.combinat sage.modules >>> A = AlgebrasWithBasis(QQ).example() >>> A.one_basis() word: >>> A.one_from_one_basis() B[word: ] >>> A.one() B[word: ]