function X=samplegeneration(adjmat,root,A,Sigma_r,Sigma_n,m,n)
[p,~]=size(adjmat);
[d,~]=size(A);
X=zeros(n,p*d);
for i=1:n
    x_r=mvnrnd(zeros(d,1),Sigma_r);
    X(i,(root-1)*d+1:root*d)=x_r;
    child=find(adjmat(root,:)>0);
    pa=root*ones(1,length(child));
    while(~isempty(child))
        pa_next=[];
        child_next=[];
        for j=1:length(child)
            x=A*X(i,(pa(j)-1)*d+1:pa(j)*d).'+mvnrnd(zeros(d,1),Sigma_n).';
            X(i,(child(j)-1)*d+1:child(j)*d)=x.';
            temp_c=find(adjmat(child(j),:)>0);
            temp_c=temp_c(find(temp_c~=pa(j)));
            child_next=[child_next temp_c];
            pa_next=[pa_next child(j)*ones(1,length(temp_c))];
        end
        child=child_next;
        pa=pa_next;
    end
end
X=X(:,1:m*d);  
            