码迷,mamicode.com
首页 > 其他好文 > 详细

Matlab生成M序列的伪随机码

时间:2016-04-29 00:17:33      阅读:1126      评论:0      收藏:0      [点我收藏+]

标签:

技术分享

 

图3.5 线性反馈移位寄存器

 

 

技术分享技术分享

 

MATLAB生成M序列伪随机码函数如下:

% 在MATLAB命令窗口输入以下: % fbconnection=[0 1 1 0 1 0 0 0 0 0 0 0 0 0 0

% 1];本原多项式系数:[d0,d1,d2...di];其中di为本原多项式前的系数
% mseq=m_sequence(fbconnection); % mseq 
%m_sequence.m功能是生成伪随机序列
%time:2016_1_13
%edit by:柴宁
function[mseq]=m_sequence(fbconnection)
n=length(fbconnection); 
N=2^n-1;
% register=[zeros(1,n-1) 1];
register=[1 1 0 1 0 0 0 0 1 0 1 1 1 1 0 1];%移位寄存器的初始状态 ,[r(i),r(i-1),r(i-2),...r(0)];
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

Matlab生成M序列的伪随机码

标签:

原文地址:http://www.cnblogs.com/sddai/p/5444802.html

(0)
(1)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!