不同周期m序列(伪随机序列)的matlab详细生成方法

本文介绍了如何使用MATLAB详细生成不同周期的m序列,重点在于利用线性反馈移存器和本原多项式。通过查找预计算的本原多项式表,根据所需的序列周期选择合适长度的多项式,调整程序中的反馈连接多项式,验证生成的序列中1的个数比0多1以确保正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

不同周期m序列的matlab详细生成方法

m序列是由线性反馈移存器产生的伪随机序列,而线性反馈移存器产生m序列的充要条件为:其特征多项式为本原多项式。只要找到本原多项式,就能由它构成m序列。但本原多项式的寻找并不简单,这里给出了经过前人大量计算整理得出的本原多项式表;通过给定的本原多项式,再调用后面的m_sequence函数,即可生成对应周期的m序列。
本原多项式表
调用

clear;
clc;
fbconnection=[0 1 0 0 1]; % fbconnection为m序列的一个本原多项式
mseq=m_sequence(fbconnection);

***注意:***表中n代表多项式长度,生成的m序列周期即为2^n-1,当我们想要生成某个长度的m序列时,找到合适的长度n,再查表找到对应的本原多项式下的代数式,只看x项,按x的升幂排序,产生对应的多项式(可以参考图片中n为4,5,6时的情况),然后把上面调用程序里的fbconnection多项式替换即可。
***验证:***当生成序列中1的个数比0的个数多1时,则表明m序列生成正确。
m序列生成函数

function mseq=m_sequence(fbconnectio
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值