一、说明:
- 功能:AM调制
- 平台:Vivado 2016.4 和 Matlab R2017a
二、原理:
1. AM调制原理
AM已调信号的时域表达式:
已调信号的频域表达式:
本质上AM调制就是频谱的搬移。AM调制的系统框图
将调制信号加上一个直流分量,保证信号的最小值大于零,然后再和载波相乘,得到已调信号。
三、AM调制的FPGA实现
1.产生调制信号和载波信号
调用ROM IP核在FPGA内部产生两路余弦信号,其中一路信号用于模拟外部输入的调制信号,另一路用作载波信号。
在配置ROM IP核之前,需要用Matlab生.coe文件,存放在ROM核里。
- Matlab生成.coe文件:
1 | %---------------------------------% |
生成.coe文件后就可以进行IP核的配置了。
- ROM核具体配置:
配置完IP核后,编写控制模块,产生两路信号。其中,调制信号上叠加的直流分量的大小为调制信号的峰值,这样将得到调制度为100%的已调信号。如果要得到不同的调制度,则需要叠加不同大小的直流分量,同时需要注意定义的数据位宽,防止数据溢出。
- 产生载波和带有直流分量的调制信号:
1 | module cos_make( |
2.生成AM调制信号
得到两路信号后就可以用乘法器将两路信号相乘,得到已调信号。
乘法器具体配置:
AM调制的顶层模块:
1 | module modulate( |
3.仿真调制结果
以上AM调制过程基本完成,但是正确与否还需要通过仿真来确定,接下来编写仿真用的测试模块。
- TestBeach的编写:
1 | `timescale 1ns/1ps |
在Vivado中将各个文件添加进工程后,运行仿真。
- 仿真结果如下:
已调信号能明显看到包络,并且包络的频率同调制信号一致,表明AM调制正确。