Description
Description
I would like to propose adding a sparse matrix utility under the utility section of stdlib.io. In many cases, when users create 2D matrices, they often do not fully utilize all the cells, leading to unnecessary storage consumption. Sparse matrices can optimize this by only storing non-zero (or meaningful) values, thereby reducing memory usage.
Why is this needed?
A sparse matrix is useful in scenarios where the matrix has a large number of zero (or default) values, which is common in scientific computing, machine learning, and other data-heavy operations. With a sparse matrix implementation, users can:
- Save memory by only storing the necessary values.
- Improve computational efficiency with large, sparsely populated matrices.
Proposed Solution: The solution will involve creating a 1D array, which will be used to simulate a 2D matrix via a mathematical formula. This approach ensures that only the non-default values are stored, significantly optimizing memory usage. The utility will:
- Allow users to interact with the matrix as if it were a standard 2D array.
- Provide methods for adding, removing, and accessing values.
- Use an internal mapping function to translate 2D indices into the 1D array.
Looking forward to your feedback!
Checklist
- I have read and understood the Code of Conduct.
- Searched for existing issues and pull requests.
- The issue name begins with
RFC:
.