Kapitola 12
Logické funkce
Logickou funkci můžeme vyjádřit několika způsoby: slovně, graficky (pomocí mapy [Svobodova, Karnaughova], vývojovým
diagramem), tabulkou (pravdivostní funkcí) nebo algebraitským vzorcem (Booleova algebra).
12.1 Booleova algebra
komutativní zákony x + y = y + x, x y = y xasociativní zákony (x + y) + z = x + (y + z), (x y) z = x (y z)
distributivní zákony (x + y) z = x z + y z, x y + z = (x + z) (y + z)
zákon o vyloučeném třetím x + x' = 1, x x' = 0
zákon o neutrálnosti nuly x + 0 = x
zákon o neutrálnosti jedničky x·1 = x
zákon agresivity nuly x · 0 = 0
zákon agresivity jedničky x + 1 = 1
zákon o idempotenci prvků x + x = x, x · x = x
zákon absorpce x + x · y = x
zákon absorpce negace x + x' y = x + y, x (x' + y) = x y
zákon dvojité negace (x')' = x
De Morganovy zákony x' y' = (x + y)', x' + y' = (x y)'
12.2 Minimalizační metody
12.2.1 Karnaughovy mapy
12.2.2 Quine-McCluskeyho metoda
Tato metoda vychází ze stejných principů jako metoda karnaughových map. Implikantem funkce F(x1, x2, …, xn) budeme nazývat každou konjunkci K(x1, x2, …, xn). Implikant budeme nazývat prostým (minimálním), když vypuštěním kteréhokoliv souboru proměnné přestane být implikantem booleovy funkce. Prostým implikantem je tedy každá konjunkce minimální součtové formy dané funkce. Vlastní minimalizační metoda se uskutečňuje ve dvou etapách. V první etapě se stanoví všechny prosté implikanty. Ve druhé se pak provádí výběr minimálního počtu prostých implikantů, jejichž logický součet tvoří minimální formu.Stanovení prostých implikantů
Vychází se z pravdivostní tabulky dané booleovy funkce. Dva stavy, kterým odpovídají konjunkce nazýváme sousedními stavy. Sousední stavy odpovídají sousedním políčkům v karnaughově mapě. Tyto dva stavy se pak zobrazují novým zkráceným stavem, kde dvě proměnné, v níž se sousední stavy liší, zapíšeme pomlčkou.Postup při tvorbě prostých implikantů
Jednotlivé stavy roztřídíme do skupin tak, že každá skupina obsahuje pouze stavy se stejným počtem jedniček v nich obsažených. Poté seřadíme skupiny stavů pod sebe např. podle stoupajícího počtu jedniček a v nich připíšeme příslušný stavový index.12.2.3 Patrickova metoda
Nechť {a1, a2, …, ai, …, ap} je množina všech prostých implikantů a {b1, b2, …, bq} množina všech jednotlivých stavů dané funkce. Pak tabulku pokrytí definujeme jako matici TP = (cij), kde cij = 1, jestliže mezi prvky ai a bi je splněn vztah pokrytí. V opačném případě bude cij = 0. Matice má p řádků a q sloupců. Platí c1j = Σi = 1q cij, c2j = Σi = 1q cij. c1i udává počet stavů, který udává implikant ai a podobně c2j udává počet implikantů, které pokrývají stav bj. Výraz
|