function [A] = GetData(iwhich)
rand('seed',0);
randn('seed',0);
switch iwhich
    case 1
        m = 2000;
        n = 1000;
        A = randn(m,n);
    case 2
        m = 1000;
        n = 1000;
        A = randn(m,n);
    case 3
        m = 2000;
        n = 1000;
        A = GetRealDataE2006(m,n);
    case 4
        m = 1000;
        n = 1000;
        A = GetRealDataE2006(m,n);
    case 5
        A = GetRealData_w1a;
    case 6
       A = GetDataMnist_uint8;
     
end

function A = GetDataMnist_uint8
load mnist_uint8;
A = double(test_x);
A = A / 255;
% [data_m,data_n] = size(A);
% [m,n] = size(A);
% s1 = randperm(data_m,2000);
% A = A(s1,:);
% e = ones(size(A,1),1);
% A = A - e*e'*A;
% A = A / norm(A(:),inf);


function A = GetRealData_w1a
load w1a_train;
A = x;
% [data_m,data_n] = size(A);
% s1 = randperm(data_m,m);
% s2 = randperm(data_n,n);
% A = A(:,s2);
% A = A(s1,:);
A = full(A);
% e = ones(size(A,1),1);
% A = A - e*e'*A;
A = A / norm(A(:),inf);

function A = GetRealDataE2006(m,n)
load E2006_5000_10000;
A = x;
[data_m,data_n] = size(A);
s1 = randperm(data_m,m);
s2 = randperm(data_n,n);
A = A(:,s2);
A = A(s1,:);
A = full(A);
% A = A / norm(A(:),inf);

% load E2006_5000_10000;
[m,n] = size(A);
% e = ones(m,1);
% A = A - e*e'*A;

A = A / norm(A(:),inf);






function A = GetRealData2(m,n)
load E2006_5000_10000;
A = x;
[data_m,data_n] = size(A);
s1 = randperm(data_m,m);
s2 = randperm(data_n,n);
A = A(:,s2);
A = A(s1,:);
A = full(A);
A = A / norm(A(:),inf);










% function [A] = GetData(iwhich)
% switch iwhich
%     case 1
%         m = 1000;
%         n = 1000;
%         A = randn(m,n);
%     case 2
%         m = 1000;
%         n = 500;
%         A = randn(m,n);
%     case 3
%         m = 500;
%         n = 1000;
%         A = randn(m,n);
%     case 4
%         m = 500;
%         n = 500;
%         A = randn(m,n);
%
%     case 5
%         m = 1000;
%         n = 1000;
%         load E2006_5000_10000;
%         A = x;
%         [data_m,data_n] = size(A);
%         s1 = randperm(data_m,m);
%         s2 = randperm(data_n,n);
%         A = A(:,s2);
%         A = A(s1,:);
%         A = full(A);
%         A = A*m;
% %         A = A / norm(A(:),inf);
%     case 6
%         m = 1000;
%         n = 500;
%         load E2006_5000_10000;
%         A = x;
%         [data_m,data_n] = size(A);
%         s1 = randperm(data_m,m);
%         s2 = randperm(data_n,n);
%         A = A(:,s2);
%         A = A(s1,:);
%         A = full(A);
%         A = A / norm(A(:),inf);
%     case 7
%         m = 500;
%         n = 1000;
%         load E2006_5000_10000;
%         A = x;
%         [data_m,data_n] = size(A);
%         s1 = randperm(data_m,m);
%         s2 = randperm(data_n,n);
%         A = A(:,s2);
%         A = A(s1,:);
%         A = full(A);
%         A = A / norm(A(:),inf);
%
%     case 8
%         m = 500;
%         n = 500;
%         load E2006_5000_10000;
%         A = x;
%         [data_m,data_n] = size(A);
%         s1 = randperm(data_m,m);
%         s2 = randperm(data_n,n);
%         A = A(:,s2);
%         A = A(s1,:);
%         A = full(A);
%         A = A / norm(A(:),inf);
%
% end
%
%
%
