本文对应西电随机试验实验的实验三,用于记录整理与参考。主要是通过FPGA实现2ASK调制,用Quartus II 搭建,用Modelsim进行仿真并将程序下载到硬件平台(XSRP软件无线电平台),将波形显示在示波器上。
总体介绍
FPGA程序框图如下
上图的模块分别对应下图的模块,后面的部分老师给的demo中都有,我们只需要产生m序列和载波,并通过一个控制开关,m序列为1的时候输出载波,m序列为0的时候输出0就可以。
主要难点在于载波的产生,软件的使用,还有参数的对应。
软件使用上有许多的小细节需要注意,建议先了解软件的基本使用再上手,磨刀不误砍柴工,直接打开操作可能会遇到不少问题。
而关于载波的产生我们首先需要明确,它的储存不是连续的,而是以一个一个的采样值储存在地址中的。而我们要做的就是对正弦波进行采样,并将这些值存入相应的rom中。对应老师给的指导书的如下部分。前一个就是计数器,和其他部分一样用Verilog编程然后生成就好,后面的rom有些不同。
另外,实验中很多参数是需要对应的,比如两个模块相接处端口的位数,分频数以及采样数需要与最后示波器上的频域带宽对应等等,要事先计算清楚。
参考链接
放几个参考链接
m序列的产生.
原理看得懂最好,不懂可直接粘贴,问了老师不要求掌握
rom的设置.
这个基本照着做就可以设置好。
分频、计数器、开关的代码都比较好写,在Modelsim仿真的时候要写testbench,其实quartus是可以自己生成testbench模板的,这样原来配置的接口啥的就不用自己写了美滋滋O(∩_∩)O哈哈~
链接:quartus设置.
其他仿真方法指导书里都很详细了。
示波器的显示与分析
2ASK信号(黄色)在示波器上显示如下,m序列对应下方蓝线,由m序列控制载波信号是否能够通过,与之前分析相符。
2ASK波形图
下图为m序列在示波器对应显示的频谱图,可以看出谱线形状与理论相符,由连续谱和离散谱组成,离散谱位于频率为0处。由m序列原理部分的介绍,可算出m序列的带宽应为B_s=f_S=(26×10^6)/960=27083Hz ,实际测得的带宽为26kHz,与理论值基本相符。 (系统时钟26MHz,960是分频数)
m序列频谱图
下图为2ASK信号在示波器对应显示的频谱图,可以看出谱线形状与理论相符,由连续谱和离散谱组成,离散谱位于频率为fc处。可算出其带宽应为B_2ASK=2B=2f_S =2×27083Hz=54.17kHz ,实际测得的带宽为50kHz,与理论值基本相符。
2ASK信号频谱图
遇到的问题
首先是关于分频数的设置。在刚开始设两个模块的分频数时,我认为只要载波的分频数小于m序列分频数就可以保证载波频率大于m序列,而忽略了采样点对于载波频率的影响,导致仿真波形的m序列值为1时,只能显示正弦波形的极小一部分。之后我意识到载波频率fc的计算需要除以采样数,求得为101.6KHz,故重新调整了分频数与采样点数,使fc>fm。
其次是在quartus的使用中出现的一些问题。
1、对应连线的两个端口数据位要一致,如[5:0]和[6:0]不能相连;
2、Verilog中的文件名要和文件中module的名称一致;
3、打开quartus工程时,应点击.qpf文件,点击其他。bsf文件也可以打开对应原理图,但是打开的不是工程;
4、在原理图中引输出引脚时,若输出值不止一位,应把连接线设置为“Bus line”,输出命名后加[n…0],对应位数为n+1位。
5、仿真时应注意检查仿真文件的设置及修改,在计数器的仿真中,波形只显示1位,我只注意了原理图及代码等的检查而忽略了test bench文件,最后发现是改过模块代码后忘记改仿真文件中的端口定义而导致的。
源文件已上传至我的资源。