《VHDL第1讲盛建伦老师课件.ppt》由会员分享,可在线阅读,更多相关《VHDL第1讲盛建伦老师课件.ppt(68页珍藏版)》请在三一办公上搜索。
1、盛建伦,1,数 字 逻 辑,Digital Logic,青岛理工大学,广义双语教学课程,盛建伦,2,习题参考答案,1-24,(5),盛建伦,3,习题参考答案,1-13,(2),(3),1-15,(1),(2),盛建伦,4,硬件描述语言VHDL基础,第3章,Very High speed Integrated Circuit Hardware Description Language,VHDL(非常高速集成电路硬件描述语言)是由美国国防部支持的一项研究计划,于1983年创建,目的是以文字化方法描述电子电路与系统。1987年,VHDL成为IEEE标准,即IEEE1076标准,1993年修改为IEE
2、E1164标准,1996年,IEEE又将电路合成的标准程序与规格加入到VHDL语言中,称为1076.3标准。之后,又有1076.4标准和1076.6标准。,盛建伦,5,VHDL程序设计基本结构,VHDL用语言的方式而非图形等方式描述硬件电路,容易修改,容易保存。特别适合于设计组合逻辑电路和状态机:译码器、编码器、加法器、多路选择器、地址译码器、.,盛建伦,6,VHDL程序基本结构,VHDL程序通常包含实体(Entity),结构体(Architecture),配置(Configuration),包集合(Package),和库(Library)五部分。,库是专门存放预编译程序包的地方。,其中实体用
3、于描述所设计的系统的外部接口信号;,配置语句安装具体元件到实体结构体对,可以被看作是设计的零件清单;,结构体用于描述系统内部的结构和行为;建立输入和输出之间的关系;,包集合存放各个设计模块共享的数据类型、常数和子程序等;,盛建伦,7,VHDL主要用于描述设计系统的结构、行为、功能和接口。,器件 或子系统 ARCHITECTURE Process Process Sequential Process Combinational Process component Ports,它将一个设计(元件、电路、系统)分为:,外部(可视部分、端口),内部(不可视部分、内部功能、算法)。,Very High
4、speed Integrated Circuit Hardware Description Language,盛建伦,8,一、信号(signal)的含义和信号的两种最常用类型:std_logic 和 std_logic_vector,VHDL入门需掌握的基本知识,二、四种常用语句的基本用法赋值语句、if语句、case语句 和 process语句,三、实体(entity)、结构体(architecture)以及 一个实体和一个结构体组成的设计实体。,四、层次结构的设计 掌握元件(component)语句和端口映射(port map)语句。,五、库(library)和程序包(package)的基本
5、使用。,有了以上入门知识,就能做一般的设计了。,盛建伦,9,库(library)和程序包(package),库(Library)用于存放预先编译好的程序包(Package),,作用:,程序包中定义了数据集合体、逻辑操作和元件等。主要是声明在设计或实体中将用到的常数,数据类型,元件及子程序等。,任何一种设计都要充分利用前人已有的成果,公用的资源要尽可能使用;自己已经设计好的资源也要尽量利用起来,程序包(package)和库(library)就是一些可以公用的资源,是设计实体的一个重要组成部分。,盛建伦,10,库(library),设计库对当前设计是可见的,默认的,无需用library子句和use
6、子句说明的库。,VHDL语言的库分为两种,一种是设计库,一种是资源库。,库是用来放置可编译的设计单元的地方。VHDL中的常用库有:STD库、WORK库、IEEE库和用户定义库。,Std 和 work 这两个库是设计库。,盛建伦,11,VHDL的标准库。库中存放有称为“standard”的标准包集合,其中定义了多种常用的数据类型,均不加说明可直接引用。,库(library),STD库,常用的资源库。IEEE库包含经过IEEE正式认可的STD_LOGIC_1164包集合和某些公司提供的一些包集合,如STD_LOGIC_ARITH(算术运算库)、STD_LOGIC_UNSIGNED等。,WORK库是
7、现行作业库。设计者所描述的VHDL语句不需要任何说明,都将存放在WORK库中。WORK库对所有设计都是隐含的,因此在使用该库时无需进行任何说明。,IEEE库,WORK库,盛建伦,12,库(library),用户定义库,用户定义库简称用户库,是由用户自己创建并定义的库。,除了IEEE标准资源库外,各可编程器件厂家的EDA软件提供自己独特的资源程序包。由于这些程序包是为它们制造的器件服务的,往往更有针对性。,设计者可以把自己经常使用的非标准(一般是自己开发的)包集合和实体等汇集在一起定义成一个库,作为对VHDL标准库的补充。,用户定义库在使用时同样要首先进行说明。,Qartus 中提供了一个LPM
8、库,库中有许多称之为 MegaFunctions的功能强大的函数。,盛建伦,13,库(library),除了STD库和WORK库之外的其它库均为资源库。,使用资源库中的元件和函数之前,需要使用library子句和use子句予以说明。,没有说明的库中的元件不能使用。,library子句和use子句总是放在设计实体的最前面(可以放在注释之后)。,如果一个设计实体中使用了某个库中的元件和函数,就要使用相应的library子句和use子句。,library子句的作用是使该库在当前文件中“可见”。,盛建伦,14,library子句说明使用哪个库,它的格式是 library 库名1,库名2,库名n;,库(
9、library),std库和work库是设计库,在任何设计文件中隐含都是“不可见”的,不需要特别说明。也就是说,每一个设计文件中总是隐含下列不可见的行:library std,work;use std.standard.all;,use子句说明使用哪个库中的哪个程序包中的元件或者函数。它的格式是:use 库名.程序包名.all;,这些是不用在程序里写的,盛建伦,15,程序包(package),程序包是一种使包体中的类型、常量、元件和函数对其他模块(文件)是可见、可以调用的设计单元。,程序包是公用的存储区,在程序包内说明的数据,可以被其它设计实体使用。程序包由包头和包体两部分组成。,盛建伦,16
10、,VHDL语言要素,盛建伦,17,VHDL数据对象,数据对象(Data Objects):,凡是可以被赋予一个值的对象称为数据对象,数据对象用于传递信号。,例:,数据对象值的类型,数据对象类型,数据对象名,盛建伦,18,信号和变量,信号(signal),变量(variable),是硬件中物理连线的抽象描述,信号在元件的端口连接元件以及在元件内部各部分之间的连接。,在硬件中没有类似的对应关系,它们主要用于保存中间结果。例如作为数组的下标。,常量代表数字电路中的电源、地、恒定逻辑值等常数。,常量(Constant),盛建伦,19,信号在逻辑电路设计中最常用的数据类型,在VHDL语言中有10种数据类
11、型,但是在逻辑电路设计中最常用的是std_logic和std_logic_vector提供的数据类型。,std_logic类型分为布尔(boolean)型、位(bit)型、位矢量(bit_vector)型。,std_logic有9种状态,常用的是三种状态:,1 高电平0 低电平z高阻,高阻状态是为了双向总线的描述,盛建伦,20,信号说明,一个信号只有经过说明后才能使用。用VHDL语言进行设计就是写一系列语句。信号说明形式如下:,一个语句用分号结束。,Signal clock,T1,T2:std_logic;,Signal 信号名:数据类型:=设定值;,Signal A:Std_logic_ve
12、ctor(3 Down to 0):=“0000”;,例如:,Signal r0,r1,r2,r3:std_logic_vector(15 downto 0);,Signal r0,r1,r2,r3:std_logic_vector(0 upto 15);,设定值,可选项,盛建伦,21,(1)说明位置不同,信号通常在实体、结构体和程序包中说明,变量一般在进程、过程和函数语句中说明;,信号与变量的区别,(2)赋值运算符不同,信号用“=”符号进行赋值,变量用“:=”符号赋值;,(3)延迟不同,信号的赋值存在延迟,变量的赋值是直接的,没有任何延迟时间。,从信号说明看不出一个信号是组合逻辑还是时序逻辑
13、(例如寄存器),这与ABEL语言是不同的。,盛建伦,22,VHDL 操作符,VHDL操作符:,逻辑操作符,算术操作符,符号操作符,关系操作符,盛建伦,23,逻辑运算符,-signal a,b:std_logic;-signal c,d:std_logic_vector(7 downto 0);,有7种逻辑运算符:,NOT、OR、AND、NAND、NOR、XOR、XNOR。,说明:-是注释开始的标志,这些signal语句的存在只是为了说明这些信号的类型,供阅读方便使用。,两个进行逻辑运算的信号,类型必须相同。例如,a and b a or b not a,正确,c and d c xor d n
14、ot c,正确,a and c,错误,常用的为前三种。,盛建伦,24,不等于(a and b)or(c and d),逻辑运算符,例如:,a and b or c and d,等于(a and b)or c)and d,这些逻辑运算符,not优先级最高,其他的优先级相同。因此运算时按由左到右的顺序展开。运算时要注意加括号。,NOT、OR、AND、NAND、NOR、XOR、XNOR。,能进行逻辑运算的数据类型:bit、bit_vector、boolean,std_logic、std_logic_vector,盛建伦,25,Signal a,b,c,d:std_logic_vector(3 dow
15、nto 0);,Signal e,f,g,h:std_logic_vector(1 downto 0);,d=a and b and c;,d=a or b or c;,d=a xnor b xnor c;,h=e nor f nor g;,h=(e nor f)nor g;,d=(e nor f)nor g;,例,盛建伦,26,算术运算符,a+ba+1,常用的算术运算符有:+-,-USE ieee.Std_logic_arith.ALL;-signal a,b:std_logic_vector(15 downto 0);,字符串必须用双引号括起来,字符类型通常用单引号括起来,字符类型区分大小
16、写,,a+01,求和运算符、求积运算符、符号运算符、混合运算符、移位运算符,VHDL中的求和运算符包括加减运算和并置运算,操作数的数据类型为整型。,例,VHDL语句不区分大小写,盛建伦,27,并置运算符&,-signal a,b:std_logic_vector(3 downto 0);-signal c,d:std_logic_vector(2 downto 0);a and(1&c)c&a,并置运算符用于位的连接,形成矢量。也可连接矢量形成更大的矢量。,例如:,盛建伦,28,Signal a:std_logic_vector(4 downto 0);,Signal b:std_logic_
17、vector(2 downto 0);,Signal c:std_logic_vector(1 downto 0);,b c,a=b c,例:,并置运算符&,并置运算符用于位的连接,形成矢量。也可连接矢量形成更大的矢量。,盛建伦,29,关系运算符,=等于/=不等于 大于=大于等于,关系运算符有下列几种:,关系运算的结果为“真”(true)或者“假”(false)。,=、/=在实现硬件电路时比其它的关系运算符对芯片的利用率要高,等于、不等于运算符适用于所有的数据类型,其他的运算符适用于整数、位及矢量等。在进行关系运算时,两边的数据类型必须相同,但位长度可以不同。,盛建伦,30,VHDL顺序语句,
18、顺序语句的特点是,每一条顺序语句的执行顺序是与它们的书写顺序基本一致的。顺序语句只能出现在进程(Process)和子程序中,子程序包括函数(Function)和过程(Procedure)。,顺序语句的种类:,进程语句赋值语句 流程控制语句 等待语句,子程序调用语句 返回语句 空操作语句,盛建伦,31,常用的4种语句,VHDL有许多类型的语句,入门只需掌握4种语句:,赋值语句,if语句,case语句 和 process语句。,盛建伦,32,赋值语句,-signal a,b,c:std_logic;-signal d,e,q:std_logic_vector(3 downto 0);,=是信号赋值
19、符,=左右两边数据类型必须相同,数据长度必须相同。,1、信号赋值语句,由于信号是物理量,因此赋值有延迟时间。如第二个语句就是一个或门,因此,信号d”或“q后到e有延迟时间。,信号赋值语句的语法格式为:目标信号名=表达式(设定值);,c=not(a and b);e=d or q;,盛建伦,33,-variable x,y,z:integer range 0 to 255;x:=0;y:=132;z:=x;,赋值语句,2、变量赋值语句,:=是变量赋值符。:=左右两边的数据类型必须相同。由于变量没有相对应的明确的物理量,因此变量赋值没有时间延迟。,盛建伦,34,3.并行赋值语句,(1)条件赋值语句
20、,格式:,目标信号=表达式1 WHEN 条件1 ELSE,表达式2 WHEN 条件2 ELSE,表达式N-1 WHEN 条件N-1 ELSE,表达式N;,盛建伦,35,并行赋值语句,(2)选择赋值语句,格式:,目标信号=信号表达式1 WHEN 选择条件1,,信号表达式2 WHEN 选择条件2,,WITH 选择条件表达式 SELECT,信号表达式N WHEN 选择条件N;,盛建伦,36,if 语句,if语句的三种形式:,1、门闩if语句,2、二选一if语句,3、多选一if语句,流程控制语句,语法格式:If expression Then statement;Elsif expression Th
21、en statement;Elsif Then statement;else statement;End if;,根据条件进行相应赋值操作,注意:不是Else if,盛建伦,37,1、门闩if语句,IF 条件 THEN 若干语句END IF,例,语句格式,IF(a b)THEN out=1;END IF;,第一种IF语句,这种if语句往往用于产生触发器和锁存器。,盛建伦,38,第二种IF语句,IF 条件 THEN 若干语句ELSE 若干语句END IF,语句格式,IF(a b)THEN out=1;ELSEout=0;END IF;,2、二选一if语句,例,盛建伦,39,例:一个8位二选一选择
22、器,用于二选一控制的if语句,-signal sel:std_logic;-signal a,b,c:std_logic_vector(7 downto 0);,if sel=1 then c=a;else c=b;end if;,盛建伦,40,第三种IF语句,If 条件1 Then 若干语句;Elsif 条件2 Then 若干语句;else 条件n Then 若干语句;End if;,语句格式,3、多选一if语句,盛建伦,41,例:,Process(A)BeginIf A=”00”then f=D0;elsif A=”01”then f=D1;elsif A=”10”then f=D2;el
23、se f=D3;end if;end process;,多选一if语句,盛建伦,42,process 语句,process语句通常称为进程语句,本质上它描述了一个功能独立的电路块。,在VHDL语言中,所有的并行执行语句都代表功能独立的电路块,而所有顺序执行语句则是用于描述电路块的功能。,process语句有许多变种,这里只介绍最基本的形式。,流程控制语句,process语句是个并行执行的语句,但是process语句内部的语句要求是顺序执行语句。它是VHDL程序中,描述硬件并行工作的最重要最常用的语句。,43,Process语句的书写格式是:进程名:process(敏感信号1,敏感信号 2,敏感
24、信号n)若干变量说明语句begin若干顺序执行语句end process 进程名;,process 语句,用方括号括起来的部分是可选的,第一个进程名以冒号结束,和关键字process隔开,它是可选的,可要可不要,对硬件电路没有影响。不过我建议最好加上进程名,加上进程名等于给这块功能独立的电路加了个标记,增强可读性。,process语句中,begin之前的若干变量说明语句也是可选的。如果该process语句中需要使用变量,则需要在begin之前予以说明。这些被说明的变量只对该进程语句起作用,只能在该process语句中使用。,敏感信号表,盛建伦,44,process语句中有个敏感信号表,各敏感信
25、号之间用逗号分开。最后一个敏感信号后面是括号,不需要跟一个逗号。,process 语句,所谓敏感信号就是指当它的状态发生变化时,启动process语句执行。由于process语句代表一块功能独立的电路,它的某些输入信号的状态变化,势必引起电路输出的变化,这些立即引起(当然要经过短暂的时间延迟)输出信号状态变化的信号就是敏感信号。,变量不是真正的物理量,因此不能出现在敏感信号表中。在process语句中只作为输出存在的信号(出现在信号赋值符“=”的左边),不能作为敏感信号。,既出现在信号赋值符“=”的左边,又出现在信号赋值符“=”右边的信号,可以出现在敏感信号表中,这是因为这些信号既作为这块电路
26、的输出,又是电路内部的反馈信号。,盛建伦,45,在process语句的书写格式中,在 begin 和 end process 之间的若干顺序执行语句用于描述该process语句所代表的电路块的功能。,process 语句,在前面介绍if语句时,用if语句描述了二选一选择器和多选一选择器。,但是由于if语句是顺序执行语句,因此不能代表一块功能独立的电路,只能成为一块功能独立电路的一部分。需要对前面的if语句进行改造,使之成为一块功能独立的电路(能并行执行)。,改造的方法之一就是将if语句放在process语句中。,盛建伦,46,-signal sel:std_logic;-signal a,b,
27、c:std_logic_vector(15 downto 0);mux2to1:process(sel,a,b)beginif sel=0 then c=a;else c=b;end if;end process;,process 语句,例:二选一选择器,注意,本例中使用了进程名,不过在end process之后没有书写进程名。,敏感信号表中有3个输入信号,盛建伦,47,case语句,case语句是顺序执行语句,常用来描述总线的行为、编码器和译码器的结构以及状态机等等。case语句可读性好,非常简洁。case语句的书写格式为,流程控制语句,case 条件表达式 is when 条件表达式值1=
28、若干顺序执行语句 when 条件表达式n=若干顺序执行语句 when others=若干顺序执行语句end case;,盛建伦,48,在case语句中,某一个条件表达式满足时,就执行它后面的顺序执行语句。,case语句,if语句的执行是按顺序执行,各条件有不同的优先级;,case语句各条件表达式值之间不存在不同的优先级,它们是同时执行的,即执行的顺序与各条件表达式值的书写顺序无关。,case语句中条件表达式的值须一一列举,不能遗漏;如果不需要一一列举,则用others代替。,case语句和if语句在许多情况下完成的功能是相同的,在这些情况下,用case语句描述比用if语句描述更清晰、更简洁。,
29、盛建伦,49,-signal sel:std_logic_vector(1 downto 0);-signal a,b,c:std_logic;process(a,b,sel)begin sel c c null;end case;end process;,case语句,本例中出现的“null;”是个什么也不做的空语句。,例:2输入与非门,本例中,首先将与非门输入信号a和b并置,生成一个2位的std_logic_vector信号sel。,信号c是与非门的输出。,第一个when 中的“|”代表或者,即三个条件中的任何一个满足,都执行 c=1 语句。,实际上与非门一般不这样设计。常用的设计方法是:
30、c=not(a and b);,盛建伦,50,设计实体,在VHDL的设计中,基本设计单元是设计实体。,实体说明了该设计实体对外的接口;结构体描述了设计实体内部的性能;程序包存放各设计实体能共享的数据类型、常数和子程序等等,库中存放已编译好的实体、结构体、程序包和配置。配置描述了实体与构造体之间的连接关系。,一个设计实体最多由5部分构成:实体(entity),一个或者几个结构体(architecture),使用的库(library)和程序包(pachage),配置(configuration)。,这里仅讨论含有一个结构体的设计实体,绝大多数设计实体都是仅含一个结构体的设计实体。一个实体-结构体“
31、对”共同定义一个电路模型。,盛建伦,51,设计实体,盛建伦,52,实体(entity),实体由实体(entity)语句说明。实体语句又称为实体说明(entity declaration)语句。实体语句的作用是定义设计实体对外的信号。entity语句的书写格式如下:,entity 实体名 is generic(类属参数表);port(端口信号表);实体说明部分;begin实体语句部分;end 实体名;,最常用的形式是:entity 实体名 isport(端口信号表);end 实体名;,盛建伦,53,port(端口)语句的书写格式是:port(端口名,端口名:模式 数据类型;端口名,端口名:模式
32、数据类型;端口名,端口名:模式 数据类型);,实体(entity),实体中的每一个输出/输入被称为一个端口。一个端口实际上是一个信号,因为这些信号负责设计实体与外部的接口,因此称为端口。如果设计实体是一个封装起来的元件,那么端口相当于元件的引脚(pin)。,跟普通信号有两点不同:一是端口一定是信号,因此在说明时省略了关键字signal,二是在说明普通信号的信号说明语句中的信号没有说明方向,端口由于是设计实体与外部的接口,因而是有方向的。,盛建伦,54,例:,实体(entity),port(reset,cs:instd_logic;rd,wr:instd_logic;a1,a0:instd_lo
33、gic;pa,pb:inoutstd_logic_vector(7 downto 0);pcoutstd_logic_vector(15 downto 0);,port(端口)语句的书写格式:port(端口名,端口名:模式 数据类型;端口名,端口名:模式 数据类型);,注意:pc信号一行最后不以分号结束,盛建伦,55,端口的模式用来说明信号通过端口的方向和通过方式,这些方向都是针对该设计实体而言的。例如,in模式对设计实体就是输入。有下列几种模式:,实体(entity),in流入设计实体,输入,out从设计实体流出,输出,inout双向端口,即可输入,又可输出,buffer 缓存,能用于内部反
34、馈的输出,盛建伦,56,out模式和buffer模式的区别在于out端口不能用于设计实体的内部反馈。buffer端口能够用于设计实体的内部反馈。,实体(entity),(a)q1的模式是out,(b)q1的模式是buffer,盛建伦,57,结构体(architecture),结构体描述设计实体内部的特性。结构体的书写格式如下:,architecture 结构体名 of 实体名 is 内部信号,常量,数据类型,函数等的定义;begin 若干并行执行语句 end 结构体名;,实体名一定要与本结构体对应实体的实体名完全一致。architecture后面的结构体名要与end后的结构体名完全一致,而不是
35、与实体名一致。结构体名可以随便起,因为别的地方很少用到结构体名。,结构体内要求使用并行执行语句。,类似if之类的顺序执行语句,只要将它们放在进程语句process语句之内即可。process语句是并行执行语句。,盛建伦,58,前面已经说明了并行语句和顺序执行语句的区别。,结构体(architecture),并行执行语句代表一个独立的功能电路,因此它一定有明确表示或者隐含表示的输入、输出信号,如process语句中敏感信号表中的信号不是输入信号就是反馈信号。,而顺序执行语句只用于描述电路的功能一般很难判断输入输出信号,因此不能代表一个独立的功能电路,例如从一个if语句中判断输入输出信号就比较难。
36、,盛建伦,59,结构体有3种描述方式:行为描述、结构描述和数据流描述。,结构体(architecture),(1)行为描述 描述该设计实体的功能,即该单元能做什么。,(2)结构描述 描述该设计实体的硬件结构,即该设计实体的硬件是如何构成的。,(3)数据流方式 以类似于寄存器传输级的方式描述数据的传输和变换。主要使用并行执行的信号赋值语句,即显式表示了设计实体的行为,也隐式表示了设计实体的结构。,其实初学者不用太钻研各种描述方式的定义,只要能正确描述设计实体的内部特性即可。,盛建伦,60,结构体内部要求使用并行执行的语句,这是十分重要的。每个并行执行语句都是一块独立的电路。,结构体(archit
37、ecture),像与非门这种简单的电路通过信号赋值语句很容易做到,但是像16位寄存器用简单的信号赋值语句就无法实现,因此process语句在结构体内得到了大量的应用。这和电路原理图中是一样的。,在用电路原理图设计的电路中,每块电路也都是并行操作,操作时间也没有先后。所以各process语句之间都是并行执行的。,盛建伦,61,在用原理图描述的电路中,各块电路之间使用信号线互相联系。在VHDL语言中,各process语句、各并行执行语句之间同样是通过信号互相联系(或者称之为通信)的。,结构体(architecture),无论用电路原理图的方式设计电路,还是用VHDL语言设计电路,组合逻辑电路中的各
38、个信号,如果不考虑信号传输延迟时间,是没有时间先后的;时序电路中的各信号是通过时钟信号来同步,并且决定时间先后顺序的。,由于结构体中的各并行执行语句都是独立的电路块,因此不允许2个或者2个以上的并行语句对同一个信号赋值。,盛建伦,62,例:,设计一个与门电路,逻辑符号,真值表,盛建伦,63,Library IEEE;Use std.standard.all;Entity and2 isPort(A:in bit;B:in bit;Y:out bit);End and2;,-首先定义输入输出端口名字,模式(Mode),信号类型,-实体定义:,注意最后语句的分号在括号外,盛建伦,64,Archit
39、ecture Nb of and2 is Begin y=1 when a=1 and b=1 else 0;End Nb;,结构体的定义可以有不同的形式:,Architecture Na of and2 is Begin y=0 when a=0 and b=0 else 0 when a=1 and b=0 else 0 when a=0 and b=1 else 1;End Na;,设计一个与门电路,条件赋值语句,行为描述,盛建伦,65,Library IEEE;,USE IEEE.STD_LOGIC_1164.ALL;,ENTITY example IS;,PORT(a,b,c,d:I
40、N STD_LOGIC;,e:out STD_LOGIC);,END example;,ACHITECTURE AA1 OF example IS,BEGIN,e=(a and b)or tmp;,Signal tmp:std_logic;,tmp=c xor d;,END AA1;,例:,并行赋值语句,盛建伦,66,Homework,2.用VHDL设计一个4人表决电路,参加表决者4人,同意为1,不同意为0,同意者过半则表决通过,绿指示灯亮;表决不通过则红指示灯亮。,3.用VHDL设计一个3线-8线译码器。,1.用VHDL设计一个8421BCD码优先编码器。,3-1,2,5,In Page 118,补充题,下次课讲第5章,Chapter 3,盛建伦,67,习题参考答案,1-16 三输入逻辑电路,当输入变量中1的个数比0的个数多时,输出为1,否则为0。,1真值表,2逻辑函数表达式,习题参考答案,1-17 三输入逻辑电路,当输入变量中1的个数为奇数时,输出为1,否则为0。,1真值表,2逻辑函数表达式,3逻辑图,