bug fix for back_substitute that breaks underdetermined solves in

linear_solve with matrix RHS.
This commit is contained in:
Adrian Mariano 2020-03-17 23:50:57 -04:00
parent 05827785f5
commit 02ab8ea1d8

View file

@ -646,7 +646,7 @@ function back_substitute(R, b, x=[],transpose = false) =
assert(is_matrix(R, square=true)) assert(is_matrix(R, square=true))
let(n=len(R)) let(n=len(R))
assert(is_vector(b,n) || is_matrix(b,n),"R and b are not compatible in back_substitute") assert(is_vector(b,n) || is_matrix(b,n),"R and b are not compatible in back_substitute")
!is_vector(b) ? transpose([for(i=[0:len(b[0])-1]) back_substitute(R,subindex(b,i))]) : !is_vector(b) ? transpose([for(i=[0:len(b[0])-1]) back_substitute(R,subindex(b,i),transpose=transpose)]) :
transpose? transpose?
reverse(back_substitute( reverse(back_substitute(
[for(i=[0:n-1]) [for(j=[0:n-1]) R[n-1-j][n-1-i]]], [for(i=[0:n-1]) [for(j=[0:n-1]) R[n-1-j][n-1-i]]],