Skip to content

Commit

Permalink
improve performance for sparse matrix vector indexing (JuliaLang#29696)
Browse files Browse the repository at this point in the history
  • Loading branch information
KristofferC authored Oct 22, 2018
1 parent 2a01598 commit 0e023d0
Showing 1 changed file with 22 additions and 8 deletions.
30 changes: 22 additions & 8 deletions stdlib/SparseArrays/src/sparsematrix.jl
Original file line number Diff line number Diff line change
Expand Up @@ -2235,27 +2235,41 @@ function permute_rows!(S::SparseMatrixCSC{Tv,Ti}, pI::Vector{Int}) where {Tv,Ti}
colptrS = S.colptr; rowvalS = S.rowval; nzvalS = S.nzval
# preallocate temporary sort space
nr = min(nnz(S), m)

rowperm = Vector{Int}(undef, nr)
rowvalTemp = Vector{Ti}(undef, nr)
nzvalTemp = Vector{Tv}(undef, nr)
rowval_temp = Vector{Ti}(undef, nr)
rnzval_temp = Vector{Tv}(undef, nr)
perm = Base.Perm(Base.ord(isless, identity, false, Base.Order.Forward), rowval_temp)

@inbounds for j in 1:n
rowrange = colptrS[j]:(colptrS[j+1]-1)
rowrange = nzrange(S, j)
nr = length(rowrange)
resize!(rowperm, nr)
resize!(rowval_temp, nr)
(nr > 0) || continue
k = 1
for i in rowrange
rowA = rowvalS[i]
rowvalTemp[k] = pI[rowA]
nzvalTemp[k] = nzvalS[i]
rowval_temp[k] = pI[rowA]
rnzval_temp[k] = nzvalS[i]
k += 1
end
sortperm!(unsafe_wrap(Vector{Int}, pointer(rowperm), nr), unsafe_wrap(Vector{Ti}, pointer(rowvalTemp), nr))

if nr <= 16
alg = Base.Sort.InsertionSort
else
alg = Base.Sort.QuickSort
end

# Reset permutation
rowperm .= 1:nr
sort!(rowperm, alg, perm)

k = 1
for i in rowrange
kperm = rowperm[k]
rowvalS[i] = rowvalTemp[kperm]
nzvalS[i] = nzvalTemp[kperm]
rowvalS[i] = rowval_temp[kperm]
nzvalS[i] = rnzval_temp[kperm]
k += 1
end
end
Expand Down

0 comments on commit 0e023d0

Please sign in to comment.