-
Notifications
You must be signed in to change notification settings - Fork 188
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Convert to sparse #204
Comments
No, right now PyCall does not know about the SciPy sparse-matrix formats. |
(You could write the conversion routine yourself on top of other PyCall functions, of course.) |
Thank you Steven. @pyimport scipy.sparse as sp
Apy = sp.rand(30,30,0.3)
IA, JA, SA = sp.find(Apy)
IA, JA = convert(Array{Int64},IA+1), convert(Array{Int64},JA+1)
Aju = sparse(IA,JA,SA) |
@edljk, glad you got it working. The const scipy_sparse_find = pyimport("scipy.sparse")["find"]
function mysparse(Apy::PyObject)
IA, JA, SA = scipy_sparse_find(Apy)
return sparse(Int[i+1 for i in IA], Int[i+1 for i in JA], SA)
end (This is in Julia 0.4. To get code that works with Julia 0.3 too, you need to do |
To get much more efficient than this, I think one would have to write specialized code depending on the SciPy sparse-matrix format. e.g. for CSC or CSR storage you can probably do better. |
I had the same exact need, and I ended up with this gist. @pyimport scipy.sparse as pysparse
jlmat2pymat(S::SparseMatrixCSC) =
pysparse.csc_matrix((S.nzval, S.rowval .- 1, S.colptr .- 1), shape=size(S))
pymat2jlmat(S::PyObject) =
SparseMatrixCSC(S[:m], S[:n], S[:indptr] .+ 1, S[:indices] .+ 1, S[:data]) I'd like to just add conversion for sparse matrices as a feature for PyCall.jl, but I'm struggling to wrap my head around where it would fit into the existing structure. Could I just add these wrappers to numpy.jl and add it as a conversion step to SparseMatrixCSC? |
@nsaphra, thanks for looking into this. You would add something like: PyObject(S::SparseMatrixCSC) =
pyimport("scipy.sparse")["csc_matrix"]((S.nzval, S.rowval .- 1, S.colptr .- 1), shape=size(S))
convert(::Type{SparseMatrixCSC}, o::PyObject) =
SparseMatrixCSC(o[:m], o[:n], o[:indptr] .+ 1, p[:indices] .+ 1, o[:data]) though it might be nice to add more checks. |
I just encountered this and I also needed the functions. Is this still open? If the code to be used is just what was given in @stevengj last comment, could this be just added and it is fine? Or there are more things necessary that I am missing? I am more than glad to do the PR, since it will take only 5 minutes (if this is indeed resolved). EDIT: The functions provided by @nsaphra 's post do not work for me. My object is:
and it doesn't have keys Second edit: The original idea @edljk works, i.e.: const scipy_sparse_find = pyimport("scipy.sparse")["find"]
function mysparse(Apy::PyObject)
IA, JA, SA = scipy_sparse_find(Apy)
return sparse(Int[i+1 for i in IA], Int[i+1 for i in JA], SA)
end (as modified by @stevengj ) |
A PR seems reasonable, although it should be structured so as not to create a dependency on scipy unless these functions are actually used. (i.e. the module should be imported lazily). |
Could you hint me how to do this? I've never do this "lazily import a module" before. What I know is that I can use Requires |
Lazily importing a Python module: const scipysparse_ = PyNULL() # will be initialized to scipy.sparse module when needed
scipysparse() = scipysparse_.o == C_NULL ? copy!(scipysparse_, pyimport_conda("scipy.sparse", "scipy")) : scipysparse_ and then use |
Are there any news on this? |
Is there a way to convert a PyObject containing a sparse matrix to a Julia sparse Matrix type ?
The text was updated successfully, but these errors were encountered: