Skip to content

Commit

Permalink
feat: clean up for algebras
Browse files Browse the repository at this point in the history
  • Loading branch information
thofma committed Sep 22, 2024
1 parent 2601ba7 commit 0b362cd
Show file tree
Hide file tree
Showing 14 changed files with 255 additions and 201 deletions.
4 changes: 2 additions & 2 deletions src/AlgAss/AbsAlgAss.jl
Original file line number Diff line number Diff line change
Expand Up @@ -727,7 +727,7 @@ of the basis elements of $A$ and a map from $B$ to $A$.
function regular_matrix_algebra(A::Union{ StructureConstantAlgebra, GroupAlgebra })
K = base_ring(A)
B = matrix_algebra(K, [ representation_matrix(A[i], :right) for i = 1:dim(A) ], isbasis = true)
return B, hom(B, A, identity_matrix(K, dim(A)), identity_matrix(K, dim(A)))
return B, hom(B, A, identity_matrix(K, dim(A)), identity_matrix(K, dim(A)); check = false)
end

###############################################################################
Expand Down Expand Up @@ -1117,7 +1117,7 @@ function product_of_components_with_projection(A::AbstractAssociativeAlgebra, a:
for b in basis(A)
push!(imgs, sum(injstoB[i](injs[i]\b) for i in eachindex(a); init = zero(B)))
end
p = hom(A, B, basis_matrix(imgs))
p = hom(A, B, basis_matrix(imgs); check = false)
_transport_refined_wedderburn_decomposition_forward(p)
return B, p
end
Expand Down
2 changes: 1 addition & 1 deletion src/AlgAss/AlgGrp.jl
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ denominator_of_multiplication_table(A::GroupAlgebra{QQFieldElem}) = one(ZZ)

base_ring(A::GroupAlgebra{T}) where {T} = A.base_ring::parent_type(T)

base_ring_type(::Type{GroupAlgebra{T}}) where {T} = parent_type(T)
base_ring_type(::Type{GroupAlgebra{T, S, R}}) where {T, S, R} = parent_type(T)

Generic.dim(A::GroupAlgebra) = size(multiplication_table(A, copy = false), 1)

Expand Down
8 changes: 7 additions & 1 deletion src/AlgAss/AlgMat.jl
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,13 @@ base_ring_type(::Type{MatAlgebra{T, S}}) where {T, S} = parent_type(T)

coefficient_ring(A::MatAlgebra{T, S}) where {T, S} = A.coefficient_ring::base_ring_type(S)

basis(A::MatAlgebra) = A.basis::Vector{elem_type(A)}
function basis(A::MatAlgebra; copy::Bool = true)
if copy
return Base.copy(A.basis::Vector{elem_type(A)})
else
return A.basis::Vector{elem_type(A)}
end
end

has_one(A::MatAlgebra) = true

Expand Down
5 changes: 5 additions & 0 deletions src/AlgAss/Elem.jl
Original file line number Diff line number Diff line change
Expand Up @@ -644,6 +644,11 @@ function (A::GroupAlgebra)(a::GroupAlgebraElem)
return a
end

function (A::MatAlgebra)(a::MatAlgebraElem)
@assert parent(a) == A "Wrong parent"
return a
end

# For polynomial substitution
for T in subtypes(AbstractAssociativeAlgebra)
@eval begin
Expand Down
Loading

0 comments on commit 0b362cd

Please sign in to comment.