function [ X_s ] = sample_MR( X , M , r , alpha )

if nargin < 4
   
    alpha = 1; 
    
end

d = size( X , 1 ) / M;

N = size( X , 2 );

X_s = zeros( d * r , N );

temp_s = nan( d , r );

for i = 1 : N
    
    temp = reshape( X( : , i ) , d , M );
    
    t_s = rand(1);
    
    if t_s < alpha * r / M
        
        temp_s( : , 1 ) = temp( : , 1 );
        
        temp_s( : , 2 : r ) = temp( : , randsample( 2 : M , r - 1 ) );
        
    else
    
    temp_s = temp( : , randsample( 2 : M , r ) );
    
    end
    
    X_s( : , i ) = reshape( temp_s , d*r , 1 ); 

end

