heat
heat copied to clipboard
Provide a solver for triangular systems
Feature functionality
Provide a solver for the linear equation $Ax = b$, where $b \in \mathbb{K}^{m \times n}$, $A \in \mathbb{K}^{m \times m}$ are two-dimensional DNDarrays
such that $A$ is either upper- or lower-triangular.
Intended scope:
- different combinations of
split
for $A$ and $b$ - of course, scalability of the routine is desired
Additional context
- Often required in combination with Cholesky decompositon #886
- also required in context of linear regression (implementing a "QR + triangular solve"-based linear regressor for massive data could be a cool second part of a corresponding student project or PR)
Hi, mrfh92, I wanted to work on this problem, can you please tell me whether this feature has to be added to /core/linalg/solver.py or with the cholesky matrix in /core/linalg/basics.py.
I would suggest to put triangular_solve
into .../solver.py
and to create a new file /core/linalg/cholesky.py
for cholesky
.
If you have questions, feel free to concact me.
Hi, I have created a new function triangular_solver in .../solver.py. It takes in A and B as inputs and returns the solution x for Ax = B, also, this function raises error flag if the user does not input a triangular matrix or the matrix is not full rank.
data:image/s3,"s3://crabby-images/5eacb/5eacbd1e533aeb1bf71157ae18e7bad9694afdca" alt="lower matrix (No split)"
data:image/s3,"s3://crabby-images/3b12d/3b12d7b0f95b9528358bab48c5537518739ecf46" alt="lower matrix (Split)"
data:image/s3,"s3://crabby-images/0771c/0771cde61f184d58f07122e578de02cc96120f86" alt="upper matrix (No split)"
data:image/s3,"s3://crabby-images/68019/6801998688bc210cb4e37b4b858b130946d9f748" alt="upper matrix (split)"
Raising Errors:
@mrfh92 , can I create a PR so , that my code can be reviewed.
Of course, please do so Looks great so far 👍
Stil open and relevant (Reviewed within #1109)
Branch features/1096-Provide_a_solver_for_triangular_systems created!
Some first thoughts on this are found in the #1236
This issue is stale because it has been open for 60 days with no activity.
@FOsterfeld works on this within #1236
Implemented and merged in #1236 by @FOsterfeld
see #1433 for the error messages
This issue is stale because it has been open for 60 days with no activity.
This issue was closed because it has been inactive for 60 days since being marked as stale.
Has been completed actually.