Минимальная конъюнктивная нормальная форма

Материал из Циклопедии
(перенаправлено с «МКНФ»)
Перейти к навигации Перейти к поиску
Карты Карно. Минимизация КНФ. Код Грея [10:14]

Минимальная конъюнктивная нормальная форма (МКНФ) для логической функции — это конъюнкция с минимальным числом элементарных дизъюнкций с минимальным числом аргументов (либо самих, либо их отрицаний) данной функции. При этом таблицы истинности для логической функции и её МКНФ совпадают.

Минимальная конъюнктивная нормальная форма для логической функции с числом аргументов до четырёх может быть построена с помощью карт Карно.

Для этого нули карты Карно последовательно покрываются прямоугольниками 4×2, 2×4, 2×2, 4×1, 1×4, 2×1, 1×2 и 1×1. Затем строятся элементарные дизъюнкты МКНФ.

Обозначения[править]

n — число аргументов функции;
k — число прямоугольников на карте Карно;
(x1, x2, …, xn) — набор аргументов функции;
f(x1, x2, …, xn) — логическая функция;
Pt(x1, x2, …, xn) = {(i1, l1); (i2, l2); …; (im, lm)} — множество клеток t-прямоугольника;
Pt(x1, x2, …, xn) = 0 — множество клеток t-прямоугольника из нулей;
argj(i, l) — значение аргумента xj в наборе аргументов для клетки (i, l);
fМКНФ(x1, x2, …, xn) — МКНФ логической функции.

Формула[править]

где

Примеры построения МКНФ[править]

Пример 1[править]

Строим карту Карно для функции трёх переменных f(x1, x2, x3):

f(x1,x2,x3)=(01001101)

МКНФ21.JPG

Нули карты Карно минимально покрываются одним прямоугольником вида 1х2 и двумя прямоугольниками вида 2х1, что соответствует трём элементарным дизъюнкциям двух аргументов.

P1(x1,x2,x3) = {(1,1);(2,1)}
P2(x1,x2,x3) = {(2,1);(3,1)}
P3(x1,x2,x3) = {(2,1);(2,2)}

Пример 2[править]

Строим карту Карно для функции четырёх переменных

f(x1,x2,x3,x4) = (1111110110100000)

МКНФ22.JPG

Нули карты Карно минимально покрываются одним квадратом вида 2х2, одним прямоугольником вида 1х4 и одним прямоугольником вида 2х1, что соответствует трём элементарным дизъюнкциям, в двух из которых два аргумента, а в одной три аргумента.

P1(x1,x2,x3,x4)={(3,2);(3,3);(4,2);(4,3)}
P2(x1,x2,x3,x4)={(3,1);(3,2);(3,3);(3,4)}
P3(x1,x2,x3,x4)={(2,4);(3,4)}

Пример 3[править]

Строим трёхмерную карту Карно для функции пяти переменных

f(x1,x2,x3,x4,x5) = (00001010000001011100111110101111)

МКНФ23.JPG

Нули трёхмерной карты Карно минимально покрываются параллелепипедами вида 2х2х2, 1х4х1 (два), 2х2х1, 1х1х2, что соответствует одной элементарной дизъюнкции двух аргументов, трём элементарным дизъюнкциям трёх аргументов и одной элементарной дизъюнкции четырёх аргументов. Заметим, что соответствующие равные фигуры в разных таблицах объединяются.

P1(x1,x2,x3,x4,x5)={(1,1,1);(1,2,1);(2,1,1);(2,2,1);(1,1,2);(1,2,2);(2,1,2);(2,2,2)}
P2(x1,x2,x3,x4,x5)={(1,1,2);(1,2,2);(1,3,2);(1,4,2)}
P3(x1,x2,x3,x4,x5)={(2,1,1);(2,2,1);(2,3,1);(2,4,1)}
P4(x1,x2,x3,x4,x5)={(2,1,2);(2,2,2);(3,1,2);(3,2,2)}
P5(x1,x2,x3,x4,x5)={(4,2,1);(4,2,2)}

Другие формы:[править]