当前位置: 首页 > news >正文

基于FPGA的BPSK+costas环实现,包含testbench,高斯信道,误码统计,可设置SNR

1.算法仿真效果

加入频偏:

1

设置SNR=30db

2

(无误码,上图中误码个数8为costas锁定过程中带来的)

设置SNR=15db

3

(无误码,上图中误码个数8为costas锁定过程中带来的)

设置SNR=5db

4

 

(误码2400个测试符号,错误30个,其中8个误码为costas锁定过程中带来的)

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

Costas环是一种用于载波同步的常见方法,特别是在调制解调中,它被广泛用于解调相位调制信号,如二进制调相(BPSK)或四进制调相(QPSK)信号。它的目的是估计和追踪接收信号的相位偏移,以便正确解调数据。

       其基本结构如下图所示

5

Costas环结构:

如上图所示Costas环包括两个主要部分:一个偏移90度的本地振荡器(Local Oscillator,LO)和一个相移解调器。这两个部分协同工作来估计信号的相位偏移。

Costas环包括以下主要组件:

本地振荡器(Local Oscillator,LO): LO产生一个本地参考信号,其频率与接收信号的载波频率相同。这个本地参考信号通常包括正弦和余弦两路信号,相位相差90度。这两路信号将与接收信号相位进行比较。

相位解调器(Phase Detector): 相位解调器用于测量接收信号和本地振荡器之间的相位差。它的输出是一个带有相位信息的信号。

环路滤波器(Loop Filter): 环路滤波器对相位差信息进行滤波和处理,以生成一个控制电压。这个电压将用于调整本地振荡器的频率和相位,以最小化相位差。

本地振荡器控制单元: 这个单元接收来自环路滤波器的控制电压,并相应地调整本地振荡器的频率和相位。

输出: Costas环的输出是本地振荡器的相位信息,该信息已经被调整,以与接收信号的相位保持同步。这个输出可以用于解调接收信号。

3.Verilog核心程序

`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company: 
// Engineer: 
// 
// Create Date: 2024/12/22 20:48:51
// Design Name: 
// Module Name: TEST
// Project Name: 
// Target Devices: 
// Tool Versions: 
// Description: 
// 
// Dependencies: 
// 
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
// 
//////////////////////////////////////////////////////////////////////////////////module TEST();
reg            i_clk;
reg            i_rst;
wire signed[1:0]o_msg;
wire signed[7:0]o_msg_filter;
wire signed[15:0]o_msg_mod;
wire signed[15:0]o_msg_modn_SNR20;
wire signed[15:0]o_low_filter_SNR20;
wire signed[31:0]o_delta_fre_SNR20;signal signal_u(
.i_clk        (i_clk),
.i_rst        (i_rst),
.o_bits       (o_msg)
);tops_costas tops_costas1(
.i_clk        (i_clk),
.i_rst        (i_rst),
.i_SNR        (5),
.i_msg        (o_msg),
.o_msg_filter (o_msg_filter),
.o_msg_mod    (o_msg_mod),
.o_msg_modn   (o_msg_modn_SNR20),
.o_low_filter (o_low_filter_SNR20),
.o_delta_fre  (o_delta_fre_SNR20)
);wire [31:0]o_error_num;
wire [31:0]o_total_num;
Error_Chech Error_Chech_us(
.i_clk        (i_clk),
.i_rst        (i_rst),
.i_trans      (o_msg),
.i_rec        (o_low_filter_SNR20),
.o_error_num  (o_error_num),
.o_total_num  (o_total_num)
);initial begin// Initialize Inputsi_clk = 1;i_rst = 1;// Wait 100 ns for global reset to finish#10250 i_rst = 0;  // Add stimulus hereendalways #5 i_clk=~i_clk;endmodule0sj_074m

  

 

http://www.jsqmd.com/news/40636/

相关文章:

  • 【硬件测试】基于FPGA的BPSK+costas环系统开发与硬件片内测试,包含高斯信道,误码统计,可设置SNR
  • ### 4
  • 每日一句
  • 4.3 基于极限拉伸强度估算零件S-N曲线
  • 2025年宁夏AI客服服务商/供应商最新top5专业推荐:智能交互重构企业服务新范式
  • Windows 文件删除命令详解
  • Polander is good.
  • 2025年宁夏智能体定制服务商专业评测:智能体重构企业服务新生态
  • 在ec2上部署deepseekOCR模型
  • 软件工程学习日志2025.11.14
  • why should woman have a shorter name
  • 使用DeepSeek润色论文:掌握这些高效指令,精准润色
  • 轨迹方程1
  • Marie Curie the shortest
  • Linux增加root权限用户
  • 2025亲测靠谱的5家留学机构推荐,新通教育必看!
  • 2025.11.14
  • Whistle操作文档
  • 线世界“3P”:数码影音界的璀璨明珠
  • C# 流程控制(学习笔记3)
  • 在周五晚上
  • 电商创业必看!4步打通运营关键环节 - 智慧园区
  • 藤校录取率超93%!2025年美国留学中介TOP5推荐,附专属申请方案
  • 【提示词工程】PPT做得越用心,听众越想睡觉?
  • 2025年11月宁夏GEO/人工智能搜索优化服务商/厂商/企业最新top5专业推荐:GEO引领智能营销新范式
  • win10 右击菜单-子项目过多导致 慢
  • 让PlantUML的布线更加简洁的一个方法
  • 《Java工程师必看:JVM性能调优的7个核心参数》‌
  • 20232301郑好 实验五 信息搜集技术实践
  • 2025年澳洲留学中介机构推荐榜单:八大名校offer保障/全流程服务/高性价比机构推荐​