function [Y, Pi_orig, X, B] = create_signal(snr, noise_var, n, p, m, h)

Pi_orig = (1:1:n).';

Pi_orig(1:h-1) = 2:h;
Pi_orig(h) = 1; 


X = normrnd(0, 1, [n, p]); 

N = noise_var * normrnd(0, 1, [n, m]);


tmpB = eye(p, m);  % p times m; 


 
B = noise_var * sqrt(m * snr)/norm(tmpB,'fro') * tmpB;

Y = X * B + N; 

Y = Y(Pi_orig, :); 


end

















