【计算机组成原理Note】2.4.2 加法器

news2025/1/30 16:24:21

文章目录

  • 加法器
    • 1. 一位全加器
    • 2. 串行加法器
    • 3. 串行进位加法器加法器
    • 4. 先行进位加法器

加法器

1. 一位全加器

image-20221127092948405
一 位 全 加 器 , 当 前 位 输 出 : S i = A i ⨁ B i ⨁ C i 也 就 是 输 入 中 有 奇 数 个 1 时 输 出 为 1 ( 异 或 ) 向 高 位 的 进 位 : C i = A i B i + ( A i ⨁ B i ) C i − 1 若 本 位 均 为 1 , 或 本 位 中 一 个 为 1 并 且 来 自 低 位 的 进 位 为 1 , 那 么 向 高 位 的 进 位 就 为 1 进 位 逻 辑 表 达 式 也 可 以 写 成 : C i = A i B i + ( A i + B i ) C i − 1 一位全加器,当前位输出: S_i=A_i\bigoplus B_i\bigoplus C_i\\ 也就是输入中有奇数个1时输出为1(异或)\\ 向高位的进位:C_i=A_iB_i+(A_i\bigoplus B_i)C_{i-1}\\ 若本位均为1,或本位中一个为1并且来自低位的进位为1,那么向高位的进位就为1\\ 进位逻辑表达式也可以写成:C_i=A_iB_i+(A_i+ B_i)C_{i-1} Si=AiBiCi11Ci=AiBi+(AiBi)Ci11111Ci=AiBi+(Ai+Bi)Ci1

其实一位全加器,逻辑表达式可以用与门或门表示,如进位的逻辑表达式不唯一,可以是A、B、C两两与,再或运算(也就是有两个1就进位),但这里用会用异或门和与门来表示,本质上这些逻辑表达式都是一样的。区别就是推到加法器先行进位时P的表示不一样

2. 串行加法器

image-20221127094140226

只有一个全加器,数据逐位串行送入加法器中进行运算。进位触发器用来寄存进位信号,以便参与下一次运算。

如果操作数长n位,加法就要分n次进行,每次产生一位和,并且串行逐位地送回寄存器。

3. 串行进位加法器加法器

image-20221127094536367

把n个全加器串接起来,就可进行两个n位数的相加。

串行进位又称为行波进位,每一级进位直接依赖于前一级的进位,即进位信号是逐级形成的。每一个加法器的计算都取决于来自低位的进位,所以串行进位加法器运算速度取决于每一个加法器求向高位进位的速度

4. 先行进位加法器

先行进位加法器:各级进位信号同时形成,又称为先行进位、同时进位

先来回顾串行进位加法器:

image-20221127094536367

串行进位加法器受到进位信号延迟的影响,计算速度迟缓。所以我们可以先将向高位的进位全部一次性算出来,这样每一位加法器就不需要等待来自低位的进位了:

image-20221127095558250

我们再次简化:

image-20221127100001390

可以发现一个规律:在计算进位时,Pi和Gi不会向低位传,但一定会向高位传。也就是说高位的进位计算依赖于所有低位的Pi和Gi。相应的产生进位的该逻辑部件,我们称为CLU先行进位部件。

这总先行进位加法器随着位数不断增多,套娃越来越严重,逻辑表达式越来越复杂,也就是电路越来越复杂。所以我们一般做到4位先行进位加法器,针对更多位的加法,我们可以对4位先行进位加法器CLA进行组间串行,如下:

image-20221127103012927

但组间串行类似串行进位加法器一样,是有延迟的。每一个4位CLA都在等待来自低位的CLA进位,卫门我们是否可以参考先行进位加法器,将组间进位再次先算出来呢?

image-20221127142545099

可以发现组内进位信号计算和组件进位信号的计算逻辑很相似,组内进位输入每一个位p和g即可输出进位,组间进位输入每一个4位CLA的P和G,就能产生组间进位信号了。所以说,组内进位和组件进位使用的是同一套CLU(先行进位部件,专门用于产生进位的部件CLU+全加器就可以组成CLA)。

优化过的先行进位加法器如下:(CLA电路就相当于CLU,用于产生进位的部件)

image-20221127143717930

串行加法器→串行进位的并行加法器→组内并行、组间串行进位的加法器(单级先行进位方式)→组内并行、组间并行进位的加法器(多级先行进位加法器优化)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/39861.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【目标检测】LLA: Loss-aware label assignment for dense pedestrian detection【标签分配】

总结 本文提出了一种用于行人目标检测的标签分配策略,具体来说,主要有以下几步流程。 构建代价矩阵。通过网络的前向传播得到网络的输出,CclsC^{cls}Ccls, CregC^{reg}Creg,构建代价矩阵CCclsλ∗CregCC^{cls}\lambda*C^{reg}CC…

小程序环境切换自定义组件

背景: 最近一直有参与小程序的项目,发现切换环境时经常要上传然后再设置为体验版,比较麻烦,所以尝试做了个切换环境的组件,分享给大家,希望大家能用得上,提点建议 组件长这个样子 展开后 功能&a…

JVM的垃圾回收机制(GC)

系列文章目录 JVM的内存区域划分_crazy_xieyi的博客-CSDN博客 JVM类加载(类加载过程、双亲委派模型)_crazy_xieyi的博客-CSDN博客 文章目录 一、什么是垃圾回收?二、java的垃圾回收,要回收的内存是哪些?三、回收堆上…

FPGA Base Xilinx跨时钟域宏XPM_CDC

FPGA Base Xilinx跨时钟域宏XPM_CDC最近看手底下的小伙子们写代码,对于跨时钟域的处理极度的不规范,还是放下这句话基础不牢,地动山摇 其实Xilinx公司已经为用户提供了宏定义,实现跨时钟域处理,见截图 XPM_CDC在命名上…

关于旅游景点主题的HTML网页设计——青岛民俗 7页 带登录注册

⛵ 源码获取 文末联系 ✈ Web前端开发技术 描述 网页设计题材,DIVCSS 布局制作,HTMLCSS网页设计期末课程大作业 | 游景点介绍 | 旅游风景区 | 家乡介绍 | 等网站的设计与制作| HTML期末大学生网页设计作业 HTML:结构 CSS:样式 在操作方面上运…

【C++】简化源码——vector的模拟实现

文章目录一、前言二、无参构造&析构三、基础接口1.empty和clear2.size和capacity3.[]和iterator四、resize和reserve五、尾插尾删六、其他构造七、迭代器失效1.insert2.erase八、memcpy问题九、vector.h一、前言 本篇的目的很简单,只有一个:模拟实现…

C语言刷题(一)

🐒博客名:平凡的小苏 📚学习格言:别人可以拷贝我的模式,但不能拷贝我不断往前的激情 目录 用递归法求一个整数一维数组a的最大元素 猴子吃桃问题 奇偶数换位问题 水仙花数(0-100000) 换啤酒…

web前端电影项目作业源码 大学生影视主题网页制作电影网页设计模板 学生静态网页作业成品 dreamweaver电影HTML网站制作

HTML实例网页代码, 本实例适合于初学HTML的同学。该实例里面有设置了css的样式设置,有div的样式格局,这个实例比较全面,有助于同学的学习,本文将介绍如何通过从头开始设计个人网站并将其转换为代码的过程来实践设计。 文章目录一、网页介绍一…

redis命令行操作库、键、和五大数据类型详解

一、数据库操作命令 redis默认有16个数据库,类似数组下标从0开始,初始默认使用0号库。 1.1 测试是否连通 ping测试服务器是否连通 返回pone就是连通了 1.2 切换数据库 select index1.3 数据移动 move key db1.4 显示数据总量 dbsize1.5 数据清除 …

Maven 跳过测试的几种方式

在 Maven 对项目进行编译的时候,我们通常可能会希望跳过复杂的测试。 尤其是在开始项目还不是非常稳定的阶段。 命令行中使用 -Dmaven.test.skiptrue 在命令行,只要简单的给任何目标添加 maven.test.skip 属性就能跳过测试: mvn install …

leetcode:6251. 统计回文子序列数目【dp + 统计xy子序列出现的个数】

目录题目截图题目分析ac code总结题目截图 题目分析 固定了中间的数i后从两边选xy 和 yx对于x y的情况,比较简单预处理每个数字出现的index为ids然后看看两边x各自的个数n1 n2n1和n2必须大于等于2左边可以选n1 * (n1 - 1) // 2右边可以选n2 * (n2 - 1) // 2两边乘…

【C++】通过哈希表实现map和set

前言 在前面,我们通过红黑树这一底层结构实现了map和set。它们是关联式容器。而现在,我们将通过哈希表这一数据结构重新实现map和set,即unordered系列的关联式容器。因为它们的遍历是无序的,和平衡二叉树不同,不能做到…

APOLLO UDACITY自动驾驶课程笔记——规划、控制

1、路径规划使用三个输入,第一个输入为地图,Apollo提供的地图数据包括公路网和实时交通信息。第二个输入为我们当前在地图上的位置。第三个输入为我们的目的地,目的地取决于车辆中的乘客。 2、将地图转为图形 该图形由“节点”(node)和“边缘…

直流潮流计算matlab程序

一、直流潮流计算原理 直流潮流发的特点是用电力系统的交流潮流(有功功率和无功功率)等值的直流电流来代替。甚至只用直流电路的解析法来分析电力系统的有功潮流,而不考虑无功分布对有功的影响。这样一来计算速度加快,但计算的准确…

Rocket MQ : 拒绝神化零拷贝

注: 本文绝非对零拷贝机制的否定笔者能力有限,理解偏差请大家多多指正不可否认零拷贝对于Rocket MQ的高性能表现有着积极正面的作用,但是笔者认为只是锦上添花,并非决定性因素。Rocket MQ性能卓越的原因绝非零拷贝就可以一言以蔽之。 笔者企图…

第146篇 笔记-智能合约介绍

定义:当满足某些预定义条件时,智能合约是一种在区块链网络上运行的防篡改程序。 1.什么是智能合约 智能合约是在区块链网络上托管和执行的计算机程序。每个智能合约都包含指定预定条件的代码,这些条件在满足时会触发并产生结果。通过在去中…

IDEA热部署插件JRebel and XRebel

IDEA热部署插件JRebel and XRebel嘚吧嘚下载安装激活配置使用嘚吧嘚 刚开始用过一段时间的eclipse,其他方面没感觉,但是eclipse的热部署真的是深得我心啊😊。 后来换了IDEA,瞬间就心动了,各个方面真的很好用&#xf…

U3D VideoPlayer播放视频和坑点

最近做的游戏里,需要先播放一段几秒钟的工作室LOGO片头,拿到的视频是AVI格式,以前没在U3D里用到过视频,本以为很简单,没想到都2022年了,U3D播放视频还这么烂。。。 插件最好用的是AVPro,除非你有大量的视频要播放,否则没必要用插件,一个是贵,另一个插件很大。 首先…

Python爬虫从入门到进阶

前言 董伟明,国内某知名Python应用网站高级产品开发工程师,《 Python Web 开发实战》作者,本书目前已经售出 17k 余本,另外也已经在台湾地区上市。在 2012 和 2014 年分别通过 2 个爬虫免试获得 2 个业界知名公司 offer&#xff…

MyBatis缓存机制之一级缓存

MyBatis缓存机制之一级缓存 前言 MyBatis内部封装了JDBC,简化了加载驱动、创建连接、创建statement等繁杂的过程,是我们常见的持久性框架。缓存是在计算机内存中保存的临时数据,读取时无需再从磁盘中读取,从而减少数据库的查询次…