常用组合逻辑电路设计

合集下载

组合逻辑电路的设计方法

组合逻辑电路的设计方法
组合逻辑电路的 设计方法
一.组合逻辑电路的特点 电路任一时刻的输出状态只决定于该时刻各输 入状态的组合,而与电路的原状态无关。
组合电路就是由门电路组合而成,电路中没有记忆单 元,没有反馈通路。
每一个输出变量是全部或部分 输入变量的函数: L1=f1(A1、A2、…、Ai) L2=f2(A1、A2、…、Ai)
如果,要求用与非门实现该逻辑电路, 就应将表达式转换成与非—与非表达式:
画出逻辑图如图所示。
例2:设计一个电话机信号控制电路。电路有I0(火警)、I1(盗警) 和I2(日常业务)三种输入信号,通过排队电路分别从L0、L1、L2输出,
在同一时间只能有一个信号通过。如果同时有两个以上信号出现时,应 首先接通火警信号,其次为盗警信号,最后是日常业务信号。试按照上 述轻重缓急设计该信号控制电路。要求用集成门电路7400(每片含 4个2输入端与非门)实现。
3.组合逻辑电路的特点是,电路任一时刻的输出状态只决定于该时 刻各输入状态的组合,而与电路的原状态无关。组合电路就是由 门电路组合而成,电路中没有记忆单元,没有反馈通路。
4.组合逻辑电路的分析步骤为:写出各输出端的逻辑表达式→化简 和变换逻辑表达式→列出真值表→确定功能。
5.组合逻辑电路的设计步骤为:根据设计求列出真值表→写出逻辑 表达式(或填写卡诺图) →逻辑化简和变换→画出逻辑图
…… Lj=fj(A1、A2、…、Ai)
二、设计过程的基本步骤:
例1:设计一个三人表决电路,结果按“少数服从多数”的原则决定。 解:(1)列真值表:
(2)由真值表写出逻辑表达式:
L ABC ABC ABC ABC
(3)化简。
得最简与—或表达式: L AB BC AC
(4)画出逻辑图。

组合电路的设计方法

组合电路的设计方法
输出Y:表决结果,提案通过 “1” ,不通过 “0”
A
B
C
Y
0
0
0
0
0
0
1
0
0
1
0
0
0
1
1
0
1
0
0
0
1
0
1
1
1
1
0
1
1
1
1
1
(2)化简得到最简输出逻辑函数
Y ABC ABC ABC AB AC
(3)画逻辑图
B
&
A.
C
&
>=1
Y
2.多输出组合逻辑电路的设计 [例2]设计一个能完成两个一位二进制数相加的
三.组合逻辑电路设计举例
1.单输出组合逻辑电路的设计 [例1]设计一个A、B、C三人表决电路。
当表决某个提案时,多数人同意,提案通过, 同时A具有否决权。用与非门实现。 解:设计步骤 (1)确定输入输出变量,列写真值表
A 同意 “1”,不同意 “0” ;
输入 B 同意 “1”,不同意 “0” ; C 同意 “1”,不同意 “0” ;
组合逻辑电路-半加器。
解:设计步骤 (1)确定输入输出变量,列写真值表
A,B
两个一位二进制数
S
表示二者之和
C进位ABSC0
0
0
0
0
1
1
0
1
0
1
0
1
1
0
1
(2)化简得到最简输出逻辑函数
S AB AB C AB
(3)画逻辑图
A B
=1
S
&
C
(4)检测此电路,证明逻辑功能符合设计要求

常见的组合逻辑电路

常见的组合逻辑电路

常见的组合逻辑电路一、引言组合逻辑电路是由多个逻辑门组成的电路,它们根据输入信号的不同组合,产生不同的输出信号。

在现代电子技术中,组合逻辑电路被广泛应用于数字电路、计算机系统、通信系统等领域。

本文将介绍几种常见的组合逻辑电路及其工作原理。

二、多路选择器(MUX)多路选择器是一种常见的组合逻辑电路,它具有多个输入端和一个输出端。

根据控制信号的不同,选择器将其中一个输入信号传递到输出端。

例如,一个4选1多路选择器有4个输入端和1个输出端,根据2个控制信号可以选择其中一个输入信号输出。

多路选择器常用于数据选择、多输入运算等场合。

三、译码器(Decoder)译码器是一种将输入信号转换为对应输出信号的组合逻辑电路。

常见的译码器有2-4译码器、3-8译码器等。

以2-4译码器为例,它有2个输入信号和4个输出信号。

根据输入信号的不同组合,译码器将其中一个输出信号置为高电平,其他输出信号置为低电平。

译码器常用于地址译码、显示控制等应用。

四、加法器(Adder)加法器是一种用于实现数字加法运算的组合逻辑电路。

常见的加法器有半加器、全加器等。

半加器用于两个1位二进制数的相加,而全加器用于多位二进制数的相加。

加法器通过多个逻辑门的组合,将两个二进制数进行相加,并输出相应的和与进位。

加法器广泛应用于数字电路、计算机算术单元等领域。

五、比较器(Comparator)比较器是一种用于比较两个数字大小关系的组合逻辑电路。

常见的比较器有2位比较器、4位比较器等。

以2位比较器为例,它有两组输入信号和一个输出信号。

当两组输入信号相等时,输出信号为高电平;当第一组输入信号大于第二组输入信号时,输出信号为低电平。

比较器常用于数字大小判断、优先级编码等应用。

六、编码器(Encoder)编码器是一种将多个输入信号转换为对应输出信号的组合逻辑电路。

常见的编码器有2-4编码器、8-3编码器等。

以2-4编码器为例,它有2个输入信号和4个输出信号。

组合逻辑电路的设计方案举例

组合逻辑电路的设计方案举例

组合逻辑电路的设计举例例1. 某工厂有A、B、C三个车间和一个自备电站,站内有两台发电机G1和G2。

G1的容量是G2的两倍。

如果一个车间开工,只需G2运行即可满足要求;如果两个车间开工,只需G1运行;如果三个车间同时开工,则G1和 G2均需运行。

试画出控制G1和 G2运行的逻辑图,用与非门实现。

解:(1)根据逻辑要求写出逻辑状态表首先假设逻辑变量取“0”、“1”的含义。

设:A、B、C分别表示三个车间的开工状态:开工为“1”,不开工为“0”;G1和 G2运行为“1”,不运行为“0”。

逻辑状态表ABC G1 G2 0 0 0 00 0 0 1 0 11 0 0 1 0 11 0 1 0 0 01 0 1 1 0 11 0 1 0 1 1 111(2)由逻辑状态表写出逻辑式根据状态表写表达式的一般步骤:①在状态表上找出输出为1的行;②将这一行中所有自变量写成乘积项,当变量的取值为“1”时写为原变量,当变量的取值为“0”时写为原变量的反变量;③将所有乘积项逻辑加,便得到逻辑函数表达式。

这里的乘积项又叫最小项,在最小项里,每个变量都以它的原变量或反变量的形式在乘积项中出现,且仅出现一次。

(3)化简逻辑式(4)用“与非”门构成逻辑电路(5)画出逻辑电路图例2:设计三人表决电路(A、B、C)。

每人一个按键,如果同意则按下,不同意则不按。

结果用指示灯表示,多数同意时指示灯亮,否则不亮。

要求用与非门实现。

解:(1)根据逻辑要求列状态表首先确定逻辑变量取0、1的含义:A、B、C分别表示三人按键的状态,键按下时为“1”,不按时为“0”。

F表示指示灯的亮灭,灯亮为“1”,不亮为“0”。

逻辑要求:两个人(包括两个人)以上同意,指示灯亮。

ABCF 0 0 0 0 0 01 0 0 1 0 01 1 1 1 0 01 0 1 1 1 111111(2)由状态表写出逻辑式并化简、转换(3)实现电路。

组合逻辑电路设计

组合逻辑电路设计

组合逻辑电路设计组合逻辑电路是数字电路中的一种基本电路类型,它由逻辑门组合而成,能够实现特定的逻辑功能。

本文将探讨组合逻辑电路设计的基本原理和方法,介绍一些常见的设计技巧。

一、组合逻辑电路的基本原理组合逻辑电路是由逻辑门(如与门、或门、非门等)按照特定的逻辑关系组成的。

它的输入信号经过逻辑门的运算后,得到输出信号。

组合逻辑电路的输出完全取决于当前的输入信号,与之前的输入信号或状态无关。

因此,它是一种无记忆性的电路。

组合逻辑电路的设计需要确定输入和输出之间的逻辑关系,即真值表。

通过真值表,我们可以得到逻辑门的布尔代数表达式,进而确定电路的结构和连接方式。

常用的逻辑门包括与门、或门、非门、异或门等。

二、组合逻辑电路的设计方法1. 确定逻辑功能:根据需求确定电路应该实现的逻辑功能。

可以通过文字描述或真值表的形式进行规定。

2. 按照真值表确定布尔代数表达式:通过真值表,我们可以得到电路的逻辑关系,进而推导出逻辑门的布尔代数表达式。

例如,一个与门的真值表为:| 输入A | 输入B | 输出 ||------|------|-----|| 0 | 0 | 0 || 0 | 1 | 0 || 1 | 0 | 0 || 1 | 1 | 1 |由此可得与门的布尔代数表达式为:输出 = A·B。

3. 设计逻辑门电路:根据上一步得到的布尔代数表达式,选择适当的逻辑门进行组合设计。

将逻辑门按照表达式和电路的连接关系进行布局。

4. 优化电路结构:对电路进行优化,以减少逻辑门的数量和延迟。

常见的优化技术包括代数化简、费诺定理、卡诺图等。

5. 进行验证和仿真:使用逻辑仿真软件对设计的电路进行验证和调试。

通过输入不同的信号组合,检查输出是否符合预期结果。

三、组合逻辑电路的设计技巧1. 使用多级逻辑门:为了减少电路的延迟和功耗,可以使用多级逻辑门的方式来实现复杂的逻辑功能。

将多个逻辑门级联,形成一个级性结构。

2. 使用寄存器:当需要存储中间结果时,可以使用寄存器来保存数据。

实验一组合逻辑电路的设计

实验一组合逻辑电路的设计

实验一组合逻辑电路的设计组合逻辑电路是一种电子电路,由逻辑门组成,用于执行特定的逻辑功能。

在本实验中,我们将设计一个基本的组合逻辑电路以及一些常见的组合逻辑电路,包括加法器、减法器、比较器等。

首先,我们将设计一个基本的组合逻辑电路,该电路由两个输入和一个输出组成。

输入可以是0或1,输出将依据输入的值进行逻辑运算得出。

在这个基本电路中,我们将使用两个逻辑门:与门和或门。

与门的真值表如下:输入1输入2输出000010100111与门的布尔表达式是:输出=输入1AND输入2或门的真值表如下:输入1输入2输出000011101111或门的布尔表达式是:输出=输入1OR输入2基于以上真值表和布尔表达式,我们可以通过逻辑门的连接来设计一个基本的组合逻辑电路。

具体设计步骤如下:1.首先,将两个输入引线分别连接到与门和或门的输入端。

这将确保输入的值能够传递到逻辑门中。

2.将与门和或门的输出引线连接到一个输出引线上,以便能够输出最终的逻辑结果。

3.最后,将逻辑门的电源连接到电路的电源上,以确保逻辑门能正常工作。

通过以上步骤,我们就完成了一个基本的组合逻辑电路的设计。

这个电路可以根据输入产生不同的输出,实现不同的逻辑功能。

除了基本的组合逻辑电路,我们还可以设计一些常见的组合逻辑电路,如加法器、减法器和比较器。

加法器是用来执行数字加法的组合逻辑电路。

在一个二进制加法器中,输入是两个二进制数和一个进位位,输出是一个和输出和一个进位位。

加法器的设计可以通过级联多个全加器来实现。

减法器是用来执行数字减法的组合逻辑电路。

在一个二进制减法器中,输入是两个二进制数和一个借位位,输出是一个差输出和一个借位位。

减法器的设计可以通过级联多个全减法器来实现。

比较器是用来比较两个数字的大小的组合逻辑电路。

比较器的输出取决于输入的大小关系。

如果两个输入相等,则输出为0。

如果第一个输入大于第二个输入,则输出为1、如果第一个输入小于第二个输入,则输出为-1、比较器的设计可以通过使用逻辑门和触发器来实现。

组合逻辑电路的设计

组合逻辑电路的设计

0 1 1 0 ×××××
010
0 1 1 1 0 ××××
011
0 1 1 1 1 0 ×××
100
0 1 1 1 1 1 0 ××
101
0 1 1 1 1 1 1 0×
110
0 1 1 1 1 1 1 10
111

YEX YS
11 10 01 01 01 01 01 01 01 01
第4章 组合逻辑电路
第4章 组合逻辑电路
Dn An BnCn An BnCn An Bn C n An BnCn An Bn Cn
Cn1 An Bn C n An Bn C n BnCn An (Bn Cn ) BnCn An (Bn Cn ) BnCn
E3 A BC BD A BC BD
E2 BC D BC BD B(C D) B(C D) B (C D)
E1 C D CD C D C D
E0 D
第4章 组合逻辑电路
③ 画逻辑电路。
该电路采用了三种门电路,速度较快,逻辑图如图4.2.4所示。
的输入、输出均为低电平有效,因此给每个输出端加一个
反相器,即可将反码输出的BCD码转换为正常的BCD码。
第4章 组合逻辑电路
图4.3.3 74LS147的逻辑符号
第4章 组合逻辑电路
表4.3.2 74LS147的功能表
I1 I2 I3 I4 I5 I6 I7 I8 I9
111 11 11 11 ××× ×× ×× × 0 ××× ×× ×× 0 1 ××× ×× × 0 1 1 ××× ×× 0 1 1 1 ××× × 0 1 1 1 1 ××× 0 1 1 1 1 1 ×× 0 1 1 1 1 1 1 ×0 1 1 1 1 1 1 1

第9章组合逻辑电路

第9章组合逻辑电路

P1 A
P2 B C
P3 BC P4 P1 P2 A(B C)
P5 A P3 ABC
Y P4 P5 A(B C) ABC
(2)用卡诺图化简输出函数表达式。
Y A(B C) ABC A(B C) ABC AB AC AB AC
0
1
0
0
1
0
0
0
1
1
1
1
0
0
0
1
0
1
1
1
1
0
1
1
1
1
1
表9.2 真值表
9.1.3组合逻辑电路的设计
(3)由真值表写出输出变量函数表达式并化简:
Y ABC ABC ABC ABC AB BC AC (4)画出逻辑电路如图9.2所示。
AB
C 00 01 11 10
A
00 0 1 0
(1)确定输入、输出变量,定义逻辑状态的含义。
设A、B、C代表三个人,作为电路的三个输入变量,当A、 B、C为1时表示同意,为0表示不同意。将Y设定为输出变 量,代表决意是否通过的结果,当Y为1表示该决意通过, 当Y为0表示决意没有通过。
(2)根据题意列出真值表,如表9.2所示。
A
B
C
Y
0
0
0
0
0
• (2)根据真值表写逻辑表达式,并化简成最简“与或” 逻辑表达式。
• (3)选择门电路和型号。 • (4)按照门电路类型和型号变换逻辑函数表达式 • (5)根据逻辑函数表达式画逻辑图。
• 例9.2 设计一个三人表决器电路,当两个或两个以上的人 表示同意时,决意才能通过。 解:根据组合逻辑电路的设计方法,可按如下步骤进行。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实 验 报 告实验日期: 学 号:姓 名:实验名称:常用组合逻辑电路设计 总 分:一、实验目的学习常用组合逻辑电路的可中和代码编写,学习并熟悉VHDL 编程思想与调试方法,掌握LPM 元件实现逻辑设计,从而完成电路设计的仿真验证和硬件验证,记录结果。

二、实验原理VHDL 设计采用层次化的设计方法,自上向下划分系统功能并逐层细化逻辑描述。

层次关系中的没一个模块可以是VHDL 描述的实体,上层VHDL 代码中实例化出各个下层子模块。

利用VHDL 语言和LPM 元件设计这两种方法方法实现两个二位数大小比较的电路,根据A 数是否大于、小于、等于B 数,相应输出端F1、F2、F3为1,设A=A2A1,B=B2B1(A2A1、B2B1表示两位二进制数),当A2A1>B2B1时,F1为1;A2A1<B2B1时,F2为1;A2A1=B2B1时,F3为1。

结构图:Vhdl 实现LPM 元件实现Vhdl 实现LPM 元件实现三、实验设计 ① 利用VHDL 实现 (1)VHDL 代码 library IEEE;use IEEE.std_logic_1164.all; entity bijiao is二位数A2A1 比较运算 二位数B2B1 仿真验证 下载验证port(a2,a1:in STD_LOGIC;b2,b1:in STD_LOGIC;f1,f2:buffer STD_LOGIC;f3:out STD_LOGIC);end bijiao;architecture bijiao_arch of bijiao isbeginf1<=(a2 and(not b2))or(a1 and (not b1)and a2)or(a1 and (not b1)and(not b2));f2<=((not a2)and b2)or((not a2)and(not a1)and b1)or((not a1)and b1 and b2);f3<=not(f1 or f2);end bijiao_arch;(2)波形仿真网格大小 100ns结束时间 2μs功能仿真:时序仿真:输入信号00,01,10,11输入信号00,01,10,11输出信号001,010,100信号均为二进制表达输入信号00,01,10,11(3)仿真分析 周期设置:为得出如图仿真结果,依据题意设置信号输入周期A2为800ns ,A1为400ns ,B2为200ns ,B1为100ns 。

仿真结论:输入 输出A2A1 B2B1 F1F2F3 00 00 001 01 01010 010 11 01001 00 100 01 00110 010 11 01010 00 100 01 10010 001 11 01011 00 100 01 10010 100 11 001由图表结果得出以下结论:I.当A2A1>B2B1时,F1为1; II.当A2A1<B2B1时,F2为1;信号均为二进制表达输入信号00,01,10,11输出信号001,010,100出现延迟III.当A2A1=B2B1时,F3为1; IV.仿真结果正确。

(4)管脚分配(实验板)Input A2 PIN_60Input A1 PIN_59Input B2 PIN_51Input B1 PIN_49Output F1 PIN_88Output F2 PIN_87Output F3 PIN_86(5)下载验证:60、59支配A2A1输入信号,51、49支配B2B1输入信号。

88、87、86分别对应显示F1、F2、F3的结果,又信号输出为1时亮,输出为0时不亮。

结果:I.A2A1>B2B1时,F1为1,88亮灯;II.A2A1<B2B1时,F2为1,87亮灯;III.A2A1=B2B1时,F3为1,86亮灯;结论:下载验证结果与管脚分配保持一致。

(6)RTL viewer调试结果f2~5 b2^b1^a1’ f1~4 b2’^b1’^a1f2~0 b2^a2’ f1~2 a2^(b1’^a1)f2~2 b1^a1’^a2’ f1~5 (b2^b1’^a1)+(b1’^a2)f1~1 b1’^a1f1~0 b2’^a2f2~6 (b2^b1^a1’)+(b2^a2’)+(b1^a1’^a2’)f3~0 (b2^b1^a1’)+(b2^a2’)+(b1^a1’^a2’)+(b2^b1’^a1)+(b1’^a2)②利用LPM元件实现(1)流程利用LPM原件定制实现两个二位数大小比较的电路,包括>、<、=、>=、<=、<>新建工程所在文件夹为lpm_compare2、工程名称为lpm_lpm_compare2、顶层实体名称为lpm_compare2,选择目标器件EPF10K20TI144-4。

选择Tool→Mega Wizard plug-in Manager命令,或在图形编辑窗口中的空白处双击,在弹出的对话框中选择Mega Wizard Plug-in Manager,选择Create a new custom megafunction variation,点击Next。

左侧列表中选择Installed Plug_Ins→Arithmetic→lpm_compare,设置目标器件为Flex10K,元件名为lpm_compare2,文件输出类型为VHDL,单击next。

设置输入数据宽度为2位,选择所需输出端口,单击Next。

设置datab和比较数值符号类型,单击next。

设置流水线,单击Next。

可设置Generate netlist,单击Next。

打开输出路径下地lpm_compare2——waveforms.html。

仿真波形结果如图:输入二进制信号dataa,databA=BA>BA>=BA<BA<=BA≠B结论:与VHDL仿真验证结果保持一致。

(2)管脚分配(实验板)Input dataa[1] PIN_60Input dataa[0] PIN_59Input datab[1] PIN_51Input datab[0] PIN_49Output AeB PIN_95Output AgB PIN_92Output AgeB PIN_91Output AlB PIN_90Output AleB PIN_89Output AneB PIN_88(3)下载验证:60、59支配A2A1输入信号,51、49支配B2B1输入信号。

95、92、91、90、89、88分别对应显示AeB、AgB、AgeB、AlB、AleB、AneB的结果,且信号输出为1时亮,输出为0时不亮。

结果:I.当A=B时,95亮灯;II.当A>B时,92亮灯,III.当A>=B时,91亮灯;IV.当A<B时,90亮灯;V.当A<=B时,89亮灯;VI.当A≠时,88亮灯。

结论:下载验证结果与管脚分配保持一致。

四、思考题1、VHDL中如何调用用户自定义元件、旧式74系列元件、参数化元件?答:调用用户自定义元件:library work;use work.package_name._package_name;调用旧式74系列元件和参数化元件:library altera;use altera.muxplus2.maxplus2;调用参数化原件:library LPM;use LPM.lpm ponents;2、比较VHDL中的signal与variable?答:对信号而言会有延时,而变量则是立即赋值。

变量声明及赋值应在进程中,而信号只需要在整个结构体中声明赋值即可。

在一个进程中,如果对一个信号多次赋值,那么,只有最后一个值才是有效的。

如果对变量多次赋值,那么每次赋值都是有效的,并且,变量的值在再次赋值之前一直保持不变。

3、VHDL中如何设计电路反馈信号?答:将端口声明为Buffer端口,而不是out端口。

4、举例说明常用的VHDL顺序执行和并行执行语句?(1) 顺序执行语句:赋值语句、流程控制语句、等待语句、调用语句、返回语句。

(2) 并行语句:并行信号赋值语句、进程语句、块语句、条件信号赋值语句、元件例化语句、并行过程调用语句、参数传递映射语句、端口说明语句。

5、说明VHDL描述组合逻辑电路是signal的作用是什么?答:在组合逻辑电路中,signal起到电路内部连接传递的作用。

五、实验日志遇到的问题:1、在进行参数设置时,不知道如何设置成仿真图所示。

2、仿真图有细微差别,原因是在LIST选取结点时,未按照信号输入结点的顺序进行点击,即应先点击A2,后点击A1,同理B2B1。

3、在进行LPM宏功能选择对话框的路径必须写明lpm_compare2,未写明是can't find files。

4、在进行LPM的lpm_compare2文件夹中无法找到lpm_compare2_waveforms.html文件,将查找范围定为all.files解决问题。

疑问:lpm_compare2波形中为什么dataa和datab中出现0、1、2、3等信号。

六、实验心得通过本次实验,掌握组合逻辑电路设计的方法,掌握并熟悉VHDL实现、LPM 元件实现以及RTL调试,并进一步熟练了仿真、下载等流程。

相关文档
最新文档