线性代数 · 矩阵 · Matlab | 满秩分解代码实现


背景 - 矩阵的满秩分解:

  • 若 A 为 m×n 矩阵,rank(A) = r,则存在 F m×r、G r×n,使得 A = FG。
  • 其中,F 列满秩,G 行满秩。
  • 求满秩分解的方法:
    1. 得到 A 的行最简形式 B;
    2. 对于 B 里某列为 1 该列中其他元素为零的列,取 A 的对应列,组成 F;
    3. 取 B 的前 r 行组成 G。

function[F,G] = fullrank_decompose(A)
r = rank(A);
if r == 0;
disp('无满秩分解,重新输入')
end
[m,n] = size(A);
B = rref(A);%行最简
F = [];
for i = 1:r
for j = 1:n
if B(i,j) == 1
F = [F, A(:,j)];
break
end
end
end
% F = A(:, 1:m);
G = B(1:r, :);
end


本文作者:MoonOut

本文链接:https://www.cnblogs.com/moonout/p/17809562.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   MoonOut  阅读(386)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 Sibelius: Violin Concerto in D Minor, Op. 47:III. Allegro, ma non tanto Jascha Heifetz / Chicago Symphony Orchestra
Sibelius: Violin Concerto in D Minor, Op. 47:III. Allegro, ma non tanto - Jascha Heifetz / Chicago Symphony Orchestra
00:00 / 00:00
An audio error has occurred.