1
0
mirror of https://github.com/kalmarek/GroupRings.jl.git synced 2025-01-04 04:10:28 +01:00

Performance tweaks to mul!

This commit is contained in:
kalmarek 2017-08-27 20:38:02 +02:00
parent 53c1872d0d
commit 0e8cec9f41

View File

@ -352,9 +352,12 @@ function mul!{T}(result::AbstractVector{T},
pm::Array{Int,2}) pm::Array{Int,2})
z = zero(T) z = zero(T)
result .= z result .= z
for j in 1:length(Y) lY = length(Y)
s = size(pm,1)
@inbounds for j in 1:lY
if Y[j] != z if Y[j] != z
for i in 1:size(pm,1) for i in 1:s
if X[i] != z if X[i] != z
pm[i,j] == 0 && throw(ArgumentError("The product don't seem to be supported on basis!")) pm[i,j] == 0 && throw(ArgumentError("The product don't seem to be supported on basis!"))
result[pm[i,j]] += X[i]*Y[j] result[pm[i,j]] += X[i]*Y[j]
@ -386,15 +389,18 @@ function mul!{T}(result::GroupRingElem{T}, X::GroupRingElem, Y::GroupRingElem)
RG = parent(X) RG = parent(X)
lX = length(X.coeffs)
lY = length(Y.coeffs)
if isdefined(RG, :pm) if isdefined(RG, :pm)
s = size(RG.pm) s = size(RG.pm)
findlast(X.coeffs) <= s[1] || throw("Element in X outside of support of RG.pm")
findlast(Y.coeffs) <= s[2] || throw("Element in Y outside of support of RG.pm")
for j::Int in 1:length(Y.coeffs) for j in 1:lY
if Y.coeffs[j] != z if Y.coeffs[j] != z
j <= s[2] || throw("Element in Y outside of support of RG.pm") for i in 1:lX
for i::Int in 1:length(X.coeffs)
if X.coeffs[i] != z if X.coeffs[i] != z
i <= s[1] || throw("Element in X outside of support of RG.pm")
if RG.pm[i,j] == 0 if RG.pm[i,j] == 0
RG.pm[i,j] = RG.basis_dict[RG.basis[i]*RG.basis[j]] RG.pm[i,j] = RG.basis_dict[RG.basis[i]*RG.basis[j]]
end end
@ -404,9 +410,9 @@ function mul!{T}(result::GroupRingElem{T}, X::GroupRingElem, Y::GroupRingElem)
end end
end end
else else
for j::Int in 1:length(Y.coeffs) for j::Int in 1:lY
if Y.coeffs[j] != z if Y.coeffs[j] != z
for i::Int in 1:length(X.coeffs) for i::Int in 1:lX
if X.coeffs[i] != z if X.coeffs[i] != z
result[RG.basis[i]*RG.basis[j]] += X[i]*Y[j] result[RG.basis[i]*RG.basis[j]] += X[i]*Y[j]
end end