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

Display sparse matrices by showing their structure with braille patterns #33821

Merged
merged 31 commits into from
May 22, 2020
Merged
Show file tree
Hide file tree
Changes from 28 commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
3918e34
Display sparse matrices by showing their structure with braille patterns
goggle Nov 12, 2019
e45c6ab
Adopt test which involves showing of sparse matrix
goggle Nov 12, 2019
e871927
Adopt docstrings
goggle Nov 12, 2019
4223e4a
Call `rowvals(S)` only once
goggle Nov 13, 2019
ff9bc5a
Extend code documentation
goggle Nov 13, 2019
64b111e
Simplify calculation of `scaleHeight` and `scaleWidth`
goggle Nov 17, 2019
4c0f3d2
Make `brailleBlocks` a `const`
goggle Nov 17, 2019
78e1ade
Initialize `brailleGrid` with `UInt16(10240)`
goggle Nov 17, 2019
0bcb47a
Let the compiler do the conversion of `\n`
goggle Nov 17, 2019
7a7b32a
Improve printing to `io`
goggle Nov 17, 2019
c324db5
Unwrap the helper functions directly into the loop
goggle Nov 17, 2019
b96ee2a
Show small sparse matrix in traditional manner
goggle Nov 18, 2019
d919d85
Add tests for `isstored`
goggle Nov 18, 2019
6c79e6b
Adapt tests for `show`
goggle Nov 18, 2019
49e8fc2
Adapt doctests
goggle Nov 18, 2019
246d9d1
Use `m` and `n` instead of `size` calls
goggle Nov 18, 2019
6ceae94
Initialize `scaleHeight` and `scaleWidth` in `else` clause
goggle Nov 18, 2019
e93dafc
Reenable commented test
goggle Nov 18, 2019
0ea6ee9
Declare type of `maxHeight` and `maxWidth`
goggle Nov 19, 2019
748c108
Do not print leading newline in `_show_with_braille_patterns`
goggle Nov 19, 2019
c8aa9de
Reenable test for issue 30589
goggle Nov 20, 2019
1e1af8e
Shorten type declarations of `maxHeight` and `maxWidth`
goggle Nov 26, 2019
c50bb66
Add `isstored` to Base
goggle Nov 26, 2019
7c772d9
Add `isstored` for sparse vectors
goggle Nov 26, 2019
0de07c2
Make use of Base function `isstored`
goggle Nov 26, 2019
bd7431c
Add `boundscheck` macro
goggle Nov 26, 2019
c998d75
Clarify news
goggle Nov 26, 2019
25f211d
Call `issorted` by `Base.issored`
goggle Nov 26, 2019
2fdfc20
Use `Base.isstored` in tests
goggle Nov 26, 2019
3f095bb
Set cutoff value to print sparse matrices with braille to 16
goggle Nov 28, 2019
f8495b1
Merge branch 'master' into 30587-spy-printing-sparse-matrices
stevengj May 21, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,8 @@ Standard library changes

#### SparseArrays

* Display large sparse matrices with a Unicode "spy" plot of their nonzero patterns, and display small sparse matrices by an `Matrix`-like 2d layout of their contents.

#### Dates

#### Statistics
Expand Down
5 changes: 5 additions & 0 deletions base/abstractarray.jl
Original file line number Diff line number Diff line change
Expand Up @@ -413,6 +413,11 @@ function isassigned(a::AbstractArray, i::Integer...)
end
end

function isstored(A::AbstractArray{<:Any,N}, I::Vararg{Integer,N}) where {N}
@boundscheck checkbounds(A, I...)
return true
end

# used to compute "end" for last index
function trailingsize(A, n)
s = 1
Expand Down
8 changes: 4 additions & 4 deletions stdlib/LinearAlgebra/src/svd.jl
Original file line number Diff line number Diff line change
Expand Up @@ -355,12 +355,12 @@ Q factor:
0.0 1.0
D1 factor:
2×2 SparseArrays.SparseMatrixCSC{Float64,Int64} with 2 stored entries:
[1, 1] = 0.707107
[2, 2] = 0.707107
0.707107
0.707107
D2 factor:
2×2 SparseArrays.SparseMatrixCSC{Float64,Int64} with 2 stored entries:
[1, 1] = 0.707107
[2, 2] = 0.707107
0.707107
0.707107
R0 factor:
2×2 Array{Float64,2}:
1.41421 0.0
Expand Down
31 changes: 16 additions & 15 deletions stdlib/SparseArrays/docs/src/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,15 +52,15 @@ remove stored zeros from the sparse matrix.
```jldoctest
julia> A = sparse([1, 1, 2, 3], [1, 3, 2, 3], [0, 1, 2, 0])
3×3 SparseMatrixCSC{Int64,Int64} with 4 stored entries:
[1, 1] = 0
[2, 2] = 2
[1, 3] = 1
[3, 3] = 0
0 ⋅ 1
⋅ 2 ⋅
⋅ ⋅ 0

julia> dropzeros(A)
3×3 SparseMatrixCSC{Int64,Int64} with 2 stored entries:
[2, 2] = 2
[1, 3] = 1
⋅ ⋅ 1
⋅ 2 ⋅
⋅ ⋅ ⋅
```

## Sparse Vector Storage
Expand Down Expand Up @@ -106,10 +106,11 @@ julia> I = [1, 4, 3, 5]; J = [4, 7, 18, 9]; V = [1, 2, -5, 3];

julia> S = sparse(I,J,V)
5×18 SparseMatrixCSC{Int64,Int64} with 4 stored entries:
[1, 4] = 1
[4, 7] = 2
[5, 9] = 3
[3, 18] = -5
⋅ ⋅ ⋅ 1 ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅
⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅
⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ -5
⋅ ⋅ ⋅ ⋅ ⋅ ⋅ 2 ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅
⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ 3 ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ ⋅

julia> R = sparsevec(I,V)
5-element SparseVector{Int64,Int64} with 4 stored entries:
Expand Down Expand Up @@ -152,11 +153,11 @@ the [`sparse`](@ref) function:
```jldoctest
julia> sparse(Matrix(1.0I, 5, 5))
5×5 SparseMatrixCSC{Float64,Int64} with 5 stored entries:
[1, 1] = 1.0
[2, 2] = 1.0
[3, 3] = 1.0
[4, 4] = 1.0
[5, 5] = 1.0
1.0 ⋅ ⋅ ⋅ ⋅
1.0 ⋅ ⋅ ⋅
⋅ ⋅ 1.0 ⋅ ⋅
⋅ ⋅ ⋅ 1.0
⋅ ⋅ ⋅ ⋅ 1.0

julia> sparse([1.0, 0.0, 1.0])
3-element SparseVector{Float64,Int64} with 2 stored entries:
Expand Down
7 changes: 3 additions & 4 deletions stdlib/SparseArrays/src/abstractsparse.jl
Original file line number Diff line number Diff line change
Expand Up @@ -110,10 +110,9 @@ Return a tuple `(I, J, V)` where `I` and `J` are the row and column indices of t
```jldoctest
julia> A = sparse([1 2 0; 0 0 3; 0 4 0])
3×3 SparseMatrixCSC{Int64,Int64} with 4 stored entries:
[1, 1] = 1
[1, 2] = 2
[3, 2] = 4
[2, 3] = 3
1 2 ⋅
⋅ ⋅ 3
⋅ 4 ⋅

julia> findnz(A)
([1, 1, 3, 2], [1, 2, 2, 3], [1, 2, 4, 3])
Expand Down
Loading