卡诺图在组合逻辑电路竞争冒险中的应用.docVIP

卡诺图在组合逻辑电路竞争冒险中的应用.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
卡诺图在组合逻辑电路竞争冒险中的应用

卡诺图在组合逻辑电路竞争冒险中的应用 匡晚成 ,肖洪祥 ( 桂林工学院 电子与计算机系 ,广西 桂林 541004 ) 摘 要:卡诺图是组合逻辑电路设计和分析最常用和有效的数学工具,排列多变量的卡诺图则不是易事。格雷码相邻码之间只有一位不同,这与卡诺图的循环邻接有相同之处。本文介绍二进制码转化为格雷码和利用格雷码的规律快速排列多变量卡诺图的方法,叙述了卡诺图在组合逻辑电路竞争冒险中的应用。 关键词:格雷码;卡诺图;竞争冒险; 中图分类号:TN791 文献标志码:A 1 引 言 在数字电子技术中,卡诺图无论是在逻辑函数的设计和化简中,还是在组合逻辑电路竞争冒险现象的分析中都占有重要的地位。它是数字电路分析和设计常用的工具,并且具有循环邻接的特点。正是这个特点,使得它可以很方便的化简多变量的逻辑函数。要化简多变量的逻辑函数,通常必须排出多变量的卡诺图。尽管可采用“折叠展开”的法则或者查表法进行排列[1],但这些方法排列和记忆比较困难。因此,设计人员急需一种简捷易行的排列卡诺图的方法。本文论述了以格雷码规律排列卡诺图的方法,并举例说明用卡诺图在组合逻辑电路竞争冒险中的应用。 2 卡诺图的排列方法 2.1 二进制码与格雷码的转换 格雷码是二进制代码表示的一种无权码,在数字系统中有着广泛的应用。其特点是任意两相邻代码之间只有一位数不同,其余各位均相同; 现常用于模拟—数字转换和转角—数字转换。它有许多种,典型的格雷码是一种具有反射特性和循环特性的单步自补码。 二进制码是一种可以直接用于计算,并能被计算机直接识别的是一种代码。在工程应用中,需将格雷码转换为二进制码;但由于相邻的两组格雷码之间的只有一位不同,这正好和卡诺图循环邻接特点一致,因此需要将二进制代码转换为格雷码,以便快速排列多变量卡诺图。 转换方法如下: 设N位二进制码: B = Bn-1 …Bi-1 Bi. …B1 B0 其对应的N位格雷码: G = Gn-1 …Gi-1 Gi. …G1 G0 最高位不变 Gn-1 = Bn-1 Gi = XOR (Bi+1, Bi ) , i从0到 n-2。 根据以上方法,我们按照十进制的大小顺序将四位的二进制数转换为相应的格雷码,其转换结 果见如下表1。该公式只适应于二进制位数不是很长的情况下,当位数超过6位时,计算特烦琐而 且易于出错,给电路设计者带来了极大的不方便。因此对位数较长的二进制数,建议用软件法实现。 作者简介:匡晚成(1980 —),男( 汉 族 ),湖南双峰人,硕士研究生。研究方向:数字信号处理 十进制数 二进制编码 格雷码 B3 B2 B1 B0 G3 G 0 0 0 0 0 0 0 0 0 1 0 0 0 1 0 0 0 1 2 0 0 1 0 0 0 1 1 3 0 0 1 1 0 0 1 0 4 0 1 0 0 0 1 1 0 5 0 1 0 1 0 1 1 1 6 0 1 1 0 0 1 0 1 7 0 1 1 1 0 1 0 0 8 1 0 0 0 1 1 0 0 9 1 0 0 1 1 0 0 0 表1 二进制码和格雷码的对应关系对照表我们用C语言编制了一个码制转换程序, 表1 二进制码和格雷码的对应关系对照表 此程序实现码制转换的主要代码: int XOR(int a,int b) { if(a!=b)return 1; else return 0; } void Bin2Gray(int Bin[],int Gray[],int Len) { int i; Gray[Len-1]=Bin[Len-1]; for(i=Len-2;i=0;i--){ Gray[i]=XOR(Bin[i+1],Bin[i]); } } 2.2 根据格雷码排列卡诺图 四变量以下的卡诺图排列比较简单,只需掌握两位格雷码就可以;但是五变量以上的卡诺图排列比较复杂,则必须掌握三位以上的格雷码顺序。排序的方法就是按十进制的大小将二进制码转换为格雷码,格雷码的顺序就是卡诺图中的最小项。 具体排列卡诺图时,通常将逻辑函数的输入变量分为两组,高位组放在卡诺图的行项,低位组放在列项。格雷码的0和1分别代表非变量和原变量,各输入变量组合按上述方法求出的格雷码顺序排列,行与列的交叉就是逻辑函数的最

文档评论(0)

zhuliyan1314 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档