function test
% min_{X} ||X-A||_F, X'X=I
clc;clear all;close all;
n = 10;
r = 3;
A = randn(n,r);
X = oproj(A);
norm(X-A,'fro')^2

[V,D]=eig(A*A');
V = V(:,n-r+1:n);
norm(V-A,'fro')^2
dd
X = oproj(randn(n,r));
% min_{V} ||XV-A||_F, V'V=VV'=I
% min_{V} -2*<XV,A>, V'V=VV'=I
% min_{V} -<XV,A>, V'V=VV'=I
% min_{V} -<V,X'*A>, V'V=VV'=I
V = oproj(X'*A);
X2 = X*V;
norm(X2-A,'fro')^2





function X = oproj(X)
[U,S,V]=svd(X,'econ');
X = U*V';

function r = mdot(x,y)
r = sum(sum(x.*y));
