基于FPGA的8PSK调制解调系统开发与硬件片内测试
创作时间:
作者:
@小白创作中心
基于FPGA的8PSK调制解调系统开发与硬件片内测试
引用
CSDN
1.
https://blog.csdn.net/hlayumi1234567/article/details/143728385
1.算法仿真效果
本文是之前写的文章的硬件测试版本,在系统在仿真版本基础上增加了ila在线数据采集模块,vio在线SNR设置模块,数据源模块。
硬件ila测试结果如下:(完整代码运行后无水印)
vio设置SNR=20db
将ila硬件测试数据导出,用matlab显示星座图:
vio设置SNR=15db
将ila硬件测试数据导出,用matlab显示星座图:
硬件测试操作步骤可参考程序配套的操作视频。
2.算法涉及理论知识概要
随着通信技术的不断发展,相位调制技术因其高频谱效率和抗干扰能力而广泛应用于无线通信系统中。其中,8PSK(8相位相移键控)作为一种高阶调制方式,具有更高的频谱效率和更强的抗干扰能力,因此备受关注。然而,8PSK调制解调的实现复杂度较高,需要高效的数字信号处理技术。现场可编程门阵列(FPGA)作为一种可编程逻辑器件,具有高度的灵活性和并行处理能力,非常适合实现复杂的数字信号处理算法。
8PSK调制是一种相位调制方式,其基本原理是通过改变载波的相位来传递信息。在8PSK中,一个符号周期内的相位变化有8种可能的状态,分别对应3个比特的信息。因此,8PSK调制可以看作是一种将3个比特映射到一个符号的映射方式。具体地,假设输入的比特序列为b2b1b0,则对应的8PSK符号可以表示为:
S(t)=Acos(2πfct+θk) (1)
其中,A是载波的振幅,fc是载波的频率,θk是第k个符号的相位,k=0,1,...,7。θk的取值由输入的比特序列b2b1b0决定,具体的映射关系如表1所示。
表1:8PSK映射关系
其星座图如下所示:
3.Verilog核心程序
module tops_hdw(
input i_clk,
input i_rst,
output reg [3:0] led
);
wire o_msg;
//产生模拟测试数据
signal signal_u(
.i_clk (i_clk),
.i_rst (~i_rst),
.o_bits(o_msg)
);
//设置SNR
wire signed[7:0]o_SNR;
vio_0 your_instance_name (
.clk(i_clk), // input wire clk
.probe_out0(o_SNR) // output wire [7 : 0] probe_out0
);
wire[2:0]o_ISET;
wire signed[15:0]o_I8psk;
wire signed[15:0]o_Q8psk;
wire signed[15:0]o_Ifir_T;
wire signed[15:0]o_Qfir_T;
wire signed[31:0]o_mod_T;
wire signed[15:0]o_Nmod_T;
wire signed[31:0]o_modc_R;
wire signed[31:0]o_mods_R;
wire signed[31:0]o_Ifir_R;
wire signed[31:0]o_Qfir_R;
wire [2:0]o_wbits;
wire o_bits;
wire signed[31:0]o_error_num;
wire signed[31:0]o_total_num;
TOPS_8PSK TOPS_8PSK_u(
.i_clk (i_clk),
.i_rst (~i_rst),
.i_SNR (o_SNR),
.i_dat (o_msg),
.o_ISET (o_ISET),
.o_I8psk(o_I8psk),
.o_Q8psk(o_Q8psk),
.o_Ifir_T (o_Ifir_T),
.o_Qfir_T (o_Qfir_T),
.o_mod_T (o_mod_T),
.o_Nmod_T(o_Nmod_T),
.o_modc_R (o_modc_R),
.o_mods_R (o_mods_R),
.o_Ifir_R (o_Ifir_R),
.o_Qfir_R (o_Qfir_R),
.o_wbits(o_wbits),
.o_bits (o_bits),
.o_error_num(o_error_num),
.o_total_num(o_total_num),
.o_flag(o_flag)
);
//ila篇内测试分析模块
ila_1 ila_u (
.clk(i_clk), // input wire clk
.probe0({
o_msg,o_SNR,//9
o_Ifir_T[15:6], o_Qfir_T[15:6],o_Nmod_T[15:6],//36
o_modc_R[27:12],o_mods_R[27:12],o_Ifir_R[27:12],o_Qfir_R[27:12],//64
o_bits,
o_error_num,o_total_num,errflag,//64
o_rec2,o_flag
})
);
endmodule
4.开发板使用说明和如何移植不同的开发板
注意:硬件片内测试是指发射接收均在一个板子内完成,因此不需要定时同步模块。
在本课题中,使用的开发板是:
如果你的开发板和我的不一样,可以参考代码包中的程序移植方法进行移植:
5.完整算法代码文件获得
V
热门推荐
又一千亿巨头诞生!航空工业174亿大重组,“歼-20”有望飞入A股
中国剩余定理:从历史到应用的全面解析
如何管理小区的噪音问题?这种管理对居民生活质量有何影响?
自考如何获得学位证书?有必要拿吗?
重塑自我—抵制日常诱惑的简单策略
音乐人生:美国传奇音乐人、“流行乐之王”迈克尔·杰克逊
解决分布式事务的方案 —— Seata
“泡沫尿”就是病吗?这几种情况也会出现气泡,不要自己吓唬自己
沃顿商学院终身教授:很多孩子都大器晚成,“开窍”关键在于……
孩子给游戏里充钱该怎么教育
解决复杂儿童白内障难题,卢奕教授点亮三位孩童眼疾阴霾
大理河尾百年敬老民俗“耆英会”
种植蓝莓的4个基本要求,以及地栽蓝莓的优缺点
為什麼有人喜歡算命?探究算命背後的心理與文化因素
氯唑沙宗片服用期间,饮酒是否可行?
股票何时适合抄底?这种抄底时机如何判断和把握?
2025广州中考跨区生全攻略|户籍学籍不统一?这篇帮你理清升学路径!
倒车时的方向盘操作技巧是什么?这些技巧如何提高倒车安全?
养车养出新毛病?平台仅赔一半引发争议
游戏源码修改完全指南:从入门到精通
“四海龙王”分别各是什么龙?都有什么来历?各有什么本领?
主卧照片摆放指南:打造温馨又个性化的私人空间
温水是多少度的水温
重视戊型肝炎监测和防控
53岁杨钰莹现状:和母亲定居深圳,在豪宅种菜生活惬意,仍未结婚
家庭陪伴的重要性:让父母老去,我们不老去
知足常乐的诗句
吊灯里面的灯怎么换?家居照明更换全攻略
荷包牡丹好养吗?养殖方法和养护要点是什么?
抖音永久封禁后手机号码怎么解绑?详细操作指南