基于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
热门推荐
如何适应不断变化的世界:掌握应对挑战的秘诀
从温如风到安北斗:理想与现实的碰撞
职场新人如何平衡理想与现实?
国庆打卡:景德镇必去陶瓷艺术景点推荐
如何有效投诉派出所?详细流程+注意事项,让你依法维护权益!
直击DSA 2024:中国公司推出ET80反潜鱼雷和便携式无人机杀手
如何分析港股趋势的影响因素?这些因素对港股市场有何作用?
温碧霞:香港女神的绚烂人生
五台山自由行新玩法:不爬山也能玩转圣地
五台山文殊菩萨庙会盛大开幕!
南宁公交K7路
昆山市市场监管局严查外卖安全,你点的餐靠谱吗?
西湖藕粉:从千年贡品到现代养生新宠
夏日清凉:西湖藕粉的花样吃法
尼克松访华必带:三家村西湖藕粉
秋长镇自驾游:最美摄影打卡地推荐!
惠州秋冬自驾游打卡地大揭秘!
X染色体和Y染色体的区别
从《论语》到现代:解读“苗而不秀”的现实意义
埃塞俄比亚AI产业崛起:亚的斯亚贝巴的新机遇
埃塞俄比亚:人口红利驱动的经济新引擎
汕头陈慈黉故居游玩攻略:岭南第一豪宅的前世今生
孩子上学没时间大户外?试试这三个方法!
《喜羊羊与灰太狼之飞马奇遇记》:奇幻世界中的成长与友谊
广东最适合度假的城市,毫无班味
花儿和蜜蜂组CP,采出花蜜靠啥工具?
优化覆盖作物实践对全球农业可持续性的提升潜力
对机器狗发展的冷思考
都江堰龙池:周末避暑新宠!
成都旅游攻略:四季穿搭全解析