function X=samplegeneimprv(adjmat,root,A,Sigma_r,Sigma_n,m,n)
[p,~]=size(adjmat);
[d,~]=size(A);
[rindex,cindex]=find(adjmat==1);
G=graph(rindex,cindex);
D_g = distances(G);
Sigma_d=zeros(p*d,p*d);
for i=1:p
    for j=i+1:p
        Sigma_d((i-1)*d+1:i*d,(j-1)*d+1:j*d)=Sigma_r*A^(2*D_g(i,j));
        Sigma_d((j-1)*d+1:j*d,(i-1)*d+1:i*d)=Sigma_r*A^(2*D_g(i,j));
    end
end
for i=1:p
    Sigma_d((i-1)*d+1:i*d,(i-1)*d+1:i*d)=Sigma_r;
end
X=mvnrnd(zeros(p*d,1),Sigma_d,n);
X=X(:,1:m*d);  
            