Определение. Булевой функцией f(x1, x2, …, xn) называется n-местная функция, аргументы которой принимают значения во множестве {0, 1} и сама функция принимает значения в этом же множестве.
Всякую булеву функцию от n переменных можно задать таблицей из 2n строк, в которой в каждой строке записывают одну из оценок списка переменных, принимающих значение 0 или 1.
Пример 31.
Для n=3 булеву функцию можно задать (табл. 2.15).
Таблица 2.15 Булева функция для n=3
N/н |
x1 |
x2 |
x3 |
f(x1, x2, x3) |
0 |
0 |
0 |
0 |
f(0, 0, 0) |
1 |
0 |
0 |
1 |
f(0, 0, 1) |
2 |
0 |
1 |
0 |
f(0, 1, 0) |
3 |
0 |
1 |
1 |
f(0, 1, 1) |
4 |
1 |
0 |
0 |
f(1, 0, 0) |
5 |
1 |
0 |
1 |
f(1, 0, 1) |
6 |
1 |
1 |
0 |
f(1, 1, 0) |
7 |
1 |
1 |
1 |
f(1, 1, 1) |
Используется также задание булевой функции в виде двоичного слова, длина которого зависит от числа переменных.
Пример 32.
Пусть задана булева функция от трех переменных (табл. 2.16). Тогда число наборов .
Таблица 2.16 Булева функция для примера 32
№ набора |
х1 |
х2 |
х3 |
f |
0 |
0 |
0 |
0 |
0 |
1 |
0 |
0 |
1 |
0 |
2 |
0 |
1 |
0 |
1 |
3 |
0 |
1 |
1 |
0 |
4 |
1 |
0 |
0 |
1 |
5 |
1 |
0 |
1 |
1 |
6 |
1 |
1 |
0 |
0 |
7 |
1 |
1 |
1 |
1 |
Номера наборов всегда нумеруются, начиная с нуля, в таблице приведено стандартное расположение всех наборов функции трех переменных (обратите внимание, что каждый набор представляет собой двоичный код числа, равный номеру соответствующего набора). Первые четыре столбца одинаковы для всех булевых функций от трех переменных. Столбец значений функции задается или вычисляется.
Эту же функцию можно записать f(х1, х2, х3)=01.
Существует ровно различных булевых функций от n переменных. Константы 0 и 1 считают нуль-местными булевыми функциями.
Утверждение. Каждой формуле логики высказываний соответствует некоторая булева функция.
Пример 33.
Построить все булевы функции, зависящие от двух переменных.
Решение.
Поскольку n=2, различных булевых функций от двух переменных существует ровно 16 (табл. 2.17).
Таблица 2.17 Булевы функции, зависящие от 2 переменных
Номер функции |
Значение функции |
Формула, соответствующая функции |
1 |
f=0000 |
f=0 |
2 |
f=0001 |
f=x1x2 |
3 |
f=0010 |
f= |
4 |
f=0011 |
f=x1 |
5 |
f=0100 |
f= |
6 |
f=0101 |
f=x2 |
7 |
f=0110 |
f=x1x2 |
8 |
f=0111 |
f=x1x2 |
9 |
f=1000 |
f= |
10 |
f=1001 |
f= |
11 |
f=1010 |
f= |
12 |
f=1011 |
f= |
13 |
f=1100 |
f= |
14 |
f=1101 |
f=x1®x2 |
15 |
f=1110 |
f= |
16 |
f=1111 |
f=1 |
Теорема 1. Пусть f(x1, x2, …, xk) k-местная булева функция. Если f не равна тождественно нулю, то существует такая формула F, зависящая от списка переменных x1, x2, …, xn и находящаяся в СДНФ относительно этого списка, что F выражает собой функцию f. Формула F определена однозначно с точностью до перестановки дизъюнктивных членов.
Теорема 2. Пусть f(x1, x2, …, xk) k-местная булева функция. Если f не равна тождественно единице, то существует такая формула F, зависящая от списка переменных x1, x2, …, xk и находящаяся в СКНФ относительно этого списка, что F выражает собой функцию f. Формула F определена однозначно с точностью до перестановки конъюнктивных членов.
Поскольку каждая булева функция представима в виде формулы логики высказываний, то принцип построения СДНФ и СКНФ сохраняется такой же как и для формул логики высказываний.
Пример 34.
Построить СКНФ и СДНФ булевой функции f(x1, x2, x3)= 00.
Решение.
Строим таблицу значений функции (табл. 2.18):
Таблица 2.18 Таблица значений функции для примера 34
N/н |
x1 |
x2 |
x3 |
f(x1, x2, x3) |
0 |
0 |
0 |
0 |
0 |
1 |
0 |
0 |
1 |
0 |
2 |
0 |
1 |
0 |
1 |
3 |
0 |
1 |
1 |
0 |
4 |
1 |
0 |
0 |
1 |
5 |
1 |
0 |
1 |
1 |
6 |
1 |
1 |
0 |
1 |
7 |
1 |
1 |
1 |
0 |
СКНФ (0): № 0, 1, 3, 7:
СДНФ (1): № 2, 4, 5, 6