Matlab产生随机序列,并采样

clear all;
M = 10; % bit数 符号数
N = 100; % 总采样数
L = N/M; % 每bit采样数
emp_rate = 0.5; % 占空比
imp = round(rand(1,M)); % round(...):四舍五入; rand(M,N):产生(0,1)之间的均匀分布的随机数,返回M*N的矩阵
% imp = randi([0,1],1,M);  % randi([iMin,iMax],m,n) 在[iMin,iMax]生成随机整数,返回m*n的矩阵
single = zeros(1,N);
for ii = 1:L*emp_rate
    for jj = 1:M
        single(ii+(jj-1)*10) = imp(jj);
    end
end
subplot(211);stem(imp);
subplot(212);stem(single);

  或者

clear all;
M = 10; % bit数 符号数
N = 100; % 总采样数
L = N/M; % 每bit采样数
W = 4; %   W 进制的符号
imp = randi([0,W-1],1,M);
single = zeros(1,N);
for ii = 1:M
    for jj = (ii-1)*L+1 : ii*L
        single(jj) = imp(ii);
    end   
end
subplot(211);stem(imp);
subplot(212);stem(single)

  或者

clear all;
M = 10; % bit数 符号数
N = 100; % 总采样数
L = N/M; % 每bit采样数
W = 4; %   W 进制的符号
imp = randi([0,W-1],1,M);
single = rectpulse(imp,L); % 把 imp 中的每个元素变成 L 个相同的元素,返回:若imp为行(列)向量,则返回 length(imp)*L 的行(列)向量。若[m,n]=size(imp);则大小为[m*L,n]的矩阵。
subplot(211);stem(imp);
subplot(212);stem(single)
  • Matlab 输入
emp_rate=input('输入占空比:');

  

  

posted @ 2018-03-17 14:08  htj10  阅读(3124)  评论(0编辑  收藏  举报
TOP