怎样用matlab产生宽带随机信号

WBOY
发布: 2024-01-25 09:54:06
转载
568 人浏览过

怎样用matlab产生宽带随机信号

怎样用matlab产生宽带随机信号

Matlab 伪随机信号的产生(M序列)

这里主要说明两种方法,一是使用m文件编辑,二是用simulink产生

一、用m文件编辑

Np=63;%循环周期

delta_T = 1;%时钟节拍

a=1;%幅度

%初始化M序列

M(1)=1;

M(2)=0;

M(3)=0;

M(4)=1;

M(5)=1;

M(6)=0;

M_XuLie(Np) = 0;

for n = 1 : Np

temp = xor(M(6), M(5));

if(temp == 0)

M_XuLie(n) = a;

else

M_XuLie(n) = -a;

end

M(6) = M(5);

M(5) = M(4);

M(4) = M(3);

M(3) = M(2);

M(2) = M(1);

M(1) = temp;

end

figure(4)

stairs(M_XuLie)

ylim([-2 2])

说明:

1.原理:由于是用代码书写,可能原理表达不是很直观,后面会以仿真形式给出原理

2.周期:若有N个移位寄存器,那么周期为2^N-1

3.周期的延拓:

r = 3; % 周期数

u=repmat(M_XuLie,1,r+1);%将M序列赋给输入,作为输入信号

二、使用simulink产生M序列

1 选6个移位寄存器,就是Z分之1那个 按顺序排列好,初始条件(initial conditions)全都设为1

2 先把这6个移位寄存器链接起来 第一个输出连第二个输入,以此类推到第六个接OUT,out这里再接一个scope以便观察信号波形或者接到工作空间(本例是接到工作空间中)。按照如下方法设置变量名和输出格式。

注意:尽量选矩阵形式输出,否则调用不方便。

3 选一个logical operator,并从设置中调成XOR,2输入端

4 继续连线

5 设置参数,主要是设置步长和总运行时间(点击菜单simulation-configuration parameters设置)

6 点击运行 scope中显示的便是m序列!或者在命令行中输入stairs(M_seque)

注:事实上,用这种方法在实际使用中存在一些问题,就是输出信号是bool型的,即是逻辑序列,无法作为传递函数的输入使用,如果是在m文件中可以通过double等方法进行转换,simulink应该是有方法转换的但还未做相关查询。

matlab中如何产生pn序列

for k=1:length(x) gfpretty(x(k,:));end

m伪随机序列Matlab源代码

%5阶m序列

% 在MATLAB命令窗口输入以下:

% fbconnection=[0 1 0 0 1];

% mseq="m"_sequence(fbconnection);

% mseq

function mseq="m"_sequence(fbconnection)

n=length(fbconnection);

N=2^n-1;

register=[ones(1,n-1) 1]; %移位寄存器的初始状态

mseq(1)=register(n); %m序列的第一个输出码元

for i="2:N"

newregister(1)=mod(sum(fbconnection.*register),2);

for j="2:n",

newregister(j)=register(j-1);

end;

register="newregister";

mseq(i)=register(n);

end

保存为m_sequence.m;

以上是怎样用matlab产生宽带随机信号的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:docexcel.net
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!