z3-加法器实验

补码器加减法,运算方法简介

我们要知道什么是补码的加法,我们为什么要用补码的加法?

补码的加法其实就是将两个补码形式的二进制数字直接相加,处理的时候忽略超出固定位数的进位。补码的加法运算和无符号二进制数的加法操作一样,不需要额外处理负号或减法的逻辑

补码加法的具体操作步骤

  1. 将两个补码数位对齐(确保位数一致)
  2. 诸位相加,处理进位
  3. 如果结果超出固定的位数,忽略超出部分的进位

例子:
假如我们在一个8位的系统中进行加法计算

  • 5+3
    • 5的补码:00000101
    • 3的补码:00000011
    • 00001000(结果位8)
  • 5+(-3)
    • 5的补码:00000101
    • -3的补码:11111101
    • 相加:10000010(结果位-2,最高位1表示结果是负数)

那么我们为什么要使用补码的加法?

补码的使用简化了计算机硬件的设计,使有符号的整数运算变得更加高效统一。补码的使用还简化了负数的表示和处理,使计算机更方便地进行各种数值运算。

在了解了补码的加法之后我们就可以尝试设计一位全加器电路了

构造一个一位全加器

首先要知道什么是全加器?

全加器是一种基本的数字电路,用于二进制数的加法运算。它能够同时处理两个二进制数的加法运算。它能够同时处理两个二进制位和一个来自低位的进位输入,并输出该位的和以及进位到高位的值。全加器是构建多位二进制加法器的基本模块。

全加器的功能

全加器有三个输入两个输出:

  • 输入:两个被加的二进制位A和B,以及来自前一位的进位输入C_in_
  • 输出:该位的和S和向更高位传递的进位输出C_out_

全加器的真值表

ABC_in_SC_out_
00000
00110
01010
01101
10010
10101
11001
11111

全加器的逻辑表达式

根据真值表,全加器的输入S和输出C可以用逻辑表达式表示:

  • 和(sum)S:S = A XOR B XOR C_in_
  • 进位(Carry)C_out_:C_out_ = (A * B) + (B * C_in_) + (A * C_in_)

一位全加器的电路实现

如下图所示:
image.png
功能封装
image.png

八位串行加法器

八位串行加法器是一种可以对两个8位二进制数进行加法运算的电路,串行加法器的工作原理是每次处理一个位,并将进位传递到下一位进行累加。以下是八位串行加法器的详细电路设计和验证。

电路设计

  • 全加器:用于对两个二进制位及一个进位进行相加。
  • 移位寄存器:用于存储和移位操作,分别存储两个8位数加数和结果
  • **D触发器:**用于存储和传递进位
  • 时钟:用于同步操作

电路示意图

image.png

使用具体数字验证

1. 初始化
  • A寄存器:10101010
  • B寄存器:01010101
  • 进位 𝐶0:0
2. 逐位相加
  1. 第1次时钟脉冲
    • 取出最低位:A0 = 0, B0 = 1, 𝐶0=0
    • 全加器计算:𝑆0=0⊕1⊕0=1
    • 进位:𝐶1=(0⋅1)+(1⋅0)+(0⋅0)=0
    • 移位:A -> 01010101, B -> 00101010
  2. 第2次时钟脉冲
    • 取出当前位:A1 = 1, B1 = 0, 𝐶1=0
    • 全加器计算:𝑆1=1⊕0⊕0=1
    • 进位:𝐶2=(1⋅0)+(0⋅0)+(1⋅0)=0
    • 移位:A -> 00101010, B -> 00010101
  3. 第3次时钟脉冲
    • 取出当前位:A2 = 0, B2 = 1, 𝐶2=0
    • 全加器计算:𝑆2=0⊕1⊕0=1
    • 进位:𝐶3=(0⋅1)+(1⋅0)+(0⋅0)=0
    • 移位:A -> 00010101, B -> 00001010
  4. 第4次时钟脉冲
    • 取出当前位:A3 = 1, B3 = 0, 𝐶3=0
    • 全加器计算:𝑆3=1⊕0⊕0=1
    • 进位:𝐶4=(1⋅0)+(0⋅0)+(1⋅0)=0
    • 移位:A -> 00001010, B -> 00000101
  5. 第5次时钟脉冲
    • 取出当前位:A4 = 0, B4 = 1, 𝐶4=0
    • 全加器计算:𝑆4=0⊕1⊕0=1
    • 进位:𝐶5=(0⋅1)+(1⋅0)+(0⋅0)=0
    • 移位:A -> 00000101, B -> 00000010
  6. 第6次时钟脉冲
    • 取出当前位:A5 = 1, B5 = 0, 𝐶5=0
    • 全加器计算:𝑆5=1⊕0⊕0=1
    • 进位:𝐶6=(1⋅0)+(0⋅0)+(1⋅0)=0
    • 移位:A -> 00000010, B -> 00000001
  7. 第7次时钟脉冲
    • 取出当前位:A6 = 0, B6 = 1, 𝐶6=0
    • 全加器计算:𝑆6=0⊕1⊕0=1
    • 进位:𝐶7=(0⋅1)+(1⋅0)+(0⋅0)=0
    • 移位:A -> 00000001, B -> 00000000
  8. 第8次时钟脉冲
    • 取出当前位:A7 = 1, B7 = 0, 𝐶7=0
    • 全加器计算:𝑆7=1⊕0⊕0=1
    • 进位:𝐶8=(1⋅0)+(0⋅0)+(1⋅0)=0

结果

最终输出结果的各位和为 𝑆7𝑆6𝑆5𝑆4𝑆3𝑆2𝑆1𝑆0=11111111,即十进制的255。进位输出 𝐶8=0,表示没有产生进位。
image.png

八位可控加减法器

8位可控加减法器是一种能够对两个8位二进制数进行加法或减法运算的电路。它通过控制信号来决定是执行加法还是减法。减法可以通过将被减数取补码并进行加法来实现。以下是详细的电路设计和使用具体数字进行验证的步骤。

电路设计

  • 全加器:用于对两个二进制位及一个进位进行相加。
  • 移位寄存器:用于存储和移位操作,分别存储两个八位数和结果。
  • D触发器:用于存储和传递进位。
  • 时钟:用于同步操作。
  • 异或门:用于将减法操作转化为加法操作。
  • 控制信号:用于选择加法或减法操作。

电路示意图

image.png

使用具体数字验证

加法验证

假设我们要相加的两个8位数是:

  • A = 01101101 (十进制的109)
  • B = 00111011 (十进制的59)
  1. 初始化
    • A寄存器:01101101
    • B寄存器:00111011
    • 进位 _C_0:0
    • 控制信号 Add/Sub = 0(加法)
  2. 逐位相加
  • 第1次时钟脉冲
    • 取出最低位:A0 = 1, B0 = 1, 𝐶0=0
    • 全加器计算:𝑆0=1⊕1⊕0=0
    • 进位:𝐶1=(1⋅1)+(1⋅0)+(0⋅0)=1
    • 移位:A -> 00110110, B -> 00011101
  • 第2次时钟脉冲
    • 取出当前位:A1 = 0, B1 = 1, 𝐶1=1
    • 全加器计算:𝑆1=0⊕1⊕1=0
    • 进位:𝐶2=(0⋅1)+(1⋅1)+(0⋅1)=1
    • 移位:A -> 00011011, B -> 00001110
  • 第3次时钟脉冲
    • 取出当前位:A2 = 1, B2 = 1, 𝐶2=1
    • 全加器计算:𝑆2=1⊕1⊕1=1
    • 进位:𝐶3=(1⋅1)+(1⋅1)+(1⋅1)=1
    • 移位:A -> 00001101, B -> 00000111
  • 第4次时钟脉冲
    • 取出当前位:A3 = 1, B3 = 0, 𝐶3=1
    • 全加器计算:𝑆3=1⊕0⊕1=0
    • 进位:𝐶4=(1⋅0)+(0⋅1)+(1⋅1)=1
    • 移位:A -> 00000110, B -> 00000011
  • 第5次时钟脉冲
    • 取出当前位:A4 = 0, B4 = 1, 𝐶4=1
    • 全加器计算:𝑆4=0⊕1⊕1=0
    • 进位:𝐶5=(0⋅1)+(1⋅1)+(0⋅1)=1
    • 移位:A -> 00000011, B -> 00000001
  • 第6次时钟脉冲
    • 取出当前位:A5 = 1, B5 = 1, 𝐶5=1
    • 全加器计算:𝑆5=1⊕1⊕1=1
    • 进位:𝐶6=(1⋅1)+(1⋅1)+(1⋅1)=1
    • 移位:A -> 00000001, B -> 00000000
  • 第7次时钟脉冲
    • 取出当前位:A6 = 0, B6 = 0, 𝐶6=1
    • 全加器计算:𝑆6=0⊕0⊕1=1
    • 进位:𝐶7=(0⋅0)+(0⋅1)+(0⋅1)=0
    • 移位:A -> 00000000, B -> 00000000
  • 第8次时钟脉冲
    • 取出当前位:A7 = 0, B7 = 0, 𝐶7=0
    • 全加器计算:𝑆7=0⊕0⊕0=0
    • 进位:𝐶8=(0⋅0)+(0⋅0)+(0⋅0)=0
结果

最终输出结果的各位和为 𝑆7𝑆6𝑆5𝑆4𝑆3𝑆2𝑆1𝑆0=10101000,即十进制的168。
image.png

减法验证

初始化
  • A寄存器:01101101
  • B寄存器:00111011
  • 进位 _C_0:1(由于使用补码减法,初始进位为1)
  • 控制信号 Add/Sub = 1(减法)
逐位计算(将B取反再加上A)
  1. 第1次时钟脉冲
    • 取出最低位:A0 = 1, B0 = 1
    • 由于控制信号为1,B0取反:B0’ = 0
    • 全加器计算:𝑆0=1⊕0⊕1=0
    • 进位:𝐶1=(1⋅0)+(0⋅1)+(1⋅1)=1
    • 移位:A -> 00110110, B -> 00011101
  2. 第2次时钟脉冲
    • 取出当前位:A1 = 0, B1 = 1
    • 由于控制信号为1,B1取反:B1’ = 0
    • 全加器计算:𝑆1=0⊕0⊕1=1
    • 进位:𝐶2=(0⋅0)+(0⋅1)+(0⋅1)=0
    • 移位:A -> 00011011, B -> 00001110
  3. 第3次时钟脉冲
    • 取出当前位:A2 = 1, B2 = 1
    • 由于控制信号为1,B2取反:B2’ = 0
    • 全加器计算:𝑆2=1⊕0⊕0=1
    • 进位:𝐶3=(1⋅0)+(0⋅0)+(1⋅0)=0
    • 移位:A -> 00001101, B -> 00000111
  4. 第4次时钟脉冲
    • 取出当前位:A3 = 1, B3 = 0
    • 由于控制信号为1,B3取反:B3’ = 1
    • 全加器计算:𝑆3=1⊕1⊕0=0
    • 进位:𝐶4=(1⋅1)+(1⋅0)+(1⋅0)=1
    • 移位:A -> 00000110, B -> 00000011
  5. 第5次时钟脉冲
    • 取出当前位:A4 = 0, B4 = 1
    • 由于控制信号为1,B4取反:B4’ = 0
    • 全加器计算:𝑆4=0⊕0⊕1=1
    • 进位:𝐶5=(0⋅0)+(0⋅1)+(0⋅1)=0
    • 移位:A -> 00000011, B -> 00000001
  6. 第6次时钟脉冲
    • 取出当前位:A5 = 1, B5 = 0
    • 由于控制信号为1,B5取反:B5’ = 1
    • 全加器计算:𝑆5=1⊕1⊕0=0
    • 进位:𝐶6=(1⋅1)+(1⋅0)+(0⋅0)=1
    • 移位:A -> 00000001, B -> 00000000
  7. 第7次时钟脉冲
    • 取出当前位:A6 = 0, B6 = 0
    • 由于控制信号为1,B6取反:B6’ = 1
    • 全加器计算:𝑆6=0⊕1⊕1=0
    • 进位:𝐶7=(0⋅1)+(1⋅1)+(0⋅1)=0
    • 移位:A -> 00000000, B -> 00000000
  8. 第8次时钟脉冲
    • 取出当前位:A7 = 0, B7 = 0
    • 由于控制信号为1,B7取反:B7’ = 1
    • 全加器计算:𝑆7=0⊕1⊕0=1
    • 进位:𝐶8=(0⋅1)+(1⋅0)+(0⋅0)=0
结果

最终输出结果的各位和为 𝑆7𝑆6𝑆5𝑆4𝑆3𝑆2𝑆1𝑆0=00110010,即十进制的50。
image.png

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

哈希双指针

文章目录 一、哈希1.1两数之和1.2字母异位词分组1.3最长子序列 二、双指针2.1[移动零](https://leetcode.cn/problems/move-zeroes/description/?envTypestudy-plan-v2&envIdtop-100-liked)2.2[盛最多水的容器](https://leetcode.cn/problems/container-with-most-water/d…

新人攻略:避开这3大坑,让老员工主动带你飞!

进入职场的新人们,常常会感到困惑和挑战。他们可能会发现自己在与老员工的交流中遇到难题,甚至发现老员工并不愿意花费时间和精力去指导他们。这背后的原因是什么呢?又该如何改善这一现象呢?本文将从新员工的角度出发,…

C# WPF入门学习(二)——创建一个demo工程

本期任务:创建一个按钮,点击之后在控制台打印文本,设置背景图片、圆角按钮加分。 一、创建WPF项目 创建工程 1. 打开VS 我用的2019 2. 打开界面 3. 选择创建项目 4. 选择C#中的WPF框架 5. 填写项目名称和选择路径 新项目就创建好了&#…

彩虹聚合二级域名DNS管理系统源码v1.3

聚合DNS管理系统可以实现在一个网站内管理多个平台的域名解析, 目前已支持的域名平台有:阿里云、腾讯云、华为云、西部数码、CloudFlare。 本系统支持多用户,每个用户可分配不同的域名解析权限;支持API接口, 支持获…

(Java面试题分享)万里长征-03-搜狐

万里长征-03-搜狐 ⚙ 以下内容基于GPT-4o模型 问题 1.LeetCode103 二叉树的锯齿形层序遍历 103. 二叉树的锯齿形层序遍历 - 力扣(LeetCode) 2.LeetCode5 最长回文子串 5. 最长回文子串 - 力扣(LeetCode) 3.Kafka为何那么快 …

Win32 API

个人主页:星纭-CSDN博客 系列文章专栏 : C语言 踏上取经路,比抵达灵山更重要!一起努力一起进步! 一.Win32 API 1.Win32 API介绍 Windows这个多作业系统除了协调应⽤程序的执⾏、分配内存、管理资源之外,它同时也是…

【达梦系列】IFUN_DATETIME_MODE 导致【无效的客户端版本】

问题描述 在项目开发时,应用程序连接达梦数据库报错:无效的客户端版本。这个问题在没有调整达梦数据参数之前是正常的,调整之后就不对了,但是又不清楚到底是哪个参数的问题。因为调整达梦参数时,用了一个达梦的参数调…

python数据分析——字符串和文本数据2

参考资料:活用pandas库 1、字符串格式化 (1)格式化字符串 要格式化字符串,需要编写一个带有特殊占位符的字符串,并在字符串上调用format方法向占位符插入值。 # 案例1 varflesh wound s"Its just a {}" p…

求斐波那契数列第n项的值

本期介绍🍖 主要介绍:什么是斐波那契数列,递归实现求斐波那契数列第n项值,递归法为什么不适合求斐波那契数,用迭代法实现求斐波那契数列的值👀。 文章目录 1. 斐波那契数列是什么?2. 题目2. 递归…

Java开发大厂面试第26讲:生产环境如何排查问题和优化 JVM?

通过前面几个课时的学习,相信你对 JVM 的理论及实践等相关知识有了一个大体的印象。而本课时将重点讲解 JVM 的排查与优化,这样就会对 JVM 的知识点有一个完整的认识,从而可以更好地应用于实际工作或者面试了。 我们本课时的面试题是&#x…

【气象常用】间断时间序列图

效果图: 主要步骤: 1. 数据准备:随机数组 2. 图像绘制:绘制间断的时间序列 详细代码:着急的直接拖到最后有完整代码 步骤一:导入库包及图片存储路径并设置中文字体为宋体,西文为新罗马&…

Foxit PDF Editor Pro福昕PDF编辑器Pro:重塑您的文档编辑体验

在信息爆炸的时代,PDF文件因其跨平台、格式稳定等特性,成为我们日常工作与学习中不可或缺的一部分。然而,面对这些文件时,许多人都会遇到一个共同的难题:如何高效、专业地编辑PDF内容?今天,我要…

企业内网开源OA服务器(办公自动化系统),搭建O2OA基于Linux(openEuler、CentOS8)

本实验环境为openEuler系统(以server方式安装)(CentOS8基本一致,可参考本文) 目录 知识点实验下载安装O2OA安装mysql配置O2OA 知识点 “O2OA” 是一个开源的、基于Java的办公自动化(Office Automation)系统。其名称中的“O2OA”…

CnosDB:深入理解时序数据质量函数

在CnosDB中,我们设计并实现了计算数据质量的多个指标,这些指标可以从多个维度评估时序数据的质量,对于时间戳列,我们考虑数据的缺失点、冗余点和延迟点。对于值列,我们考虑数据的异常值、范围、变化、速度和加速度。 C…

【对角线遍历】python

没啥思路 class Solution:def findDiagonalOrder(self, mat: List[List[int]]) -> List[int]:mlen(mat)nlen(mat[0])ret[]if len(mat)0:return retcount0#mn-1是对角线总数while count<mn-1:#x和y的和刚好是count数#偶数为右上走if count%20:xcount if(count<m)else (…

(二十一)【Jmeter】定时器作用域

简述 由于在性能测试中,要模拟用户操作时间差,需要设置操作之间的等待时间,Jmeter中有定时器,那么在使用定时器之前,需要了解定时器的工作原理,是否符合我们业务场景的执行要求? 该文主要讲解Jmeter中定时器作用范围,本次文主要使用两种简单模型来进行说明,可以基于这…

Java进阶学习笔记14——模板方法设计模式

面试和看源码。 谈到设计模式&#xff1a; 1、解决了什么问题&#xff1f; 2、怎么写&#xff1f; 模板方法设计模式解决了什么问题&#xff1f; 解决方法中存在重复代码的问题。 写法&#xff1a; 1&#xff09;定义一个抽象类&#xff1a; 2&#xff09;在里面定义两个方…

【限免】短时傅里叶变换时频分析【附MATLAB代码】

来源&#xff1a;微信公众号&#xff1a;EW Frontier 简介 一种能够同时对信号时域和频域分析的方法——短时傅里叶变换&#xff08;STFT&#xff09;&#xff0c;可以在时频二维角度准确地描述信号 的时间、频域的局部特性&#xff0c;与其他算法不同&#xff0c;通过该算法可…

类和对象【六】友元和内部类

文章目录 友元友元的作用友元的缺点友元函数语法&#xff1a;特点&#xff1a; 友元类语法&#xff1a;特点&#xff1a; 内部类概念特点 友元 友元的作用 友元提供了一种打破封装的方式&#xff0c;有时提供了便利。 友元的主要作用就是打破封装 即可以让一个类的友元函数…

Hive(28): CLIs and Commands客户端和命令

1 Hive CLI $HIVE_HOME/bin/hive是一个shellUtil,通常称之为hive的第一代客户端或者旧客户端,主要功能有两个: 用于以交互式或批处理模式运行Hive查询,注意,此时作为客户端,需要并且能够访问的是Hive metastore服务,而不是hiveserver2服务。用于hive相关服务的启动,比如…