邏輯函數(shù)的卡諾圖化簡(jiǎn)法
一、最小項(xiàng)的定義及其性質(zhì)
1.最小項(xiàng)的基本概念
由A、B、C三個(gè)邏輯變量構(gòu)成的許多乘積項(xiàng)中有八個(gè)被稱(chēng)為A、B、C的最小項(xiàng)的乘積項(xiàng),它們的特點(diǎn)是
1. 每項(xiàng)都只有三個(gè)因子
2. 每個(gè)變量都是它的一個(gè)因子
3. 每一變量或以原變量(A、B、C)的形式出現(xiàn),或以反(非)變量(A、B、C)的形式出現(xiàn),各出現(xiàn)一次
一般情況下,對(duì)n個(gè)變量來(lái)說(shuō),最小項(xiàng)共有2n個(gè),如n=3時(shí),最小項(xiàng)有23=8個(gè)
2.最小項(xiàng)的性質(zhì)
為了分析最小項(xiàng)的性質(zhì),以下列出3個(gè)變量的所有最小項(xiàng)的真值表。
由此可見(jiàn),最小項(xiàng)具有下列性質(zhì):
(1)對(duì)于任意一個(gè)最小項(xiàng),只有一組變量取值使得它的值為1,而在變量取其他各組值時(shí),這個(gè)最小項(xiàng)的值都是0。
?。?)不同的最小項(xiàng),使它的值為1的那一組變量取值也不同。
(3)對(duì)于變量的任一組取值,任意兩個(gè)最小項(xiàng)的乘積為0。
?。?)對(duì)于變量的任一組取值,全體最小項(xiàng)之和為1。
3.最小項(xiàng)的編號(hào)
最小項(xiàng)通常用mi表示,下標(biāo)i即最小項(xiàng)編號(hào) ,用十進(jìn)制數(shù)表示。以ABC為例,因?yàn)樗?11相對(duì)應(yīng),所以就稱(chēng)ABC是和變量取值011相對(duì)應(yīng)的最小項(xiàng),而011相當(dāng)于十進(jìn)制中的3,所以把ABC記為m3按此原則,3個(gè)變量的最小項(xiàng)
二、邏輯函數(shù)的最小項(xiàng)表達(dá)式
利用邏輯代數(shù)的基本公式,可以把任一個(gè)邏輯函數(shù)化成一種典型的表達(dá)式,這種典型的表達(dá)式是一組最小項(xiàng)之和,稱(chēng)為最小項(xiàng)表達(dá)式
。下面舉例說(shuō)明把邏輯表達(dá)式展開(kāi)為最小項(xiàng)表達(dá)式的方法。例如,要將化成最小項(xiàng)表達(dá)式,這時(shí)可利用的基本運(yùn)算關(guān)系,將邏輯函數(shù)中的每一項(xiàng)都化成包含所有變量A、B、C的項(xiàng),然后再用最小項(xiàng)下標(biāo)編號(hào)來(lái)代表最小項(xiàng),即
又如,要將 化成最小項(xiàng)表達(dá)式,可經(jīng)下列幾步:
?。?)多次利用摩根定律去掉非號(hào) ,直至最后得到一個(gè)只在單個(gè)變量上有非號(hào)的表達(dá)式;
?。?)利用分配律除去括號(hào),直至得到一個(gè)與或表達(dá)式;
?。?)在以上第5個(gè)等式中,有一項(xiàng)AB不是最小項(xiàng)(缺少變量C),可用乘此項(xiàng),正如第6個(gè)等式所示。
由此可見(jiàn),任一個(gè)邏輯函數(shù)都可化成為唯一的最小項(xiàng)表達(dá)式。
三、用卡諾圖表示邏輯函數(shù)
1.卡諾圖的引出
一個(gè)邏輯函數(shù)的卡諾圖就是將此函數(shù)的最小項(xiàng)表達(dá)式中的各最小項(xiàng)相應(yīng)地填入一個(gè)特定的方格圖內(nèi),此方格圖稱(chēng)為卡諾圖。
卡諾圖是邏輯函數(shù)的一種圖形表示。
下面從討論一變量卡諾圖開(kāi)始,逐步過(guò)渡到多變量卡諾圖。
大家知道,n個(gè)變量的邏輯函數(shù)有2n個(gè)最小項(xiàng) ,因此一個(gè)變量的邏輯函數(shù)有兩個(gè)最小項(xiàng)。
比如有一個(gè)變量D,其邏輯函數(shù)L的最小項(xiàng)表達(dá)式為:
其中D和是兩個(gè)最小項(xiàng),分別記為m1和m0,即m0=D,m1=D。這兩個(gè)最小項(xiàng)可用兩個(gè)相鄰的方格來(lái)表示,如下圖所示。方格上的D和分別表示原變量和非變量。為了簡(jiǎn)明起見(jiàn),非變量可以不標(biāo)出,只標(biāo)出原變量D。但是還可以進(jìn)一步簡(jiǎn)化,也就是將m0,m1只用其下標(biāo)編號(hào)來(lái)表示。
若變量的個(gè)數(shù)為兩個(gè),則最小項(xiàng)個(gè)數(shù)為22=4項(xiàng),函數(shù)的最小項(xiàng)表達(dá)式為
由于有4個(gè)最小項(xiàng),可用4個(gè)相鄰的方格來(lái)表示。這4個(gè)方格可以由折疊了的1變量卡諾圖展開(kāi)來(lái)獲得,如下圖所示,變量D標(biāo)在圖的底下,標(biāo)的規(guī)律符合展開(kāi)的規(guī)律,即中間兩格底下為D,兩邊的兩格底下為。而變量C可標(biāo)在展開(kāi)后新的兩個(gè)方格的頂上,以保持左邊的第一格仍為m0項(xiàng),即維持展開(kāi)前兩方格最小項(xiàng)序號(hào)不改變。由圖中可看到一個(gè)規(guī)律:新的方格內(nèi)最小項(xiàng)的編號(hào)比對(duì)應(yīng)的原方格增加了2n-1=22-1=2。按照這個(gè)規(guī)律折疊時(shí),方格1后面為方格3,方格0后面為方格2,展開(kāi)后即得圖示的2變量卡諾圖。
綜上所述,可歸納“折疊展開(kāi)”的法則如下:
?、傩略黾拥姆礁癜凑归_(kāi)方向應(yīng)標(biāo)以新變量。
?、谛碌姆礁駜?nèi)最小項(xiàng)編號(hào)應(yīng)為展開(kāi)前對(duì)應(yīng)方格編號(hào)加2n-1。
按照同樣的方法,可從折疊的2變量卡諾圖展開(kāi)獲得3變量卡諾圖。3變量邏輯函數(shù)L(B, C, D)應(yīng)有8?jìng)€(gè)最小項(xiàng),可用8?jìng)€(gè)相鄰的方格來(lái)表示。新增加的 4個(gè)方格按展開(kāi)方向應(yīng)標(biāo)以新增加的變量B(以區(qū)別于原來(lái)的變量C、D)。而且,新增加的方格內(nèi)最小項(xiàng)的編號(hào)為展開(kāi)前對(duì)應(yīng)方格編號(hào)加2n-1=23-1=4,這樣即可獲得3變量卡諾圖如下:
同理,可得4變量卡諾圖,如下圖所示。
在使用時(shí),只要熟悉了卡諾圖上各變量的取值情況(即方格外各變量A、B、C、D等取值的區(qū)域),就可直接填入對(duì)應(yīng)的最小項(xiàng)。
將上圖中的數(shù)碼編號(hào)與最小項(xiàng)的編號(hào)——對(duì)應(yīng),可以得到下面這種形式的卡諾圖。
2.卡諾圖的特點(diǎn)
上面所得各種變量的卡諾圖,其共同特點(diǎn)是可以直接觀察相鄰項(xiàng)
。也就是說(shuō),各小方格對(duì)應(yīng)于各變量不同的組合,而且上下左右在幾何上相鄰的方格內(nèi)只有一個(gè)因子有差別,這個(gè)重要特點(diǎn)成為卡諾圖化簡(jiǎn)邏輯函數(shù)的主要依據(jù)。在卡諾圖水平方向的同一行里,最左和最右端的方格也是符合上述相鄰規(guī)律的,例如,m4和m6的差別僅在C和。同樣,垂直方向同一列里最上端和最下端兩個(gè)方格也是相鄰的,這是因?yàn)槎贾挥幸粋€(gè)因子有差別。這個(gè)特點(diǎn)說(shuō)明卡諾圖呈現(xiàn)循環(huán)鄰接的特性。
3.已知邏輯函數(shù)畫(huà)卡諾圖
根據(jù)邏輯函數(shù)的最小項(xiàng)表達(dá)式和卡諾圖的一般形式,就可以得到相應(yīng)的卡諾圖。
例如,要畫(huà)出邏輯函數(shù)的卡諾圖時(shí),可根據(jù)4變量卡諾圖,對(duì)上列邏輯函數(shù)最小項(xiàng)表達(dá)式中的各項(xiàng),在卡諾圖相應(yīng)方格內(nèi)填入1,其余填入0,即可得到如下圖所示的L的卡諾圖。
例:畫(huà)出
的卡諾圖
解:
?。?)利用摩根定律,可以將上式化簡(jiǎn)為:
?。?)因上式中最小項(xiàng)之和為L,故對(duì)L中的各最小項(xiàng),在卡諾圖相應(yīng)方格內(nèi)應(yīng)填入0,其余填入1,即得下圖所示的卡諾圖。
四、用卡諾圖化簡(jiǎn)邏輯函數(shù)
1.化簡(jiǎn)的依據(jù)
我們知道,卡諾圖具有循環(huán)鄰接的特性,若圖中兩個(gè)相鄰的方格均為1,則這兩個(gè)相鄰最小項(xiàng)的和將消去一個(gè)變量。
比如4變量卡諾圖中的方格5和方格7,它們的邏輯加是,項(xiàng)消去了變量C,即消去了相鄰方格中不相同的那個(gè)因子。若卡諾圖中4個(gè)相鄰的方格為1,則這4個(gè)相鄰的最小項(xiàng)的和將消去兩個(gè)變量,如上述4變量卡諾圖中的方格2、3、7、6,它們的邏輯加是
消去了變量B和D,即消去相鄰4個(gè)方格中不相同的那兩個(gè)因子
,這樣反復(fù)應(yīng)用的關(guān)系,就可使邏輯表達(dá)式得到簡(jiǎn)化。這就是利用卡諾圖法化簡(jiǎn)邏輯函數(shù)的某本原理。
2.化簡(jiǎn)的步驟
用卡諾圖化簡(jiǎn)邏輯函數(shù)的步驟如下:
?。?)將邏輯函數(shù)寫(xiě)成最小項(xiàng)表達(dá)式。
?。?)按最小項(xiàng)表達(dá)式填卡諾圖 ,凡式中包含了的最小項(xiàng),其對(duì)應(yīng)方格填1,其余方格填0。
?。?)合并最小項(xiàng),即將相鄰的1方格圈成一組(包圍圈),每一組含2n個(gè)方格,對(duì)應(yīng)每個(gè)包圍圈寫(xiě)成一個(gè)新的乘積項(xiàng)。
?。?)將所有包圍圈對(duì)應(yīng)的乘積項(xiàng)相加。
有時(shí)也可以由真值表直接填卡諾圖,以上的(1)、(2)兩步就合為一步。
畫(huà)包圍圈時(shí)應(yīng)遵循以下原則:
?。?)包圍圈內(nèi)的方格數(shù)必定是2n個(gè),n等于0、1、2、3、…。
?。?)相鄰方格包括上下底相鄰,左右邊相鄰和四角相鄰。
(3)同一方格可以被不同的包圍圈重復(fù)包圍 ,但新增包圍圈中一定要有新的方格,否則該包圍圈為多余。
?。?)包圍圈內(nèi)的方格數(shù)要盡可能多,包圍圈的數(shù)目要盡可能少。
化簡(jiǎn)后,一個(gè)包圍圈對(duì)應(yīng)一個(gè)與項(xiàng)(乘積項(xiàng)),包圍圈越大,所得乘積項(xiàng)中的變量越少。實(shí)際上,如果做到了使每個(gè)包圍圈盡可能大
,結(jié)果包圍圈個(gè)數(shù)也就會(huì)少,使得消失的乘積項(xiàng)個(gè)數(shù)也越多,就可以獲得最簡(jiǎn)的邏輯函數(shù)表達(dá)式。下面通過(guò)舉列來(lái)熟悉用卡諾圖化簡(jiǎn)邏輯函數(shù)的方法。
例: 一個(gè)邏輯電路的輸入是4個(gè)邏輯變量A、B、C、D ,它的真值表如下,用卡諾圖法求化簡(jiǎn)的與一或表達(dá)式及與非一與非表達(dá)式。
解:
?。?)由真值表畫(huà)出卡諾圖,如下圖所示。
(2)畫(huà)包圍圈合并最小項(xiàng),得簡(jiǎn)化的與一或表達(dá)式。
?。?) 求與非一與非表達(dá)式。
二次求非然后利用摩根定律得
利用卡諾圖表示邏輯函數(shù)式時(shí),如果卡諾圖中各小方格被1占去了大部分,雖然可用包圍1的方法進(jìn)行化簡(jiǎn),但由于要重復(fù)利用1項(xiàng)
,往往顯得零亂而易出錯(cuò)。這時(shí)采用包圍0的方法化簡(jiǎn)更為簡(jiǎn)單。即求出非函數(shù)再對(duì)求非,其結(jié)果相同,下面舉例說(shuō)明。
例:化簡(jiǎn)下列邏輯函數(shù)
解:
?。?)由L畫(huà)出卡諾圖,如圖所示。
?。?)用包圍1的方法化簡(jiǎn),如下圖所示,得
所以有:
?。?)用包圍0的方法化簡(jiǎn),如圖所示,
根據(jù)圖得到:,兩邊去反后可得:
兩種方法得到的結(jié)果是相同的。
實(shí)際中經(jīng)常會(huì)遇到這樣的問(wèn)題,在真值表內(nèi)對(duì)應(yīng)于變量的某些取值下,函數(shù)的值可以是任意的,或者這些變量的取值根本不會(huì)出現(xiàn),這些變量取值所對(duì)應(yīng)的最小項(xiàng)稱(chēng)為無(wú)關(guān)項(xiàng)或任意項(xiàng)。
無(wú)關(guān)項(xiàng)的意義在于,它的值可以?。盎蛉。?,具體取什么值,可以根據(jù)使函數(shù)盡量得到簡(jiǎn)化而定。
評(píng)論