《计算机组成原理与汇编语言程序设计》实验报告一 基本数字逻辑及汉字显示

目  录

一、实验学时

二、实验目的

三、实验要求

四、实验内容

五、实验步骤

1、打开Logisim软件,列出异或逻辑电路真值表,并使用与、或、非基本原件实现异或逻辑电路。

2、打开Logisim软件,列出同或逻辑电路真值表,并使用与、或、非基本原件实现同或逻辑电路。

3、打开Logisim软件,列出一位二进制数据比较器真值表,并使用与、非、异或非原件实现一位二进制数据比较器逻辑电路。

4、打开Logisim软件,列出全加器逻辑电路真值表,并使用与、或、异或原件实现全加器逻辑电路。

5、打开Logisim软件,列出3-8译码器逻辑电路真值表,并使用非、或原件实现3-8译码器逻辑电路。

6、打开Logisim软件以及机内码与汉字转换软件,并打开电路文件分析和理解相关的电路功能。

六、实验小结

1、问题和解决方法

2、心得体会


一、实验学时

        课堂2学时,课后2学时

二、实验目的

        1) 熟悉Logisim软件的使用方法。

        2) 掌握基本数字逻辑电路实现方法。

        3) 熟悉汉字字库及显示电路。

三、实验要求

        1)做好实验预习,复习基本数字逻辑电路的原理,掌握实验元器件的功能特性。

        2)按照实验内容与步骤的要求,独立思考,认真仔细地完成实验。

        3)书写实验报告。

四、实验内容

        1、本次实验使用Logisim软件实现基本的数字逻辑电路,与、或、非等基本原件的使用,及异或(XOR)、同或逻辑的实现。

        (1)异或电路及真值表示意如下:

图4-1 异或真值表及电路图

        (2)在完成基本数字逻辑测试的基础上,完成3-8译码器,一位二进制数据比较器设计。

        (3)请列出上述提到基本数字逻辑电路真值表,最后在Logisim中实现连线,并测试逻辑是否正确。

        2、利用给出的电路文件,熟悉汉字显示电路,分析相关子电路的功能,理解GB2312编码与区位码的转化规则和电路实现,熟悉Logisim中存储器ROM、LED点阵的使用。最后利用机内码与汉字转换工具,或者自己编程实现转化,将自己名字写进GB2312 存储器中,实现将自己的名字在LED点阵中显示。

图4-2  所需电路及工作区

五、实验步骤

1、打开Logisim软件,列出异或逻辑电路真值表,并使用与、或、非基本原件实现异或逻辑电路。

        (1)使用异或逻辑公式F=A⊕B=AB’+A’B(F为A异或B的结果值,⊕为异或符号,A’和B’分别表示对A、B进行非操作后的结果)完成对异或逻辑电路的实现,对应的异或逻辑电路真值表如图5-1-1所示:

图5-1-1 异或逻辑电路真值表

        (2)依据异或逻辑公式完成异或逻辑电路的架构,输入端A、B,先进行A的非操作,然后与B进行与操作得到A’B;再进行B的非操作,然后与A进行与操作得到AB’,最后将A’B和AB’进行或操作,得到最后的异或逻辑运算结果F,对应的异或逻辑电路如图5-1-2所示:

图5-1-2 异或逻辑电路

        (3)异或逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的异或逻辑电路测试如图5-1-3至5-1-5所示:

图5-1-3 异或逻辑电路测试0⊕0

图5-1-4 异或逻辑电路测试1⊕0

图5-1-5 异或逻辑电路测试1⊕1

2、打开Logisim软件,列出同或逻辑电路真值表,并使用与、或、非基本原件实现同或逻辑电路。

        (1)使用同或逻辑公式F=A⨀B=AB+A’B’(F为A同或B的结果值,⨀为同或符号,A’和B’分别表示对A、B进行非操作后的结果)完成对同或逻辑电路的实现,对应的同或逻辑电路真值表如图5-2-1所示:

图5-2-1 同或逻辑电路真值表

        (2)依据同或逻辑公式完成同或逻辑电路的架构,输入端A、B,先进行A和B的与操作后得到AB;然后分别进行A和B的非操作后并进行与操作得到A’B’;最后将AB和A’B’进行或操作,得到最后的同或逻辑运算结果F,对应的同或逻辑电路如图5-2-2所示:

图5-2-2 同或逻辑电路

        (3)同或逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的同或逻辑电路测试如图5-2-3至5-2-5所示:

图5-2-3 同或逻辑电路测试1⨀0

图5-2-4 同或逻辑电路测试0⨀1

图5-2-5 同或逻辑电路测试1⨀1

        (4)使用同或逻辑公式F=A⨀B=A⨁B(____________)(F为A同或B的结果值,⨀为同或符号,⨁为异或符号)完成对同或逻辑电路的实现,对应的同或逻辑电路真值表如图5-2-6所示:

图5-2-6 同或逻辑电路真值表

        (5)依据对异或操作进行非操作后得到同或逻辑完成同或逻辑电路的架构,在异或的基础之上进行非操作得到最后的同或逻辑运算结果F,对应的同或逻辑电路如图5-2-7所示:

图5-2-7 同或逻辑电路

        (6)同或逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的同或逻辑电路测试如图5-2-8至5-2-10所示:

图5-2-8 同或逻辑电路测试0⨀0

图5-2-9 同或逻辑电路测试1⨀0

图5-2-10 同或逻辑电路测试0⨀1

3、打开Logisim软件,列出一位二进制数据比较器真值表,并使用与、非、异或非原件实现一位二进制数据比较器逻辑电路。

        (1)使用一位二进制数据比较器逻辑公式(A<B)=A’B、(A=B)=A⨀B、(A>B)=AB’(⨀为同或符号,A’和B’分别表示对A、B进行非操作后的结果)完成对一位二进制数据比较器逻辑电路的实现,对应的一位二进制数据比较器逻辑电路真值表如图5-3-1所示:

图5-3-1 一位二进制数据比较器逻辑电路真值表

        (2)依据一位二进制数据比较器逻辑公式完成一位二进制数据比较器逻辑电路的架构,输入端A、B,先进行A的非操作,然后与B进行与操作得到A’B,A’B=1则表示A<B;再进行B的非操作,然后与A进行与操作得到AB’,AB’=1则表示A>B;最后A和B进行同或操作结果为1则表示A=B,对应的一位二进制数据比较器逻辑电路如图5-3-2所示:

图5-3-2 一位二进制数据比较器逻辑电路

        (3)一位二进制数据比较器逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的一位二进制数据比较器逻辑电路测试如图5-3-3至5-3-5所示:

图5-3-3 一位二进制数据比较器逻辑电路测试0和0

图5-3-4 一位二进制数据比较器逻辑电路测试1和0

图5-3-5 一位二进制数据比较器逻辑电路测试0和1

4、打开Logisim软件,列出全加器逻辑电路真值表,并使用与、或、异或原件实现全加器逻辑电路。

        (1)使用全加器逻辑公式G=AB、P=A⊕B、CI=G+PC(G为A与B的结果值,P为A异或B的结果值,⊕为异或符号,CI为G或PC的结果值)完成对全加器逻辑电路的实现,对应的全加器逻辑电路真值表如图5-4-1所示:

图5-4-1 全加器逻辑电路真值表

        (2)依据全加器逻辑公式完成全加器逻辑电路的架构,输入端A、B、C,先进行A和B的异或操作得到P;然后进行A和B的与操作得到G;再进行P和C的异或操作得到S;最后将P和C进行与操作后再和G进行或操作,得到最后的全加器逻辑运算结果CI,对应的全加器逻辑电路如图5-4-2所示:

图5-4-2 全加器逻辑电路

        (3)全加器逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的全加器逻辑电路测试如图5-4-3至5-4-5所示:

图5-4-3 全加器逻辑电路测试0+0

图5-4-4 全加器逻辑电路测试1+0

图5-4-5 全加器逻辑电路测试0+1

5、打开Logisim软件,列出3-8译码器逻辑电路真值表,并使用非、或原件实现3-8译码器逻辑电路。

        (1)使用3-8译码器逻辑公式D0=A’B’C’、D1=AB’C’、D2=A’BC’、D3=ABC’、D4=A’B’C、D5=AB’C、D6=A’BC、D7=ABC(A’、B’、C’分别为对A、B、C的非操作,D为进行与操作后的结果值)完成对3-8译码器逻辑电路的实现,对应的3-8译码器逻辑电路真值表如图5-5-1所示:

图5-5-1 3-8译码器逻辑电路真值表

        (2)依据3-8译码器逻辑公式完成3-8译码器逻辑电路的架构,输入端A、B、C,对A、B、C分别进行非操作后再进行与操作得到D0;对B、C分别进行非操作后再和A进行与操作得到D1;对A、C进行非操作后再和B进行与操作后得到D2;对C进行非操作后再和A、B进行与操作后得到D3;对A、B进行非操作后再和C进行与操作后得到D4;对B进行非操作后再和A、C进行与操作得到D5;对A进行非操作后再与B、C进行与操作得到D6;对A、B、C进行与操作后得到D7,对应的3-8译码器逻辑电路如图5-5-2所示:

图5-5-2 3-8译码器逻辑电路

        (3)3-8译码器逻辑电路铺设完毕后进行测试,进而判断自己的电路是否铺设成功,经过测试后此电路状态一切正常,对应的3-8译码器逻辑电路测试如图5-5-3至5-5-8所示:

图5-5-3 3-8译码器逻辑电路测试000

图5-5-4 3-8译码器逻辑电路测试001

图5-5-5 3-8译码器逻辑电路测试010

图5-5-6 3-8译码器逻辑电路测试100

图5-5-7 3-8译码器逻辑电路测试101

图5-5-8 3-8译码器逻辑电路测试110

6、打开Logisim软件以及机内码与汉字转换软件,并打开电路文件分析和理解相关的电路功能。

        (1)使用机内码与汉字转换软件将汉字“于”转换为机内码,得到对应的机内码为D3DA,然后对只读存储器ROM中的内容进行编辑,将其写进GB2312存储器中,实现汉字“于”在LED点阵中的显示,汉字“于”LED点阵显示如图5-6-1所示:

图5-6-1 汉字“于”LED点阵显示

        (2)使用机内码与汉字转换软件将汉字“立”转换为机内码,得到对应的机内码为C1A2,然后对只读存储器ROM中的内容进行编辑,将其写进GB2312存储器中,实现汉字“立”在LED点阵中的显示,汉字“立”LED点阵显示如图5-6-2所示:

图5-6-2 汉字“立”LED点阵显示

        (3)使用机内码与汉字转换软件将汉字“伟”转换为机内码,得到对应的机内码为CEB0,然后对只读存储器ROM中的内容进行编辑,将其写进GB2312存储器中,实现汉字“伟”在LED点阵中的显示,汉字“伟”LED点阵显示如图5-6-3所示:

图5-6-3 汉字“伟”LED点阵显示

六、实验小结

1、问题和解决方法

        (1)实验问题:使用逻辑门和相关元素构建逻辑电路后发现有时输出结果与自己的真值表内容不符。

解决方法:观察自己的逻辑电路后发现部分逻辑门的引脚过多,与、或、非等逻辑门的默认引脚的个数为5个,因此我们需要根据自己需要的引脚数量进行设置,将对应的引脚数量改为自己需要的2个引脚后对应问题得到解决。

        (2)实验问题:在对逻辑门进行连线的过程中发现电路中出现了多余的连线。

解决方法:点击对应多余的连线并进行删除操作或者对该条连线重新进行勾连。

        (3)实验问题:逻辑电路连接完成后发现部分输入端或者输出端是蓝色,且点击输入端进行数值切换对蓝色的输出端无影响。

解决方法:线路没有彻底连接,输入端和输出端的引脚默认朝西,所以在连接电路时要首先将对应端口的引脚方向进行设置,进而方便逻辑电路的正常连接。

        (4)实验问题:逻辑电路中有部分区域的连线为红色。

解决方法:由于红色连线前方处于断路状态,逻辑信号无法正常到达后续的逻辑电路之中,因此出现了红色连线,将对应区段的电路连接通路后即可恢复正常。

        (5)实验问题:在使用两个以上的异或门进行逻辑电路操作时发现出现了错误。

解决方法:由于Logisim允许指定异或门的逻辑行为,默认是当一个输入为1是输出为1,另一种是奇数个1输入时输出为1,因此在使用过程中需要对默认值进行相应的修改操作,进而避免错误的出现。

        (6)实验问题:逻辑电路设计完毕以后,出现了红色或者橘红色的线条,但是自己的逻辑电路没有任何的错误。

解决方法:由于软件本身因素引起的,因此对自己的逻辑电路进行保存,关闭Logisim软件后重新打开对应的逻辑电路文件后即可恢复正常。

2、心得体会

        (1)通过使用Logisim软件对逻辑电路进行操作,让我熟悉了相关的逻辑符号及逻辑运算等。其中蓝色的方框表示输入信号;蓝色的圆框表示输出信号;绿色的圆圈加上短横表示锚,主要用于移动和定位。

        (2)逻辑电路是用来对数字信号进行逻辑运算,以实现逻辑命题的电路。

        (3)组合逻辑电路中电路的输出只与该时刻的输入有关,而时序逻辑电路中电路的输出不仅与该时刻的输入有关,还与电路的原状态有关。

        (4)真值表是描述逻辑功能的最底层工具,它是先结构而后内容的,列数据时输入部分从全0到全1,逐个递增。

        (5)基本逻辑运算是与、或、非,而常用的复合逻辑为与非、或非、与或非、异或、同或。

        (6)逻辑门电路(门电路)用于实现各种的基本逻辑运算、常用符合逻辑运算的电子电路。

        (7)两输入异或、同或互为反函数,即非关系。

        (8)两输入异或、同或的功能为:

        两输入异或,输入取值不同,输出1,输入取值相同,输出0;

        两输入同或,输入取值不同,输出1,输入取值相同,输出0.

        (9)n输入异或的功能为当输入中有奇数个1时,输出值为1,有偶数个1时输出值为0.

        (10)n为偶数时,异或、同或互为非关系;n为奇数时,异或、同或功能相同。

        (11)编码器用于编码,使用二进制代码表示具有某种特定含义的信号,即输入信号输出代码。

        (12)译码器用于译码,将使用一组代码表示的特定含义翻译出来,即输入代码输出信号。

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

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

相关文章

聚焦牛牛道:绿色积分模式如何实现快速发展?

​绿色消费积分政策再次进入大众视野&#xff0c;这种能为企业减轻库存负担、让咨金周转更灵活的促销方式&#xff0c;很快就成了焦点。牛牛道作为积极践行这一政策的平台&#xff0c;凭借其独树一帜的商业模式和运营思路&#xff0c;在短时间内就取得了显著发展。一、牛牛道平…

高频 RFID 赋能工业教学设备教学应用

高频 RFID 赋能工业教学设备教学应用应用背景传统工业教学设备侧重机械原理、电气控制等基础功能演示&#xff0c;缺乏对 RFID 等工业识别技术的具象教学载体。学生在理论学习中难以直观理解 RFID 技术的工业适配逻辑&#xff0c;实训中缺乏设备识别系统的部署、调试经验&#…

Transformer:颠覆NLP的自注意力革命

Transformer:颠覆NLP的自注意力革命 Transformer是自然语言处理领域中极具影响力的深度学习模型架构,以下是对其的详细介绍: 提出背景与应用:2017年,Vaswani等人在《Attention Is All You Need》论文中首次提出Transformer架构,它主要用于处理序列到序列的任务,如机器翻…

基于 KeepAlived + HAProxy 搭建 RabbitMQ 高可用负载均衡集群

基于 KeepAlived HAProxy 搭建 RabbitMQ 高可用负载均衡集群 基于 KeepAlived HAProxy 搭建 RabbitMQ 高可用负载均衡集群实战指南 一、前言 在企业级应用中&#xff0c;消息队列的高可用性是系统稳定性的重要保障。RabbitMQ 作为主流的消息中间件&#xff0c;虽然自身支持…

京东获得JD商品详情 API 返回值说明||京东API接入文档

京东商品详情API返回值核心字段说明一、商品基础信息商品ID&#xff08;skuId/productId&#xff09;唯一标识符&#xff0c;用于定位具体商品或SKU&#xff08;如不同颜色、尺寸的变体&#xff09;。示例&#xff1a;"skuId": "123456789"商品标题&#x…

其他世界的自来水

西欧&#xff0c;北美&#xff0c;亚洲日韩等地区&#xff0c;他们的自来水可以直接饮用以英国为例&#xff1a;自来水的质量可能等同或者有可能超过纯净水&#xff0c;不需要消毒和过滤直接可以饮用。直接从水龙接的水和瓶装纯净水没有什么差别&#xff0c;甚至比瓶装纯净水更…

IO密集型、CPU密集型、负载、负载均衡

0、引入 从宏观上来讲&#xff0c;计算机可以抽象为【输入 > 计算 > 输出】这三部分 输入输出自然就是io&#xff0c;而计算部分自然归cpu管 不同的任务&#xff0c;对io和cpu的依赖程度不同&#xff0c;由此有了cpu密集型任务和io密集型任务 1、IO密集型 更依赖输入…

从甲方的角度看MOM项目成败的原因

关键词&#xff1a;MOM、数字化转型、成败数字化转型中流行这么一句话&#xff1a;SAP项目加班到晚上8点&#xff0c;MOM项目最少到晚上10点。由此可见&#xff0c;MOM项目实施的难度、复杂度。但&#xff0c;为什么MOM难度大&#xff1f;先引入1个故事&#xff1a;1个价值300万…

MySQL操作进阶

系列文章目录 MySQL的基础操作-CSDN博客 目录 系列文章目录 前言 一、数据库的约束 1. 约束类型&#xff1a;not null 2. 约束类型&#xff1a;unique 3. 约束类型&#xff1a;default 4. 约束类型&#xff1a;primary key 5. 约束条件&#xff1a;foreign key 二、表…

表征工程 中怎么 调整参数或比例

表征工程 中怎么 调整参数或比例 在表征工程(Representation Engineering)中,调整参数或比例的核心目标是平衡干预效果与模型基础能力,避免过度干预导致语义失真或能力退化。以下是几种常用的方法论及具体案例: 1. 系数缩放法(Scaling Coefficients):通过权重参数控制…

如何使用Anaconda(miniconda)和Pycharm

文章目录前言具体操作Pycharm连接配置 Anaconda&#xff08;miniconda&#xff09;创建的虚拟环境PipAnacondaPyCharm三者关系一图胜千言总结前言 本文介绍如何利用Anaconda和Pycharm这两个强大的工具&#xff0c;实现Python项目的高效开发。通过构建虚拟环境、安装依赖包及利…

【07】C#入门到精通——C# 生成dll库 C#添加现有DLL C#调用自己生成的dll库

文章目录0 多个.cs文件源码01 Hero.cs02 ShowInfo.cs03 Program.cs &#xff08;相当于Main文件&#xff09;04 运行效果1 生成dll库1.1 创建类库1.2 添加要生成 dll库 的代码文件1.2.1 添加 Hero类1.2.2 添加 ShowInfo类1.3 生成dll库 及 查看3 添加自己生成的dll库4 调用运行…

进程控制->进程替换(Linux)

在之前的博客中&#xff0c;我们已经探讨了进程创建、终止和等待的相关知识。今天&#xff0c;我们将继续深入学习进程控制中的另一个重要概念——进程替换。回顾之前的代码示例&#xff0c;我们使用fork()创建子进程时&#xff0c;子进程会复制父进程的代码和数据&#xff08;…

认识泛型、泛型类和泛型接口

目录泛型泛型类泛型接口泛型 定义类、接口、方法时&#xff0c;同时声明了一个或者多个类型变量&#xff08;如&#xff1a;<E>&#xff09;&#xff0c;称为泛型类、泛型接口、泛型方法、它们统称为泛型 作用&#xff1a;泛型提供了在编译阶段约束所能操作的数据类型&…

如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题

如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题 摘要 本文针对Java项目启动时出现的java.io.IOException: closed错误&#xff0c;提供系统性解决方案。该异常通常由流资源异常关闭或损坏引发&#xff0c;常见于Maven依…

Kafka——多线程开发消费者实例

引言在分布式系统领域&#xff0c;Kafka凭借高吞吐量、低延迟的特性成为消息队列的事实标准。随着硬件技术的飞速发展&#xff0c;服务器多核CPU已成常态——一台普通的云服务器动辄配备16核、32核甚至更多核心。然而&#xff0c;Kafka Java Consumer的设计却长期保持着"单…

PDF 转 HTML5 —— HTML5 填充图形不支持 Even-Odd 奇偶规则?(第二部分)

这是关于该主题的第二部分。如果你还没有阅读第一部分&#xff0c;请先阅读&#xff0c;以便理解“绕组规则”的问题。 快速回顾一下&#xff1a;HTML5 只支持 Non-Zero&#xff08;非零&#xff09;绕组规则&#xff0c;而 PDF 同时支持 Non-Zero 和 Even-Odd&#xff08;奇偶…

机器学习 KNN 算法,鸢尾花案例

目录 一.机器学习概述 二.人工智能的两大方向 三.KNN算法介绍 1.核心思想&#xff1a;“物以类聚&#xff0c;人以群分” 2.算法步骤 四.KNN算法实现 1.安装scikit-learn库 2.导入knn用于分类的类KNeighborsClassifier 3.设置KNeighborsClassifier的相关参数 4.训练模…

强化学习(第三课第三周)

文章目录强化学习&#xff08;第三课第三周&#xff09;一、以火星探测器为例说明强化学习的形式化表示二、强化学习中的回报三、强化学习算法的目标&#xff08;一&#xff09;马尔可夫决策过程&#xff08;二&#xff09;状态动作价值函数&#xff08;四&#xff09;使用Bell…

星痕共鸣数据分析2

今天实验内容是攻击力部分 1.思路 由于昨天数据分析出了一个函数 这个函数可以把奇怪的字节变成正常的数字 int parse_varint(unsigned const char* data, int count) {int value 0;int shift 0;for (int i 0; i < count; i) {unsigned char byte data[i];value | ((byt…