Основные понятия
Пусть задан алфавит переменных {x1, x2, … , xn}. Логическое произведение Ki = xi11 & xi22 &…& xirr, где 0 r n и x= x при =1 и x= при =0, называется элементарной конъюнкцией ранга r, если все переменные в нем различны (т.е. ii при ).
Константа 1 считается элементарной конъюнкцией нулевого ранга.
Логическая сумма Di = xi11 xi22 … xirr, где 0 r n, называется элементарной дизъюнкцией ранга r, если все переменные в ней различны.
Константа 0 считается элементарной дизъюнкцией нулевого ранга.
Формула вида D = K1 K2 … Ks, где K1, K2,…, Ks – различные элементарные конъюнкции рангов r1, r2,…, rs соответственно, называется дизъюнктивной нормальной формой (ДНФ).
Формула вида K = D1 & D2 &…& Ds, где D1, D2,…, Ds – различные элементарные дизъюнкции рангов r1, r2,…, rs соответственно, называется конъюнктивной нормальной формой (КНФ).
Всякая истинностная функция, не равная тождественно нулю (единице) может быть выражена в виде ДНФ (КНФ). Будет ли такое представление единственным?
-
О числе различных ДНФ
Число различных ДНФ, которые могут быть построены для функций от n переменных равно 23n.
Доказательство:
В дизъюнктивную нормальную форму для функций от n переменных {x1,x2,…,xn} могут входить конъюнкции нулевого, первого, второго и т.д, n-го рангов. Причем, число конъюнкций нулевого ранга может быть не больше единицы. (Его можно рассматривать как число нуль элементных подмножеств n-множества, оно равно биномиальному коэффициенту и равно 1.)
Число конъюнкций 1–го ранга равно 2n. Каждую конъюнкцию 1–го ранга можно рассматривать как одноэлементное подмножество n-множества. А число таких подмножеств равно , но элемент в конъюнкции может быть либо xi, либо , поэтому общее число конъюнкций 1–го ранга будет вдвое больше и равно 2n.
Конъюнкции 2–го ранга можно рассматривать как двухэлементные подмножества n-множества. Число таких подмножеств равно , но каждый из двух элементов конъюнкции может быть либо xi, либо , поэтому общее число конъюнкций 2–го ранга будет вчетверо больше и равно 22
Аналогично определяется число конъюнкций k–го ранга, оно равно 2k. И общее число различных конъюнкций над алфавитом {x1,x2,…,xn} равно сумме: . Поскольку различные ДНФ отличаются друг от друга совокупностью входящих в них конъюнкций, то их общее число равно 23n. Так как число различных функций алгебры логики от n переменных равно 22n, и 22n < 23n, то представление функции в виде ДНФ не может быть единственным.
Из этой теоремы следует также, что число различных СДНФ для функций алгебры логики от n переменных равно 22n, так как СДНФ состоят только из конъюнкций ранга n, а их число равно 2n=2n. Тем самым, каждая функция представляется в виде СДНФ единственным образом.
Пример:
x | y | z | f(x,y,z) |
0 | 0 | 0 | 1 |
0 | 0 | 1 | 0 |
0 | 1 | 0 | 0 |
0 | 1 | 1 | 0 |
1 | 0 | 0 | 1 |
1 | 0 | 1 | 1 |
1 | 1 | 0 | 1 |
1 | 1 | 1 | 1 |
Таблица 19 |
СДНФ=. (Здесь и далее для компактности записи пропущен знак «&».) Выполнив преобразования, получим ДНФ1=, затем ДНФ2=. Далее ДНФ3=. Нетрудно убедиться, что у этой функции имеются и другие ДНФ.
Среди всех ДНФ (КНФ), реализующих некоторую функцию, естественно можно выбрать наиболее простую. Критерием простоты может служить число букв в записи ДНФ, или число элементарных конъюнкций, или число символов «» над буквами.
ДНФ (КНФ), имеющая наименьшее число букв среди всех ДНФ, реализующих некоторую функцию, называется минимальной (МДНФ).
ДНФ (КНФ), состоящая из наименьшего числа конъюнкций среди всех ДНФ, реализующих данную функцию, называется кратчайшей (КДНФ).
Задачи построения минимальных и кратчайших ДНФ каждая имеет свою специфику. Множества МДНФ и КДНФ для одной и той же функции могут находиться в любых отношениях: содержаться одно в другом или не иметь пересечения или пересекаться. Но на начальном этапе эти задачи имеют много общего, и поэтому можно ограничиться каким-то конкретным критерием. Обычно в качестве такого критерия рассматривается число букв в ДНФ.
Итак, далее под задачей минимизации булевой функции будем понимать построение её минимальных дизъюнктивных нормальных форм.
Заметим, что в силу двойственности ДНФ и КНФ, в задаче минимизации булевой функции обычно рассматривают только построение минимальных ДНФ. При этом исходными данными обычно считают таблицу истинности функции или совершенную ДНФ (СДНФ). Существует так называемый тривиальный алгоритм построения всех МДНФ для произвольной булевой функции f(x1, x2, …, xn). Он состоит в просмотре всех различных ДНФ, которые могут быть построены над алфавитом {x1, x2, …, xn}, и выделении тех из них, которые реализуют функцию f и имеют наименьшую сложность. Однако, в виду того, что общее число ДНФ от n переменных равно 23n, тривиальный алгоритм фактически неприменим даже при небольших значениях n.
Для решения задачи минимизации разработано довольно много других алгоритмов, которые легко могут быть запрограммированы для ЭВМ. Рассмотрим простейшие из них.
Yandex.RTB R-A-252273-3- Часть II
- Алгебра двузначной логики
- Функции алгебры логики
- Способы задания функций алгебры логики
- Эквивалентность функций
- Реализация функций формулами
- Эквивалентность формул и тождества
- Упрощение формул
- Двойственные функции и принцип двойственности
- Применение принципа двойственности
- Аналитическая запись функций алгебры логики
- Аналитическое построение сднф и скнф
- Теорема о тройке связок
- Полные системы функций и полиномы Жегалкина
- Замыкание систем функций алгебры логики
- Важнейшие замкнутые классы
- Теорема Поста о полноте
- Минимизация булевых функций
- Основные понятия
- Метод неопределенных коэффициентов
- Тупиковые днф и алгоритм наискорейшего спуска
- Геометрическое представление функций алгебры логики
- Аналитическое построение сокращенной днф
- Локальные алгоритмы
- Алгоритм Куайна
- Диаграммы Вейча–Карно
- Построение днф по карте Карно
- Задачи и упражнения
- Список литературы
- Часть II
- 400131, Волгоград, просп. Им. В.И.Ленина, 28
- 400131, Волгоград, ул. Советская, 35