This project builds on SymPy's Matrix class and is designed for students taking NUS MA1522 Linear Algebra for Computing. It has implementations of most of the algorithms taught during the course (as of Sem 1 AY24/25).
- Import matrices directly from
$\rm\LaTeX$ or string/list representations. - Step-by-step workings for most algorithms (including LU Factorisation, SVD, QR, diagonalization, and more).
- Enhanced symbolic matrix class with:
- Matrix creation from lists,
$\rm\LaTeX$ , or random values. - Matrix decompositions: REF, RREF, LU, QR, SVD, diagonalization.
- Vector space operations: orthogonalization, projections, basis manipulation, subspace intersection, and more.
- Eigenvalue/eigenvector computations and characteristic polynomials.
- Custom pretty-printing and
$\rm\LaTeX$ formatting, including augmented matrices. - Support for both exact symbolic and numerical computations.
- Utilities for displaying results in Jupyter/IPython or standard Python.
- Matrix creation from lists,
- Follows MA1522 syllabus conventions for linear algebra and provides detailed, educational output.
- Rich set of custom types for representing decompositions, solutions, and factorizations.
This project is best supported in a Jupyter Notebook environment with Python 3.10+. You can download Python from here.
Alternatively, you can use a minimal GUI developed by @MarcusMa06-code here.
It is recommended to use a virtual environment for managing dependencies.
-
Create a virtual environment:
python -m venv venv
-
Activate the virtual environment:
- On Windows:
venv\Scripts\activate
- On macOS/Linux:
source venv/bin/activate
- On Windows:
-
Install the library:
pip install ma1522-linear-algebra
It is recommended to use a Jupyter Notebook environment to run the code.
pip install notebook
Create a Jupyter Notebook test.ipynb. Within the notebook, run the following code.
from ma1522 import *
# Create Matrix objects
A = Matrix([[1, 2, 3],
[4, 5, 5],
[7, 8, 9]])
b = Matrix([[1],
[2],
[3]])
# Join matrices along the columns via `row_join`.
augmented_matrix = A.aug_line().row_join(b)
# `aug_line` adds a visual line that can be seen using `display`
display(augmented_matrix)
# Solution to the matrix equation Ax = b can be found using `solve`.
A.solve(rhs=b)
# Alternatively, the full steps with LU Factorisation can be found using `ref` with the appropriate options.
augmented_matrix.ref(verbosity=2)Documentation of more functions can be found here.
More usage examples can be found under tutorials.
Live demonstration of the library can be found here.
An offline version of the documentation is available for download from the Releases page. This is useful for exam when you may not have internet access.
To use the offline documentation:
- Download
linear-algebra-docs-offline.zipfrom the latest release - Extract the ZIP to a folder
- Open
index.htmlin your browser
If the offline ZIP is not available in the releases, you can build it yourself:
-
Clone the repository:
git clone https://github.com/YeeShin504/linear-algebra.git cd linear-algebra -
Install documentation dependencies:
pip install mkdocs-material mkdocs-jupyter
-
Build the documentation:
mkdocs build
-
The documentation will be in the
site/folder. Opensite/index.htmlin your browser.
I would like to thank @DenseLance for his contributions.