Solve linear equation in matrix form with least square method

13 vues (au cours des 30 derniers jours)
DoinK
DoinK le 26 Mai 2023
Modifié(e) : DoinK le 28 Mai 2023
I have linear equation Ax=b, the size of every matrix are : matrix A is 1009*1008, vector b is 1009*1, and vector x is 1008*1.
If I use lsqr command which is lsqr(A,b), this come out
"Error using iterchk (line 38)
Argument must be a floating point matrix or a function handle.
Error in lsqr (line 93)
[atype,afun,afcnstr] = iterchk(A);".
If I try simple matrix, it can calculate easily.
If I use (A.'*A)\(A.'*b), i can get the result, but why this code lsqr(A,b) cannot
I want to know what is wrong and how to solve it.
Actually i have 1009 linear equation and 1008 variable, so i use this method, or is there any method to use to solve this problem?

Réponse acceptée

Matt J
Matt J le 26 Mai 2023
Modifié(e) : Matt J le 26 Mai 2023
If I use (A.'*A)\(A.'*b), i can get the result
An even easier and more accurate way to get it is,
x=A\b
and that is the method you should be using for matrix data of this size. As to why you get the error, perhaps your A matrix is not type double, but some other type? E.g.,
A=randi(3,3,'int8');
b=A(:,1);
lsqr(double(A),double(b))
lsqr converged at iteration 3 to a solution with relative residual 2.9e-13.
ans = 3×1
1.0000 -0.0000 -0.0000
lsqr(A,b)
Error using iterchk
Argument must be a floating point matrix or a function handle.

Error in lsqr (line 93)
[atype,afun] = iterchk(A);
  12 commentaires
Walter Roberson
Walter Roberson le 27 Mai 2023
The least squares solvers like A\b and lsqrt work with numbers, not symbolic variables.
syms A [3 3]
syms b [3 1]
A\b
ans = 
However, with a system of rank 1008, unless it is pretty much a diagonal matrix, the time required to solve might be enormous.
DoinK
DoinK le 28 Mai 2023
Modifié(e) : DoinK le 28 Mai 2023
Finally I understood all and was able to solve my matrix.
Thank you so much Sir @Matt J @Steven Lord @Walter Roberson

Connectez-vous pour commenter.

Plus de réponses (0)

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by