欢迎来到天天文库
浏览记录
ID:35241796
大小:357.00 KB
页数:8页
时间:2019-03-22
《eda大作业quartusii简易计算器实验报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、实验报告——简易计算器目录:一、实验目的1二、实验任务1三、电路设计及仿真11.结构设计图示如下:22.设计描述23.一位全加器:24.四位全加器:25.补码器36.四位加减器47.八位全加器58.乘法器59.整体电路:6四、实验总结71.实验收获:82.实验中出现的问题及解决:8一、实验目的1.学习面向可编程器件(FPGA)的简单数字系统的设计流程。2.熟练掌握EDA设计软件QuartusII的原理图输入方式和层次化设计模式。3.熟悉实验装置——实验箱。二、实验任务1.设计1位全加器,并将其封装成1位全加器模块,仿真验证运算结果;2
2、.设计4位加/减运算器。用封装好的1位全加器模块组成成4位加/减运算器。仿真验证运算结果;3.以全加器为基础设计一个4位乘法器并封装成乘法器模块,输出显示乘积和正负数标志。仿真验证运算结果;4.使用已生成的器件模块为基础设计一个简易计算器,根据控制端的状态,完成加、减、乘法运算,用十进制显示运算结果;用发光二极管显示负数标志。仿真验证运算结果;即实现如下设计:一、电路设计及仿真1.结构设计图示如下:2.设计描述① 利用门电路组合成1位全加器,封装;② 调用1位全加器组合4位全加器和4位补码全加器(实现补码和相加),分别封装;③ 利用门
3、电路实现补码器,封装;(可改进——使用4位全加器实现,见下);④ 调用4位补码全加器和补码器实现4位加减器;⑤ 调用4位全加器实现8位全加器,封装;⑥ 调用8位全加器实现乘法器;⑦ 译码(二进制码——BCD码);⑧ 组合4位加减器和乘法器成简易计算器;3.一位全加器:① 利用门电路组合而成4位全加器;电路图如下:② 将其封装成1位全加器模块。4.四位全加器:① 利用1位全加器模块搭建4位补码全加器(实现补码后相加),电路如下:① 将其封装成4位补码全加器模块。② 仿真波形:1.补码器① 根据真值表可得如下表达式:;其中K,CO,S3,
4、S2,S1,S0的含义由四位补码全加器表明;F表示结果的符号;H,R3,R2,R1,R0依次表示运算结果的从高到低位;R3,R2,R1,R0具有高度对称性;② 利用门电路组合而成4位补码器,电路图如下:① 将其封装成4位补码器模块。② 改进说明:直接根据由得到的符号位,用类似运算前求补码的方式求结果的补码;即令原先A3,A2,A1,A0输入端都等于0,将S3,S2,S1,S0接入原先B3,B2,B1,B0输入端;F(由得到)接入原先K输入端;便可通过4位全加器实现求补码运算。即得到如下电路(求补码时取CO输出端接运算结果的最高位H):
5、1.四位加减器① 调用4位补码全加器和4位补码器实现4位加减器,电路如下:1.八位全加器① 用4位全加器实现8位全加器,电路如下:② 将其封装成8位全加器模块,供乘法器使用。2.乘法器① 根据错位相加法原理利用8位全加器模块组合而成乘法器,电路如下:① 将其封装成乘法器模块,供简易计算器调用。② 仿真波形:1.整体电路:① 将4位加减器和乘法器组合起来,根据控制端的状态,完成加、减、乘法运算;② 将模块电路输出的二进制码转换为BCD码输出;整体电路如下:① 功能仿真波形:② 时序仿真波形:一、实验总结1.实验收获:① 通过在Quart
6、usII上用门电路搭建和组合原理图并实现封装调用,掌握了层次化的设计模式和由小到大、由简单到复杂的设计流程;② 掌握了引脚锁定,功能下载的方法,熟悉了实验装置——实验箱的操作方法,并能通过开关、按键输入,数码管、二极管输出来验证简易计算器的运算结果是否正确。2.实验中出现的问题及解决:① 首先遇到的问题是封装后调用出错的问题,即在新建的工程文件中新建原理图,调用之前封装的模块,但编译不能通过。但将工程放在同一文件夹下即可避免此问题。出错原因是封装后的模块的原理图不再当前文件夹下。最后采用将封装模块和原理图文件都拷贝到需要此模块的文件夹
7、下,在新建工程时添加.bdf文件即可。② 实现4位加减运算器时借鉴组合电路设计实验中2位加减运算器的设计方法。但需要考虑到最后将补码转换为原码的方法。方法a采用门单路实现,较复杂;方法b仿照运算前取补码的方式,将补码相加后的结果和符号类比输入的加数和符号,同时被加数位全部置0,即可实现求补码运算。③ 由于忽视实验指导中的要求,最后将二进制码转化为BCD码。故开始没有转化,在实验中只能得到10以下的正确结果。最后利用74185及其组合电路将运算器输出的结果转化为BCD码,再接到数码管上,便能得到正确结果。④ 时序仿真时,由于设置的波形不
8、合理,造成输出波形不断跳变而无法判断输出结果的问题原因是由于传输延时时间和周期同等数量级大小,致使输出尚未稳定时输入即发生变化,故输出不断跳变。最后将周期扩大为传输延迟时间的20倍左右,输出就能够保持一定的稳定时间,便可
此文档下载收益归作者所有