mirror of
https://github.com/kalmarek/PropertyT.jl.git
synced 2025-01-12 06:32:34 +01:00
reworked reconstruct_sol with axpy!
This commit is contained in:
parent
33dc278762
commit
f3d813cb67
@ -166,17 +166,24 @@ end
|
||||
|
||||
function reconstruct_sol{T<:GroupElem, S<:Nemo.perm}(preps::Dict{T, S},
|
||||
aUs::Vector, aPs::Vector, adims::Vector)
|
||||
s = size(first(mreps).second)
|
||||
recP = zeros(Float64, s)
|
||||
tmp = [zeros(Float64, s) for _ in 1:length(Us)]
|
||||
ks = [(g, inv(g)) for g in keys(mreps)]
|
||||
|
||||
Threads.@threads for π in 1:length(Us)
|
||||
for (g, invg) in ks
|
||||
tmp[π] += dims[π]*mreps[g]*Us[π]*Ps[π]*Us[π]'*mreps[invg]
|
||||
idx = [π for π in 1:length(aUs) if size(aUs[π], 2) != 0]
|
||||
Us = aUs[idx]
|
||||
Ps = aPs[idx]
|
||||
dims = adims[idx];
|
||||
|
||||
l = length(Us)
|
||||
transfP = [dims[π].*Us[π]*Ps[π]*Us[π]' for π in 1:l]
|
||||
tmp = [zeros(Float64, size(first(transfP))) for _ in 1:l]
|
||||
perms = collect(keys(preps))
|
||||
|
||||
@inbounds Threads.@threads for π in 1:l
|
||||
for p in perms
|
||||
BLAS.axpy!(1.0, view(transfP[π], preps[p].d, preps[p].d), tmp[π])
|
||||
end
|
||||
end
|
||||
recP += 1/length(keys(mreps)) .* sum(tmp)
|
||||
|
||||
recP = 1/length(perms) .* sum(tmp)
|
||||
recP[abs.(recP) .< eps(eltype(recP))] = zero(eltype(recP))
|
||||
return recP
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user