SVD and basis of a plane

77 ビュー (過去 30 日間)
RR
RR 2019 年 12 月 12 日
コメント済み: RR 2019 年 12 月 12 日
X is a 1000x3 matrix describing a group of points in 3D space.
I am interested in finding the normal vector of the best fit plane in 3D of such points, thus i'am perfoming the following lines of code:
XC = mean(X,1);
Y=X-XC;
[~,~,V]=svd(Y,0);
Normal=V(:,end)
What is the meaning of the first two columns of V?
Are they two of the infinite orthogonal vectors that lying on the best-fitted plane?

採用された回答

John D'Errico
John D'Errico 2019 年 12 月 12 日
編集済み: John D'Errico 2019 年 12 月 12 日
Lets make some random data.
X = rand(1000,2)*rand(2,3) + rand(1,3);
I have no idea what plane represents the data, but I do know there is some plane that perfectly contains all the data points, since it was constructed that way.
XC = mean(X,1);
Y=X-XC;
[~,~,V]=svd(Y,0);
V
V =
0.44144 0.67346 -0.59295
0.71352 -0.66416 -0.22313
0.54408 0.32458 0.77371
s = svd(Y,0)
s =
15.628
4.2751
2.1204e-14
So it is indeed a planar set.
A good definition of a plane uses the normal vector. Any point Z in the plane has the property that
dot(Z - XC,V(:,3)) == 0
Here V(:,3) corresponds to the vector with a zero singular value. It is the normal vector to the plane. As you can see, it kills off anything in-plane.
norm(Y*V(:,3))
ans =
2.1259e-14
However, if I pick any random point, it will generally not produce zero, unless I get very lucky.
(randn(1,3) - XC)*V(:,3)
ans =
-1.6699
So what are the other two vectors in V? As you say, they form a spanning basis for the planar subspace, although they could have been as easily been chosen differently. In a sense, the choice here is somewhat arbitrarily chosen so that V(:,1) is a vector that represents most of the mass in your data. But V(:,1:2) could be rotated arbitrarily here, as long as you care only about what they tell you about the plane. We can write any point in the plane using the generic parametric form
P(a1,a2) = XC + a1 * V(:,1).' + a2*V(:,2).'
If your data does not fall exactly on a perfect plane, then the third singular value from svd will be larger than zero. In the case I tried, it is not exactly zero, but 2e-14 is as close as we can reasonably get.
  1 件のコメント
RR
RR 2019 年 12 月 12 日
Thank you for the prompt answer!
So, if i have understood well: the more the value s(3) is close to 0 the more the points that are distributed in space lie on a plane.
How the vectors V (:, 1) and V (:, 2) are chosen among the infinite pairs of versors lying on the estimated plane?
thank you very much!

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLinear Algebra についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by