function [X] = RandomPositiveOrth(n,r,grouping,seed)
rand('seed',seed);
randn('seed',seed);
group = [];
% different grouping strategies
if(grouping==1)
    for i=1:r
        group{i} = [];
    end
    sss = randperm(n);
    for i=1:n
        g_id = mod(i-1,r)+1;
        group{g_id} = [group{g_id};sss(i)];
    end
else
    for i=1:r
        group{i} = i;
    end
    
    for i=(r+1):n
        g_id = randperm(r,1);
        group{g_id} = [group{g_id};i];
    end
end


X = zeros(n,r);
for i=1:r
    www = group{i};
    X(www,i) = 1 / sqrt(length(www));
end


