10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码

2024-02-08 21:59

本文主要是介绍10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 always的block之间,采用并行执行

always之内,采用非阻塞赋值,为顺序执行

一些代码分析

这个把使能信号和W信号组合在一起,进行case语句,即只有合并信号最高位为1时,才进行操作

always后面要写@,assign不用

存储元件代码

这没有期望的边沿,就是只要发生变化就会触发

加上posedge,negedge就可以标记期望的边沿

按位操作与逻辑操作

一个操作符就是按位操作,两个就是逻辑操作

香浓展开与选择器实现电路 

对四变量提取w1,做出香浓展开,则w1为选择信号,其他w2,w3,w4组合成被选择的信号

提取出n个量,就有n个选择信号,就需要传进2^n的被选择信号

例一

香浓展开的提取项,就是选择器的选择信号

对两个量进行展开,考虑出所有情况

对于各子项里没有出现的提取项,可以放到任意一个里去,但必须有对应的提取项,最后的目标是各种情况能凑齐子项

移位器

就是移位信号为1时,y3选为0,y2为w3,y1为w2,y0为w1,即整体左移一位

代码

由于采用了always,所以输出信号在模块内要定义成reg

always@(W,Shift)就是说,只要这里面有一个变化,就进行触发

如果用assign就是时刻都在触发,而always是标定信号发生变化时才触发

另一种实现

桶形移位器

就是一个可以指定移动位数的移位器,并且循环

y3,y2,y1,y0是实际输出的每位,每位都是一个四选一选择器,被选择信号就是循环出现的四个信号,然后s1s0组合在一起构成移位信号对每个选择器进行选择。

代码

多位宽信号在运算时,是整成实际大小意义进行的

二进制转格雷码函数

就是从低位与高位两两异或,最高位独自保留

异或实现

 选择器的上是0,下是1的情况,即异或式中,认为一个信号是选择信号,剩下的所有信号的异或运算结果和它的非为被选择信号,选择信号为0时,不做改变,直接消掉,即输出剩下所有的运算结果,即选择上部直接出;为1时,对前面的所有信号的异或运算结果取反,输出取反后的结果;

三个项异或电路

n个项就是往后不断递归加二选一选择器,延长电路长度

这个原理也可说明异或函数能检验一串二进制数的1的个数

如果个数为奇数,则输出结果为1;

如果个数为偶数,则输出结果为0;

这篇关于10.31一些代码分析,香浓展开,移位器(桶形多位),二进制转格雷码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

python多进程实现数据共享的示例代码

《python多进程实现数据共享的示例代码》本文介绍了Python中多进程实现数据共享的方法,包括使用multiprocessing模块和manager模块这两种方法,具有一定的参考价值,感兴趣的可以... 目录背景进程、进程创建进程间通信 进程间共享数据共享list实践背景 安卓ui自动化框架,使用的是

SpringBoot生成和操作PDF的代码详解

《SpringBoot生成和操作PDF的代码详解》本文主要介绍了在SpringBoot项目下,通过代码和操作步骤,详细的介绍了如何操作PDF,希望可以帮助到准备通过JAVA操作PDF的你,项目框架用的... 目录本文简介PDF文件简介代码实现PDF操作基于PDF模板生成,并下载完全基于代码生成,并保存合并P

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.