function test_SVD
clc;clear all;close all;
n = 16;
r = 13;
A = randn(n,r)*10;
ipo(A)
dd
O1 = oproj(A);
O2 = OneQR(A);
norm(A-O1)/norm(A-O2)
norm(A-O1)
norm(A-O2)

function U = ipo(A)
[n,r] = size(A);
U = A;
for iter = 1:2
U = U *inv(eye(r)+3*U'*U)*(3*eye(r)+U'*U);
end
U'*U
dd

 


function [O] = OneQR(A)
[n,r] = size(A);
R1 = A;
U = eye(n);
V = eye(r);
for iter = 1 : 11
    [Q1, R1] = qr(R1,0);
    [Q2, R2] = qr(R1',0);R1 = R2';
    U = U * Q1;
    V = V * Q2;
 end
S = R1;

O = U*eye(r,r)*V';

 % R1 = A;
% U = eye(size(A,1));
% V = eye(size(A,2));
% for iter = 1 : 10
%     [Q1, R1] = qr(R1,0);
%     [Q2, R2] = qr(R1',0);
%     R1 = R2';
%     U = U * Q1;
%     V = V * Q2;
% end
% S = R1;