- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 5.7k
          Improve performance of svd and eigen of Diagonals
          #43856
        
          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
Conversation
This reduces lots of intermediate array allocations, and now even works with (Furlong) units.
| This is a wonderful example why splitting LinearAlgebra and SparseArrays was really useful. See the benchmarks: julia> D = Diagonal(randn(1024));
julia> @btime svd($D);
  16.898 ms (10275 allocations: 866.75 KiB) # old behavior with sparse U and Vt
julia> @btime svd($D);
  11.371 ms (2076 allocations: 40.38 MiB) # before this PR: dense output + temporary allocations
julia> @btime svd($D);
  1.506 ms (8 allocations: 16.02 MiB) # this PR: dense output + seemingly no unnecessary allocationsWhile sparse output is good from a memory perspective, writing into an initially empty sparse matrix is slow. I think the same is true for the multiplications listed in 14154fc#commitcomment-64103782. Honestly, I hadn't seen that coming. 😅  So, I believe the "new" defaults ( Pinging some involved people to make sure they join me in my little github celebration 🎉 : @vtjnash @KristofferC @ViralBShah 😄 | 
svd(::Diagonal)svd and eigen of Diagonals
      | This also fixes an issue in sorted  | 
| I tried to backport this to 1.6 but got a test error: julia> E = eigen(Du)
Eigen{Furlong{0, Float64}, Furlong{1, Float64}, Matrix{Furlong{0, Float64}}, Vector{Furlong{1, Float64}}}
values:
3-element Vector{Furlong{1, Float64}}:
  Furlong{1, Float64}(-0.5153917252601611)
 Furlong{1, Float64}(-0.23809233488008882)
   Furlong{1, Float64}(0.1571713328338422)
vectors:
3×3 Matrix{Furlong{0, Float64}}:
 Furlong{0, Float64}(1.0)  Furlong{0, Float64}(0.0)  Furlong{0, Float64}(0.0)
 Furlong{0, Float64}(0.0)  Furlong{0, Float64}(1.0)  Furlong{0, Float64}(0.0)
 Furlong{0, Float64}(0.0)  Furlong{0, Float64}(0.0)  Furlong{0, Float64}(1.0)
julia> @test Matrix(E) == Du
Error During Test at REPL[55]:1
  Test threw exception
  Expression: Matrix(E) == Du
  AssertionError: p == q
  Stacktrace:
    [1] Furlong{1, Float64}(x::Furlong{0, Float64})
      @ Main.Furlongs ~/julia/test/testhelpers/Furlongs.jl:20
    [2] convert(#unused#::Type{Furlong{1, Float64}}, x::Furlong{0, Float64})
...at julia/stdlib/LinearAlgebra/test/diagonal.jl Line 427 in ac1d693 
 | 
| I can reproduce. I think the diagonal multiplication code must have changed between versions, and on v1.6 it cannot multiply  | 
| why are we back porting? isn't this just a performance improvement? | 
| 
 So it is unit correct now. | 
| First of all, it contains a fix for the aliasing of  | 
This reduces lots of intermediate array allocations, and now even works with (Furlong) units. I'll add a test for that case later.