Package Exports
- csr-matrix
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (csr-matrix) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
csr-matrix
A very minimal incremental compressed sparse row matrix library for JavaScript.
Usage
First install using npm:
npm install csr-matrixThen you can create a matrix and apply it to a vector like this:
var dict = {}
dict[[1,2]] = 1
dict[[0,0]] = 2.5
dict[[3,4]] = 5
var CSRMatrix = require("csr-matrix")
var M = CSRMatrix.fromDictionary(dict, 4, 5)
console.log(M.apply([1,2,3,4,5]))CSRMatrix
CSRMatrices are optimized for exactly one thing: fast matrix-vector multiplies. The way you do this is by calling the following method:
matrix.apply(vector[, result])
This computes the normal matrix-vector product, but is often much faster than a dense multiply since the matrix is stored in a compressed sparse format.
vectoris the vector to be multipliedresultis an optional array which gets the result. If not specified, a new vector gets allocated
Returns the resulting product
matrix.transpose()
Returns the transpose of the matrix
matrix.get(i,j)
Returns the i,j-th entry of the matrix
matrix.rowCount
Returns the number of rows
matrix.columnCount
matrix.toList()
Converts matrix into a list format
matrix.toDictionary()
Converts matrix into hash table
matrix.toDense()
Converts matrix into array of arrays
matrix.toNDArray()
Converts matrix into ndarray
Constructors
There are several ways to create csr-matrices. The most direct way to do this is to just call the constructor yourself:
CSRMatrix(rows, row_ptrs, columns, column_ptrs, data)
Where:
rowsis an array of row indicesrow_ptrsis an array of pointers to the start of each rowcolumnsis an array of column namescolumn_datais a pointer to the start of each column's rundatais an array of all the entries of the matrix stored left-to-right and top-to-bottom
Calling this method directly is not advised. Instead, you should use one of the more user-friendly constructors:
CSRMatrix.fromList(items[, nrows, ncols])
Turns an array of entries of the form [row, column, value] into a sparse matrix. Note that if there are some zero rows or columns at the end of the matrix, you need to specify the number of rows/columns in the optional nrows/ncols arguments.
CSRMatrix.fromDictionary(dict[, nrows, ncols])
Converts a JavaScript object with entries for the form "row,column" into a sparse matrix.
CSRMatrix.fromDense(mat)
Turns an array-of-arrays into a csr matrix
CSRMatrix.fromNDArray(ndarr)
Turns a 2D dimensional ndarray into a csr matrix
Credits
(c) 2013 Mikola Lysenko. BSD