function [T, samples] = generateSample(ops)
% ops.stepsize,d,k,n,components
LEN = 10000;
% generate basis sample according to ops.components

Aprime=zeros(ops.n,ops.k);
for i = 1: ops.n
    Aprime(i,randi(ops.k))=1;
end
% Aprime(:,1) = randi(2,[ops.n,1])-1;
% Aprime(:,2) = 1 - Aprime(:,1);
samples = mnrnd(LEN*ones(ops.n,1), Aprime*ops.components');
samples=bsxfun(@rdivide,samples,sum(samples,2));
%%% samples = samples.*sqrt(sqrt(ops.k));


% generate vectors such that the 4th order are tensors
T = zeros([ops.d,ops.d,ops.d,ops.d]);
for i = 1 : ops.k
    tmp1 = outerProduct_11(ops.components(:,i),ops.components(:,i));
    tmp2 = outerProduct_21(tmp1, ops.components(:,i));
    T = T + outerProduct_31(tmp2, ops.components(:,i));
end
% % % % sample reconstruction error
% % % T_est = zeros([ops.d,ops.d,ops.d,ops.d]);
% % % for i =1 : ops.n
% % %     thissample = samples(i,:);
% % %     thissample = thissample(:);
% % %     T_est = T_est + outerProduct_31(outerProduct_21(outerProduct_11(thissample,thissample),thissample),thissample);
% % % end
% % % T_est = T_est/ops.n;
% % % err = sum(sum(sum(sum((T - T_est).^2))));




