news 2026/4/30 3:14:07

【硬件测试】基于FPGA的8PSK+帧同步系统开发与硬件片内测试,包含高斯信道,误码统计,可设置SNR

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【硬件测试】基于FPGA的8PSK+帧同步系统开发与硬件片内测试,包含高斯信道,误码统计,可设置SNR

.算法硬件测试效果

硬件ila测试结果如下:(完整代码运行后无水印):

vio设置SNR=30db

1

vio设置SNR=15db

2

硬件测试操作步骤可参考程序配套的操作视频。

2.算法涉及理论知识概要

随着通信技术的不断发展,相位调制技术因其高频谱效率和抗干扰能力而广泛应用于无线通信系统中。其中,8PSK(8相位相移键控)作为一种高阶调制方式,具有更高的频谱效率和更强的抗干扰能力,因此备受关注。然而,8PSK调制解调的实现复杂度较高,需要高效的数字信号处理技术。现场可编程门阵列(FPGA)作为一种可编程逻辑器件,具有高度的灵活性和并行处理能力,非常适合实现复杂的数字信号处理算法。

2.1 8PSK调制原理

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

其星座图如下所示:

4

2.2 帧同步

在数字通信中,信息通常是以帧为单位进行组织和传输的。帧同步的目的是确定每一帧的起始位置,以便接收端能够正确地解调出每帧中的数据。

设发送的帧结构为:帧同步码 + 信息码元序列 。帧同步码是具有特定规律的码序列,用于接收端识别帧的起始。

帧同步的过程就是在接收序列中寻找与帧同步码匹配的位置,一旦找到匹配位置,就确定了帧的起始位置,后续的码元就可以按照帧结构进行正确的划分和处理。

3.Verilog核心程序

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

`timescale 1ns / 1ps

//////////////////////////////////////////////////////////////////////////////////

// Company:

// Engineer:

//

// Create Date: 2024/11/04 19:54:30

// Design Name:

// Module Name: tops_hdw

// Project Name:

// Target Devices:

// Tool Versions:

// Description:

//

// Dependencies:

//

// Revision:

// Revision 0.01 - File Created

// Additional Comments:

//

//////////////////////////////////////////////////////////////////////////////////

module tops_hdw(

input i_clk,

input i_rst,

output reg [3:0] led

);

//产生模拟测试数据

wire o_msg;

wire[1:0]o_en;

signal signal_u(

.i_clk (i_clk),

.i_rst (~i_rst),

.o_bits(o_msg),

.o_en (o_en)

);

//设置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 [1:0]o_bits_head;

wire [7:0]o_peak;

wire o_en_data;

wire o_en_pn;

wire o_frame_start;

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_en (o_en),

.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_bits_head(o_bits_head),

.o_peak(o_peak),

.o_en_data(o_en_data),

.o_en_pn(o_en_pn),

.o_frame_start(o_frame_start),

.o_error_num(o_error_num),

.o_total_num(o_total_num)

);

//ila篇内测试分析模块140

//ila篇内测试分析模块140

ila_0 ila_u (

.clk(i_clk), // input wire clk

.probe0({

o_msg,o_SNR,o_I8psk[15:6],o_Q8psk[15:6],//30

o_Nmod_T,o_Ifir_R[27:14],o_Qfir_R[27:14],o_wbits,//48

o_error_num[15:0],o_total_num[23:0],//40

//28

o_en_pn,

o_en_data,

o_peak,

o_bits_head,

o_bits

})

);

endmodule

0sj2_065m

4.开发板使用说明和如何移植不同的开发板

注意:硬件片内测试是指发射接收均在一个板子内完成,因此不需要定时同步模块。

在本课题中,使用的开发板是:

5

如果你的开发板和我的不一样,可以参考代码包中的程序移植方法进行移植。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/29 20:50:02

中国移动中兴云电脑W132D-RK3528-2+32G_安卓9_ADB开启线刷包

中国移动中兴云电脑W132D-RK3528-232G_安卓9_ADB开启线刷包 往期固件: 参考:中国移动中兴云电脑W132D-RK3528-232G-刷机固件包(非原机制作) 链接:https://blog.csdn.net/fatiaozhang9527/article/details/151287241?o…

作者头像 李华
网站建设 2026/4/30 0:04:50

深度学习python项目--垃圾图像分类识别 关键模型:VGG19DenseNet121Res...

深度学习python项目--垃圾图像分类识别 关键模型:VGG19DenseNet121ResNeXt101 包含内容:数据集ppt文档代码搞图像分类项目的时候,选模型总让人头大。这次垃圾识别项目我试了三个经典CNN架构:VGG19、DenseNet121和ResNeXt101。这三个老将放在垃圾数据集上…

作者头像 李华
网站建设 2026/4/22 20:28:36

3000亿参数AI大模型部署终极指南:4步实现低成本企业级应用

3000亿参数AI大模型部署终极指南:4步实现低成本企业级应用 【免费下载链接】ERNIE-4.5-300B-A47B-W4A8C8-TP4-Paddle 项目地址: https://ai.gitcode.com/hf_mirrors/baidu/ERNIE-4.5-300B-A47B-W4A8C8-TP4-Paddle 在AI大模型技术快速发展的今天,…

作者头像 李华
网站建设 2026/4/23 21:27:41

Manim 3D螺旋动画:从DNA到宇宙的数学可视化之旅

Manim 3D螺旋动画:从DNA到宇宙的数学可视化之旅 【免费下载链接】manim A community-maintained Python framework for creating mathematical animations. 项目地址: https://gitcode.com/GitHub_Trending/man/manim 想象一下,你能用代码编织出…

作者头像 李华
网站建设 2026/4/25 20:12:00

基于Simulink的UR5机械臂的变阻抗控制及平面力跟踪仿真

基于位置的阻抗控制,自适应变阻抗控制,平面力跟踪仿真,有结果图,simscape simulink matlab,机械臂采用ur5直接上干货。咱今天聊机械臂的力控制,拿UR5当例子,在Simulink里搞基于位置的阻抗控制。…

作者头像 李华
网站建设 2026/4/26 23:25:27

快速上手Codebox:开源云端IDE的终极配置指南

快速上手Codebox:开源云端IDE的终极配置指南 【免费下载链接】codebox Open source cloud & desktop IDE 项目地址: https://gitcode.com/gh_mirrors/co/codebox Codebox是一款功能强大的开源云端和桌面集成开发环境,让你在本地或云端都能享受…

作者头像 李华