计算机组成原理实验1---运算器 预习报告

news2025/1/19 13:06:11

    本实验为哈尔滨工业大学计算机组成原理实验,实验内容均为个人完成,目的是分享交流,如有抄袭将追究责任,笔者能力有限,若因此影响读者的分数,本人深表抱歉。

 一、 实验目的

  1. 了解运算器的组成结构
  2. 基于数据通路图,观察并分析运算器的工作原理
  3. 基于信号时序图,观测并分析运算器的工作原理

二、 实验预习

1.学习使用 TDX-CMX 实验台,然后回答下列问题。

实验台上“时序与操作台单元”中 KK1 功能是选择时序单元的工作状态,KK2 功能是选择时序单元的节拍信号,ST 功能是产生一个节拍信号;方波信号 300Hz、30Hz 和 3Hz 位于实验台的时序与操作台单元单元,ALU 位于实验台的 ALU&REG单元,数据输入位于实验台的 IN单元单元(我看指导书上写的ALU的输入是IN单元 但是不理解为啥输入AB寄存器要通过CON上的SD17等),数据总线和地址总线位于实验台的系统总线单元。

  •  注:CON单元那几个控制部件,是选择什么操作的(算数运算、移位运算、逻辑运算、LDA表示把存的数存入A寄存器中、LDB表示把数存入寄存器B中)
  • CON右边是A和B的输入,从左到右依次是高位到低位
  • 输入之前,一定要多按几下节拍器,这样才会通过时序逻辑将数据传输过去。
  • FZ零标志位,FC进位标志位,要注意这两个的信息。

2.参看实验台运算器实现原理,填写括号处的部件名称或信号名称。

3.ALU 完成哪些基本的逻辑运算、算术运算和移位运算。

  •  逻辑运算:
  1. 取AB其中之一
  2. AB按位或
  3. AB按位与
  4. A取非
  • 算术运算:
  1. 加法运算、
  2. 带进位的加法运算、
  3. 减法运算、
  4. 减一运算、
  5. 加一运算。
  • 移位运算:
  1. A不带进位循环右移B位
  2. A逻辑右移一位
  3. A带进位循环右移一位
  4. A逻辑左移一位
  5. A带进位循环左移一位

 功能如图所示,要了解各种运算的硬件实现。

4.画出 4×4 阵列乘法器原理图,分析延迟与哪些因素有关?

影响因素:与乘数位数有关  与门电路延迟有关

分析:阵列乘法器的工作过程类似于人的手算乘法,FA(全加器)的斜线方向是进位输出,竖线方向是输入和输出,图中最后一行构成了一个串行加法器。由于FA一级是无需考虑进位的,他的进位被暂时保留下来不往前传递,因此同一级中任意一位FA加法器的进位输出和输出几乎是同时形成的,和“串行移位“相比可大大减少同级间的进位传递延迟,所以送往最后一行的串行加法输入与 门电路的级数有关 即与乘积位数有关,也与门电路的延迟有关。

5.简述 Quartus 环境下载 sof 文件到 FPGA 的操作流程。

从桌面上双击打开Quarts,导入文件点击file,openproject找到文件所在的路径安装路径/FPGA/Multiply/Multiply,导入后点击open programma;添加硬件,选择USB,点击左上角start,等待烧录成功。

(1)从桌面打开软件
(2)导入文件
(3)选择打开文件
(4)导入后双击program device
(5)点击Hardware setup添加硬件
(6)选择USB
(7)点击start烧录
(8)查看左上角烧录成功

三、 实验步骤及原始数据记录

本次实验包括基本运算器实验和阵列乘法器实验两部分。

外部PC机实现

  1. 本机运行
  • 把时序与操作台单元的“MODE”用短路块短接,使系统工作在四节拍模式,JP1ALU&REG 单元)用短路块将 1短接,按 所示连接实验电路,并检查无误。图中将用户需要连接的信号用圆圈标明(其它实验相同)。

                                                         实验一接线图

  • 将时序与操作台单元的开关 KK2 置为单拍档,开关 KK1KK3 运行档。确认连线正确。
  • 打开电源,如果听到有‘嘀’报警声,说明有总线竞争,应立即关闭电源,重新检查接线,直到错误排除。然后按动 CON 单元的 CLR 按钮,将运算器的 AFCFZ 清零。

                         连线如图所示,注意相同面的正反相同,否则会读数麻烦。

记录:
SD17~SD10 开关拨到上面,对应 LED 指示灯状态(亮 / 灭) ,表示二进制数据(1/0) 1   SD17~SD10 作用是  形成八位二进制数 , S3、 S2 S1 S0 的作用是  选择ALU的功能    
LDA 的作用是  选择将SD17~SD10产生的二进制数存放再哪个寄存器中。
观察 ALU 单元中:
CLR 前   FZ=     ;FC=     ,A7~A0=   000 000 00   ;B7~B0=    000 000 00  。
这个CLR之前的数据不一定,因为还没有复位,我是因为前面的同学帮我清零了
CLR 后   FZ=     ;FC=     ,A7~A0=   000 000 00   ;B7~B0=    000 000 00  。
注:CLR的作用:将寄存器、FC、FZ等清零,类似于复位器,只不过CLR是内部设备清零
  • 用输入开关向暂存器 置数

按动 2 次时序单元的 ST 按钮,产生 T1、T2 节拍后,拨动 CON 单元的 SD17…SD10 数据开关,形成二进制数 01100101(或其它数值),数据显示亮为‘1’,灭为‘0’。置 LDA=1, LDB=0,按动 2 次 ST 按钮产生 T3、T4节拍,则将二进制数 01100101 置入暂存器 A 中, 暂存器 A 的值通过 ALU单元的 A7…A0 八位 LED 灯显示。(我感觉前提条件得控制LDA指令将传递寄存器打开指令)


 

                                                        如图所示位ST位置 

 记录:

暂存器 A 的数据(二进制):01 100 101

按动 2 次 ST 按钮后 ALU 中 A7~A0 中数据(二进制):01 100 101

  • 用输入开关向暂存器 置数

按动 次时序单元的 ST 按钮,产生 T1T2 节拍后,拨动 CON 单元的 SD17…SD10 数据开关,形成二进制数 10100111(或其它数值。置 LDA=0LDB=1,按动 ST 按钮产生 T3T4 节拍,则将二进制数 10100111 置入暂存中,暂存器 的值通过 ALU 单元的 B7…B0 八位 LED 灯显示。

记录:

暂存器 B 输入数据(二进制):10 100 111

按动  ST 按钮后 ALU  B7~B0 中数据(二进制):10 100 111

改变运算器的功能设置,观察运算器的输出

      按动 次时序单元的 ST 按钮,产生 T1T2 节拍后,置 ALU_B=0LDA=0LDB=0, 然后按 设置 S3S2S1S0 Cn 的数值,并观察数据总线 LED 显示灯显示的结果。

     如置 S3S2S1S0 1001,运算器作加法运算;S3S2S1S0 0010,运算器作逻辑与运算。按动 ST 按钮产生 T3T4 节拍,观察 FCFZ 标志位变化。

  •       当S3S2S1S0 = 1001,运算器做 加法运算

     寄存器A内容01 100 101,寄存器B内容10 100 111

                              FC = 1          FZ =   0

  •       当S3S2S1S0 = 0010,运算器做 逻辑与运算

      寄存器A内容01 100 101,寄存器B内容10 100 111

                              FC = 1          FZ =   0

连接运行

环境的建立及操作的简单介绍

下图演示所需下载的软件,找到安装包并点击进行安装

 安装完以后,此电脑右键->属性->设备管理器(有些电脑打开设备管理器的方式不同,具体问题具体分析)->找到端口 就能看到是否连接USB接口

 安装TDX-CMX

 安装完以后打开发现 下位机已复位代表环境搭建成功

 点击右上角来介绍一下我们的门电路

 分为主存和微存,可以修改数据的值

 修改完之后点击,刷新指令数据区域,数据就完成了更新

 通过下拉可以实现不同的实验查看,对于本实验来说,选择运算器实验

 

 上图表示可以选择不同的时序方式控制查看程序,单拍运行、单周期运行、单机器指令运行、连续运行,当然也可以打开示波器,通过配合我们扩展单元的逻辑层

 点击运行就可以

 时序观测窗口可以选择我们想要观察的信号

 

 点击确定 就可以进行时序观测了

如果还有不明白的 就在实验的帮助菜单中 实验帮助 选择指导书 继续查询

操作

    如果实验箱和 PC 联机操作,则可通过软件中的数据通路图来观测实验结果,也可通过软件中的信号时序图来观测实验结果。

  • 观测数据通路图

    打开 TDX-CMX 软件,选择联机软件的“【实验】—【运算器实验】”,打开运算器实验的数据通路图,如图 2 所示。

    操作方法同本机运行,每按动一次 ST 按钮,数据通路图会有数据的流动,反映当前运算器所做的操作,或在软件中选择“【调试】—【单节拍】”其作用相当于将时序单元的状态开关 KK2 置为‘单拍’档后按动了一次 ST 按钮,数据通路图也会反映当前运算器所做的操作。

     重复上述操作,并完成 3。然后改变 A的值,验证 FCFZ 的锁存功能。点击联机软件的 【回放】【保存按钮,可保存数据通路图的实验过程。

                                                                 表 记录运算结果

观测时序逻辑

     弹出时序观测窗,操作方法同本机运行,记录操作过程的时序图,时序图左侧标明信号的名称

四 阵列乘法器验证实验

实验步骤

烧录见上方实验预习

                                                                 上图为安装路径

  • 根据上述阵列乘法器的原理,使用 Quartus 软件编辑相应的电路原理图并进行编译,其在 FPGA 芯片中对应的引脚如 所示,框外文字表示连线标号,框内文字表示该引脚的含义(本实验例程见‘安装路径\FPGA \Multiply\Multiply.qpf’工程)。

  • 关闭实验系统电源,按 连接实验电路,图中将用户需要连接的信号用圆圈标明。

CON 单元中的 SD10 SD13 四个二进制开关为乘数  , SD03… SD00 四个二进制开关为被乘数 B ,而相乘的结果在扩展单元的 L7… L0 八个 LED 灯显示。给 A B 置不同的数, 观察相乘的结果。

给A和B 置不同的数,观察相乘的结果。 完成实验报告表格。记录被乘数、乘数和乘积:

SD17~SD10输入数据:(00000101)SD07~SD00输入数据:(0 0000011)

L7~L0:(00001111)

下面是该阵列乘法器实现逻辑图,补充括号内缺失的信号名称。

  1. A3B1
  2. A3B0
  3. A3B1
  4. A3B3

这个图具体是怎么填的我也不知道,就是根据阵列乘法器的原理图找规律

思考题

1.本实验完成了 位加法器的设计,如何在实验台上实现 16 位加法运算?

可将十六位加法的低八位和高八位分为两组依次进行计算,首先进行低八位的加法计算,得到结果的低八位和一位进位,然后进行高八位加法运算,如果低八位的进位是0则得到十六位加法的高八位,如果低八位的进位是一则再将结果加一得到十六位加法的高八位。

2.试比较教材中无符号原码一位乘(位)与实验中阵列乘法器的时间延迟。

教材中的无符号原码一位乘(4位)需要进行四次加法和四次移位,每次都会有延迟。而阵列乘法器只有在四次进位时产生延迟。原码一位乘需要四次加运算四次右移运算设每次加法的延迟是2.5ty右移运算的延迟是txT1=10ty+4tx阵列乘法器前三行每行的延迟都是一位加法器的延迟2ty,最后一行的延迟是6ty,T2=3*2ty+3*2ty=12ty,因为右移运算的延迟显著大于一位加法运算,所以T1>T2。

3.思考题:将 A=01H 和 B=02H 进行逻辑与运算,观察运算器零标志 FZ 的时序,是否和进位标志

                                FC 一致 FZ FC都是0 与运算不影响进位 时序一致

五.实验总结

本实验通过对底层硬件的操控和实践,了解了运算器的底层工作逻辑,并通过数据通路图和信号时序图,观察并分析运算器的工作原理 ,加强了对陌生软件的操作能力,同时,通过芯片的连接和管脚的辨别将理论付诸实际,增强了动手能力,同时将上课的理论知识转化为电路实现。通过对阵列乘法器的验证和实现,了解了对运算器进行优化的思路、方向,观察了乘法的结果,本次实验收获巨大。

六.操作注意事项

1. 实验箱上电后,等待设备就绪,端口会自动连接,如果初始化失败,按实验箱上的“复位”按钮。
2. 设备就绪后,进行登录。按学号、密码登录成功后,如果没有实验计划,请按“复位”,设置好端口后,重新登录。
3. 编辑实验报告单时,避免从word直接复制粘贴带有格式的文本,可以把答案保存在记事本txt上,进行复制粘贴,或者在报告编辑区手动输入。
4. 关于实验报告单中需要上传图片的题目,请准备低像素的图片,如果上传不成功,先完成其他内容,下次进行编辑。
5. 优先完成实验内容,如时序图上传、运算表格的编辑。实验报告可以后续从登录界面左上角功能中“查看历史实验报告”中进行编辑。

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

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

相关文章

ChatGPT 究竟在做什么?它为何能做到这些?(2)

机器学习和神经网络的训练 到目前为止,我们一直在讨论那些 “已经知道” 如何完成特定任务的神经网络。但是,神经网络之所以如此有用(估计也是在大脑中),是因为它们不仅是可以完成各种任务,而且可以逐步 “…

数据 数据元素 数据项 数据对象

文章目录数据、数据元素、数据项和数据对象数据数据元素数据对象数据元素和数据对象数据结构数据结构包括以下三个方面的内容逻辑结构物理结构(存储结构)逻辑结构与存储结构的关系逻辑结构的种类集合结构线性结构树型结构图状结构或网状结构四种基本的存…

【人工智能】模糊推理

模糊推理:以下内容都是我自学理解的&#xff0c;不保证对引言&#xff1a;“生活中的模糊关系”模糊集合模糊集合的定义模糊集合的表示法模糊集合表示法示例隶属函数模糊规则模糊计算的流程引言&#xff1a;“生活中的模糊关系” 如果说&#xff0c;我们简单的将 温度<10度 …

如何构建敏捷项目管理团队?

敏捷专家认为&#xff1a;团队合作对于交付出色软件来说非常关键&#xff0c;而在优秀的敏捷团队普遍都是站在集体的角度去思考和工作&#xff0c;而不是以个体的形式。对每个成员来说更有价值的是——优秀的成员都会站在团队的角度将自己宝贵的开发经验分享出来&#xff0c;来…

mysql(beetlsql框架)适配人大金仓(KingBase)有感

毁灭吧&#xff0c;前几天加班适配kingbase&#xff0c;发现坑是真滴多&#xff0c;小小总结一波。 tips:kingbase的语法可以直接参照pgsql...他们两个是通用的&#xff08;应该&#xff09; 1. 的坑 在Mysql里面的 (不是单引号&#xff01; 和 还是有点区别的) 这是拿来…

机械臂路径规划path planning

一、路径规划&#xff1a;假设机械臂的终端结构要从一个点运动到另一个点&#xff0c;我们要求所有的关节和终端机构在运动的过程中都不能碰到障碍物&#xff0c;这个称为路径规划。 1、路径规划算法主要可分成两种&#xff1a; &#xff08;1&#xff09;一种是基于搜索结果…

第十三天缓存一致性篇

目录 一、缓存的应用场景 二、缓存数据一致性如何保证&#xff1f; 三、缓存的最终一致性解决方案&#xff1a; 一、缓存的应用场景 1、缓存中的数据不应该是实时性一致性要求超高的&#xff0c; 通过缓存加上过期时间保证每天拿到的数据都是最新的即可。 2、如果实时性要求…

tcp通信,客户端服务端

进行过程 //TCP通信的流程 //服务器端&#xff08;被动接受连接的角色&#xff09; 1.创建一个用于监听的套接字 -监听&#xff1a;监听有客户端的连接 -套接字&#xff1a;这个套接字其实就是一个文件描述符 2.将这个监听文件描述符和本地的IP和端口绑定&#xff08;IP和端口…

飞凌嵌入式AM62x核心板,赋能新一代HMI

HMI&#xff08;人机界面&#xff09;是系统和用户之间进行交互和信息交换的媒介&#xff0c;凡是涉及人机信息交流的领域都离不开人机界面&#xff0c;因此在许多行业内都能见到HMI的身影。随着技术的进步HMI也在持续发展和演进&#xff0c;除了数据收集、控制和显示外&#x…

在采购过程中保持供应商诚实的5种方法

不信任潜在供应商的心理在B2B买家中很常见。据报告称&#xff0c;供应商和买家之间存在着信任差距。这不是针对个人&#xff0c;而是健康的怀疑态度。谁不会对他们企业的潜在六七位数技术投资持怀疑态度&#xff1f; 企业和其供应商之间的关系通常是决定成败的关键。为此&…

SQL 条件函数 日期函数 文本函数 窗口函数

玩了几天&#xff0c;劳逸结合&#xff0c;继续复习刷题sql 一、条件函数 1.题目&#xff1a;现在运营想要将用户划分为25岁以下和25岁及以上两个年龄段&#xff0c;分别查看这两个年龄段用户数量&#xff08;age为null 也记为 25岁以下&#xff09; user_profile 期望结果&…

【论文阅读】MAMIL

1、基本信息 misc{Konstantinov_Utkin, title{Multi-Attention Multiple Instance Learning}, author{Konstantinov, AndreiV. and Utkin, LevV.} }2、摘要 本文提出了基于多注意力的MIL问题求解方法&#xff0c;该方法考虑了包中每个被分析实例的相邻实例。在该方法中&…

如何还原min.js文件

最近在看别人给的一个代码包&#xff0c;但是有一些文件是 xx.min.js ,这种文件在vscode中打开后是这样的 这种怎么阅读&#xff0c;太难了&#xff0c;于是全选&#xff0c;右键格式化文档&#xff0c;不管用 通过咨询群友&#xff0c;学到了&#xff1a; 回答一&#xff1…

vscode开发常用的工具栏选项,查看源码技巧以及【vscode常用的快捷键】

一、开发常用的工具栏选项 1、当前打开的文件快速在左侧资源树中定位&#xff1a; 其实打开了当前的文件已经有在左侧资源树木定位了&#xff0c;只是颜色比较浅 2、打开太多文件的时候&#xff0c;可以关闭 3、设置查看当前类或文件的结构 OUTLINE 相当于idea 查看当前类或接…

【计算机网络-数据链路层】流量控制与可靠传输机制

文章目录1 停止-等待协议1.1 无差错情况1.2 有差错情况——数据帧出错或丢失1.3 有差错情况——ACK 丢失1.4 有差错情况——ACK 迟到1.5 性能分析1.6 相关例题2 后退 N 帧协议&#xff08;GBN&#xff09;2.1 无差错情况2.2 超时重传、回退 N 帧2.3 相关例题3 选择重传协议&…

AX7A200教程(6): 串口接收图片数据,通过hdmi接口输出显示

本章节主要使用uart接收图片数据&#xff0c;然后通过ddr3缓存&#xff0c;最后通过hdmi接口显示输出&#xff0c;功能框图如下图所示 uart接收的图片数据位1024*768*3分辨率大小的数据&#xff0c;一共2359296个字节&#xff0c;输入图片如下图所示 图片属性 串口接收数据&…

基于matlab分析卫星星座对通信链路的干扰

一、前言此示例说明如何分析从中地球轨道 &#xff08;MEO&#xff09; 中的卫星星座到位于太平洋的地面站的下行链路上的干扰。干扰星座由低地球轨道&#xff08;LEO&#xff09;的40颗卫星组成。此示例确定下行链路闭合的时间、载波噪声加干扰比以及链路裕量。此示例需要卫星…

锚框+ssd v2 整合笔记

13.4. 锚框 — 动手学深度学习 2.0.0 documentation 13.7. 单发多框检测&#xff08;SSD&#xff09; — 动手学深度学习 2.0.0 documentation 锚框 一.归一化推导公式 目标检测SSD | Lee的个人博客 之前笔记有点错误 https://mp.csdn.net/mp_blog/creation/editor/129528…

输入电阻、输出电阻、特性阻抗、阻抗匹配

一、输入阻抗和输出阻抗 1.输入阻抗 输入阻抗&#xff08;input impedance)是指一个电路输入端的等效阻抗。在输入端上加上一个电压源U&#xff0c;测量输入端的电流I&#xff0c;则输入阻抗Rin就是U/I。你可以把输入端想象成一个电阻的两端&#xff0c;这个电阻的阻值&#…

云原生助力数字原生企业业务快速迭代|阿里云峰会精彩回顾

导语&#xff1a; 4月11日&#xff0c;2023 阿里云峰会如期举行。一直以来&#xff0c;阿里云都积极融入企业数字原生创新发展的新浪潮&#xff0c;是中小企业走向数字原生坚实的支持者。阿里云坚持以数据和智能驱动&#xff0c;与合作伙伴、企业客户一起专注于技术创新&#x…