基于Quartus II逻辑的DSSS发射机MATLAB仿真验证
项目介绍
本项目是一个用于验证直接序列扩频(Direct Sequence Spread Spectrum, DSSS)发射机设计逻辑的MATLAB仿真工具。虽然原定硬件设计环境为Quartus II 7.2,但在进行RTL级代码编写和FPGA板级调试之前,使用MATLAB作为一个高层级的验证平台至关重要。
本项目脚本主要模拟了将在FPGA内部实现的数字逻辑电路行为,包括线性反馈移位寄存器(LFSR)的运作机制、基带信号的生成、数字扩频逻辑以及后续的模拟载波调制过程。通过本仿真,设计者可以直观地观察到信源、m序列、扩频信号在时域波形上的时序关系,以及扩频前后信号在频域上的功率谱密度变化,从而验证DSSS系统的理论可行性和逻辑设计的正确性。
功能特性
- FPGA时钟与速率模拟:精确定义了码片速率(1 MHz)、采样率(10 MHz)和载波频率(2 MHz),建立了符合FPGA时钟分频逻辑的时间基准。
- 软件定义的LFSR逻辑:通过算法精确模拟了硬件5级线性反馈移位寄存器生成m序列的过程,复现了硬件反馈抽头的行为。
- 数字基带信号生成:模拟产生低速二进制数据流,用于测试传输链路。
- 数字扩频调制:实现了逻辑层面的异或(XOR)扩频运算,验证频谱扩展原理。
- BPSK载波调制仿真:将扩频后的数字信号映射到双极性电平并调制到高频载波上。
- 全流程信号分析:包含从比特流到RF输出的全链路时域波形观测,以及扩频前后的频谱对比分析。
系统要求
- MATLAB R2016b 或更高版本
- Signal Processing Toolbox(推荐,用于频谱分析部分)
---
仿真逻辑与实现细节
本项目的核心实现完全基于对数字硬件逻辑的数学建模,主要流程如下:
1. 系统参数初始化
脚本首先定义了仿真所需的关键物理层参数。设定扩频码(m序列)长度为31,对应5级寄存器的最大周期(2^5 - 1)。码片速率设定为1 MHz,依据扩频增益计算得出基带数据比特率约为32.25 kbps。为了满足奈奎斯特采样定理并模拟数字系统中的过采样,系统采样率设定为10 MHz,载波频率设定为2 MHz。
2. 伪随机序列(PN码)发生器
这是模拟FPGA内部核心逻辑的部分。脚本没有直接调用现成的序列函数,而是通过一个自定义的算法函数模拟了
线性反馈移位寄存器(LFSR)的硬件行为。该逻辑使用了5级寄存器,反馈多项式配置为 $P(x) = x^5 + x^2 + 1$。生成的m序列被扩展为与采样率匹配的时域波形,模拟了FPGA引脚输出的高速伪随机码流。
3. 信源数据产生
为了保证仿真结果的可复现性,脚本设置了固定的随机数种子(Seed 123)。随后生成了10个随机二进制比特(0或1)作为待传输的信源数据。这些比特通过矩形脉冲成型,被转换为持续时间为比特周期的基带波形。
4. 逻辑扩频调制
此步骤模拟了发射机中的数字混频器或异或门电路。系统将低速的基带数据波形与高速的PN码波形进行
异或(XOR)运算。运算结果即为扩频后的基带信号。为了适配后续的BPSK调制数学模型,逻辑电平(0/1)被映射为双极性电平(-1/+1),其中逻辑0映射为-1V,逻辑1映射为+1V。
5. BPSK载波调制
系统生成了一个频率为2 MHz的余弦载波信号。通过将双极性的扩频基带信号与载波信号相乘,完成了二进制相移键控(BPSK)调制,生成最终模拟的射频发射信号。
6. 频谱分析
利用快速傅里叶变换(FFT)算法,脚本分别计算了原始基带信号、扩频后基带信号以及最终调制输出信号的功率谱密度。为了便于对比,频谱幅度进行了归一化处理。此步骤用于验证扩频操作是否成功将信号能量分散到了更宽的频带上。
7. 结果可视化
脚本生成了两幅主要的图表来模拟示波器和频谱仪的界面:
- 时域波形图:采用子图形式,依次展示了前2个比特周期内的信源数据、PN码序列、XOR后的扩频逻辑电平以及最终的BPSK调制波形。这有助于检查码片与数据位的对齐情况。
- 频域分析图:对比了原始窄带信号与扩频宽带信号的频谱形状,清晰展示了主瓣宽度的扩展;同时展示了调制到2 MHz载波处的最终信号频谱。
---
关键算法说明
自定义m序列生成算法
脚本末尾包含一个名为
generate_m_sequence 的辅助函数,它精确复刻了硬件寄存器的工作方式:
- 初始化:设置一个长度为5的寄存器数组,状态全为1(模拟复位)。
- 移位与反馈:
* 在每个时钟周期,输出寄存器末位的值。
* 根据抽头配置
[5, 2],提取对应位置的寄存器值进行异或运算,计算反馈位。
* 将数组整体右移,并将反馈位填入首位。
- 循环输出:重复上述过程直到生成完整的周期序列。
这种实现方式确保了仿真产生的序列与未来在Quartus II中综合出的Verilog/VHDL硬件电路行为完全一致。
使用方法
- 确保MATLAB环境已安装并配置正确。
- 直接运行主脚本文件。
- 程序将自动执行计算,并弹出两个图形窗口展示波形和频谱。
- 观察控制台变量或图形结果以验证设计指标。