基于VHDL(Verilog)语言的汉明码编码器和译码器的设计(串行设计)

2023-10-11 00:30

本文主要是介绍基于VHDL(Verilog)语言的汉明码编码器和译码器的设计(串行设计),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于Verilog语言的汉明码设计,刚开始根据汉明码的原理,设计了并行的输入和clk,产生数据。

汉明码的实质及原理

汉明码实质上是个多重奇偶校验,实现原理为:在有效信息位中加入几个校验位形成汉明码,使码距比较均匀的拉大,最大的特点:具有校验并纠正一位错误的能力。

原来的设计(课程设计大部分都这么设计)

后面发现要求不对,输入信号需要自己使用m序列产生。并且采用串行的方式

总体思路:

使用m序列发生器,产生输入信号,经过串并转换为汉明码编码器的输入,得到汉明码编码。再随机产生错误,输入到汉明码译码器中,得到正确输出。经过并串转换,得到输出信号。

又仔细琢磨,对照仿真图,发现输入输出数据不一致,简单记录一下排查过程

上代码(译码部分):

always@(posedge h_clk)//同步检测
begind_shift[0]<=dataerror;d_shift[6:1]<=d_shift[5:0];if(decode_cnt==3'd6)begind_buff[6:0]<=d_shift[6:0];S2[2]<=d_buff[6]^d_buff[5]^d_buff[4]^d_buff[2];S2[1]<=d_buff[6]^d_buff[5]^d_buff[3]^d_buff[1];S2[0]<=d_buff[6]^d_buff[4]^d_buff[3]^d_buff[0];S1<=S2;if((S1&S2)!=0)decode_cnt<=3'd6;elsedecode_cnt<=3'd0; o_buff[3]<=d_buff[6]^((d_buff[6]+d_buff[5]+d_buff[4]+d_buff[2])&(d_buff[6]+d_buff[5]+d_buff[3]+d_buff[1])&(d_buff[6]+d_buff[4]+d_buff[3]+d_buff[0]));o_buff[2]<=d_buff[5]^((d_buff[6]+d_buff[5]+d_buff[4]+d_buff[2])&(d_buff[6]+d_buff[5]+d_buff[3]+d_buff[1])&(~(d_buff[6]+d_buff[4]+d_buff[3]+d_buff[0])));o_buff[1]<=d_buff[4]^((d_buff[6]+d_buff[5]+d_buff[4]+d_buff[2])&(~(d_buff[6]+d_buff[5]+d_buff[3]+d_buff[1]))&(d_buff[6]+d_buff[4]+d_buff[3]+d_buff[0]));o_buff[0]<=d_buff[3]^((~(d_buff[6]+d_buff[5]+d_buff[4]+d_buff[2]))&(d_buff[6]+d_buff[5]+d_buff[3]+d_buff[1])&(d_buff[6]+d_buff[4]+d_buff[3]+d_buff[0]));//纠错endelsedecode_cnt<=decode_cnt+3'd1;
end

上仿真结果

输入和输出数据对应补上,虽然在串转并和并转串的过程中存在延时,但也不应该影响数据的输出。

上面这个波形明显不对,后来经过大神的指点,研究了很久,重新写了代码,终于出现了正确波形,上图

输入数据和输出数据,中间都产生了一位错误,但都可以产生正确的输出,具有一位纠错功能。

关注 一枚努力的程序猿

一起学习一起成长

这篇关于基于VHDL(Verilog)语言的汉明码编码器和译码器的设计(串行设计)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/184218

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

SprinBoot+Vue网络商城海鲜市场的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质创作者,全网30w+