EDA技术及应用朱正伟课后习题答案.docx

上传人:叶*** 文档编号:34913847 上传时间:2022-08-19 格式:DOCX 页数:6 大小:20.54KB
返回 下载 相关 举报
EDA技术及应用朱正伟课后习题答案.docx_第1页
第1页 / 共6页
EDA技术及应用朱正伟课后习题答案.docx_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《EDA技术及应用朱正伟课后习题答案.docx》由会员分享,可在线阅读,更多相关《EDA技术及应用朱正伟课后习题答案.docx(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、第五章1.试说明实体端口形式BUFFER与INOUT的不同之处?2.VHDL的数据对象有哪几种?它们之间有什么不同?3.说明以下各定义的意义: SIGNAL a , b , c : BIT : =0; CONSTANT TIME1 , TIME2 : TIME : 20ns ;VARIABLE x , y , z : STD_LOGIC :=x;4.什么是重载函数?重载运算符有何用途?如何调用重载运算符函数?5.数据类型BIT INTEGER BOOLEAN分别定义在哪个库中?哪些库与程序包总是可见的?6.函数与过程有什么区分?7.假设在进程中参与WAIT语句,应留意哪几个方面的问题?8.哪些

2、状况下需用到程序包STD_LOGIC_UNSIGNED试举一例。9.为什么说一条并行赋值语句可以等效为一个进程?假设是这样的话,怎样实现敏感信号的检测?10.比较CASE语句与WITH_SELECT语句,表达它们的异同点?11.将以下程序段转换为WHEN_ELSE语句: PROCESS (a , b ,c ,d) BEGIN IF a=0AND b=1THEN NEXT1 =1101; ELSEIF a=0THEN NEXT1 =d; ELSEIF b=1THEN NEXT1 =c; ELSE NEXT1 =1011; END IF; END PROCESS;12.试用并行信号赋值语句分别描绘

3、以下器件的功能:(1) 3-8译码器(2) 8选1数据选择器13.利用生成语句描绘一个由几个一位全加器构成n位加法器(n的默认值为4)。14.用VHDL设计输出占空比为50%的1000分频器。参考答案1. 答: BUFFER端口:缓冲形式,具有读功能的输出形式,即信号输出到实体外部,但同时也在内部反响运用,不允许作为双向端口运用。而INOUT端口:双向形式,即信号的流通是双向的,既可以对此端口赋值,也可以通过此端口读入数据。2.答:VHDL的数据对象有三种:信号、变量、常量。 它们之间的的区分如下:信号赋值至少有延时,而变量与常量没有;信号除当前值外,有很多相关信息,变量只有当前值,常量的值在

4、设计实体中始终不变;进程对信号敏感而对变量及常量不敏感;信号可以是多个进程的全局信号,变量只在定义它们的依次域可见,而常量的运用范围取决于它被定义的位置;信号是硬件连线的抽象描绘信号赋值,赋值符号 = 而变量与常量的赋值符号 :=。3.答:定义3个位数据类型的信号a、b、c,它们取值为0; 定义2个时间数据类型的常量TIME1、TIME2,它们值为20ns; 定义3个标准逻辑位 STD_LOGIC数据类型的变量x、y、z,它们的值是强未知的。 4.答:为了便利各种不同数据类型间的运算,VHDL允许用户对原有的根本操作符重新定义,赐予新的含义与功能,从而建立一种新的操作符,这就是重载操作符,定义

5、这种操作符的函数成为重载函数。重载运算符的作用是为了便利各种不同的数据类型间的运算。要调用重载运算符函数,先要在程序包中进展函数体的定义,调用的格式如下 : x =函数名参数1,参数2, 参数个数与类型与所定义的函数要保持一样。5.答:数据类型BIT INTEGER BOOLEAN均定义在STD库中。IEEE库与程序包 、STD_LOGIC_UNSIGNED、STD_LOGIC_SIGNED、STD_LOGIC_ARITH等总是可见的。 6.答:子程序有两种类型,即过程PROCEDURE)与函数FUNCTION)。它们的区分在于:过程的调用可以通过其界面获得多个返回值,而函数只能返回一个值;在

6、函数入口中,全部参数都是输入参数,而过程有输入参数、输出参数与双向参数;过程一般被看作一种语句构造,而函数通常是表达式的一部分;过程可以单独存在,而函数通常作为语句的一部分调用。 7.答:应留意以下问题:已列出敏感信号的进程中不能运用任何形式的WAIT语句;一般状况下,只有WAIT UNTIL格式的等待语句可以被综合器所承受,其余语句格式只能在VHDL仿真器中运用;在运用WAIT ON语句的进程中,敏感信号量应写在进程中的WAIT ON语句后面;在不运用WAIT ON语句的进程中,敏感信号量应在开头的关键词PROCESS后面的敏感信号表中列出。8.答:调用数据类型变换函数或重载运算符函数时;定

7、义UNSIGNED类型的数据时。举例如下: LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; UNSIGNED.ALL; IF temp=THEN temp:= ; ELSE temp:=temp+16;END IF;9答:因为信号赋值语句的共同点是赋值目的必需都是信号,全部赋值语句与其它并行语句一样,在构造体内的执行是同时发生的,与它们的书写依次没有关系,所以每一信号赋值语句都相当于一条缩写的进程语句。由于这条语句的全部输入信号都被隐性地列入此缩写进程的敏感信号表中,故任何信号的变更都将相关并行语句的赋值操作,这样就实现了敏感信号的检测。 :一样点:CAS

8、E语句中各子句的条件不能有重叠,必需包涵全部的条件;WITH_SECLECT语句也不允许选择值有重叠现象,也不允许选择值涵盖不全的状况。另外,两者对子句各选择值的测试都具有同步性,都依靠于敏感信号的变更。不同点:CASE语句只能在进程中运用,至少包含一个条件语句,可以有多个赋值目的;WITH_SECLECT语句依据满意的条件,对信号进展赋值,其赋值目的只有一个,且必需是信号。11.原程序转换如下: ARCHITECTURE one OF mux IS BEGIN PROCESS (a , b ,c ,d) BEGIN NEXT1 =1101WHEN a=0AND b=1ELSE d WHEN

9、a=0ELSE c WHEN b=1ELSE 1011; END one; END PROCESS;12.1功能描绘如下: LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; ENTITY decoder38 IS PORT(a,b,c,g1,g1a,a2b:IN STD_LOGIC; q:OUT STD_LOGIC_VECTOR(7 DOWNTO 0); END decoder38; ARCHITECTURE behave38 OF decoder38 IS SIGNAL inda: STD_LOGIC_VECTOR(2 DOWNTO 0); BEGIN i

10、ndaqqqqqqqqq=XXXXXXXX; END CASE; ELSE q=11111111; END IF; END PROCESS;END behave38; 2功能描绘如下: LIBRARY IEEE; USE IEEE.STD_LOGIC_1164.ALL; ENTITY mux8 IS PORT(d0,d1,d2,d3,d4,d5,d6,d7:IN STD_LOGIC_VECTOR(7 DOWNTO 0); s0,s1,s2:IN STD_LOGIC; q:OUT STD_LOGIC_VECTOR(7 DOWNTO 0); END mux8;ARCHITECTURE behave OF mux8 IS SIGNAL s: STD_LOGIC_VECTOR(2 DOWNTO 0);BEGIN s =s2&s1&s0; WITH s SECLECT d =d0 WHEN 000, d1 WHEN 001, d2 WHEN 010, d3 WHEN 011, d4 WHEN 100, d5 WHEN 101, d6 WHEN 110, d7 WHEN 111, XWHEN OTHERS;END behave;13.用生成语句描绘如下:第 6 页

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 初中资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁