Skip to content
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

Backslash with SparseMatrix falls back to the generic backslash method #333

Closed
KristofferC opened this issue May 24, 2016 · 14 comments
Closed
Labels
sparse Sparse arrays

Comments

@KristofferC
Copy link
Member

KristofferC commented May 24, 2016

This means that cholmod is actually never used even if the matrix is pos def for backslash.

julia> typeof(A)
SparseMatrixCSC{Float64,Int64}

julia> isposdef(A)
true

julia> typeof(x)
Array{Float64,1}

julia> @which A\x
\(A::AbstractArray{T<:Any,2}, B::Union{AbstractArray{T<:Any,1},AbstractArray{T<:Any,2}}) at linalg/generic.jl:333

julia> @time A \ x; # Uses LU factorization because the generic factorize uses this for square matrices
 13.809494 seconds (87 allocations: 1.744 GB, 0.97% gc time)

julia> @time factorize(A) \ x; # Uses Cholesky factorization 
  3.442693 seconds (79 allocations: 648.282 MB, 0.20% gc time)

Shouldn't backslash for sparse matrices use the factorize methods defined at https://github.com/JuliaLang/julia/blob/master/base/sparse/linalg.jl#L859?

cc @andreasnoack

@KristofferC KristofferC changed the title Backslash with SparseMatrix falls back to the generic factorize method Backslash with SparseMatrix falls back to the generic backslash method May 24, 2016
@andreasnoack
Copy link
Member

I'll have to look a little more into this. I consolidated some of the \ logic at some point and maybe something unintentional happened.

@andreasnoack
Copy link
Member

I think it was an unanticipated consequence of JuliaLang/julia@87e26c5. We should probably have what you suggested so it would be great if you could prepare a PR.

@KristofferC
Copy link
Member Author

I tried the easy way with just \(A, x) = factorize(A) \ x but it fails on the @inferred test in spqr.jl. Julia infers Any from factorize and that of course propagates to \.

@andreasnoack
Copy link
Member

..and suddenly I remember the issue and the reason why I added the @inferred test. We might have to add a \ method that is almost identical to factorize.

@tkelman
Copy link

tkelman commented Jun 16, 2016

@Sacha0 any chance you could take a look at this one? would be much-appreciated!

@Sacha0
Copy link
Member

Sacha0 commented Jun 17, 2016

any chance you could take a look at this one?

Shall do!

Sacha0 referenced this issue in Sacha0/julia Jun 17, 2016
…ecking that that specialized method gets called, a simple if inelegant fix for #16548.
Sacha0 referenced this issue in Sacha0/julia Jun 17, 2016
…ecking that that specialized method gets called, a simple if inelegant fix for #16548.
Sacha0 referenced this issue in Sacha0/julia Jun 17, 2016
…ecking that that specialized method gets called, a simple if inelegant fix for #16548.
@Sacha0
Copy link
Member

Sacha0 commented Jun 17, 2016

any chance you could take a look at this one?

Shall do!

@tkelman I should be able to spend a decent fraction of the coming week on things Julia. So if there are similar RC-freeze-related tasks in need of attention, please don't hesitate to ask. Best!

@JaredCrean2
Copy link

I don't think I can add labels, but if any issue deserves the needs-a-test label, this one does.

@KristofferC
Copy link
Member Author

JuliaLang/julia#16979 includes a test, albeit brittle

@JaredCrean2
Copy link

Cool. Dispatch tests like that are important.

@tkelman
Copy link

tkelman commented Jun 17, 2016

We just took it off the milestone, but maybe you'd be able to make a little bit of headway on #257 while Andreas is overloaded with JuliaCon organizing?

@KristofferC
Copy link
Member Author

Took what off milestone?

vtjnash referenced this issue in JuliaLang/julia Jun 23, 2016
Simple but inelegant fix for #16548
@Sacha0
Copy link
Member

Sacha0 commented Jun 23, 2016

Close with benefit of JuliaLang/julia#16979 and open a new issue to track JuliaLang/julia#16979 (comment) / JuliaLang/julia#16979 (comment), or leave this issue open to track those points?

@KristofferC
Copy link
Member Author

Let's close since the actual problem is fixed. Can have another issue for the style "problem".

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
sparse Sparse arrays
Projects
None yet
Development

No branches or pull requests

5 participants