Элементарные функции алгебры логики
Материалы этого приложения базируются на учебниках, пособиях[3, 7, 46, 44, 76, 89 , 52, 16 и информации с интернета]. Основы алгебры логики, которые здесь приведёны, позволят получить более глубокие знания и сократить время на поиск данного материала. В пособии [7, 16] подчёркнуто, что множество {0,1}, элементы которого не являются числами в обычном смысле, хотя по некоторым свойствам и похожи на них. Наиболее распространенная интерпретация двоичных переменных – логическая: «да» – «нет», «истинно» (и) – «ложно» (л), или «1» - «0».
Обозначения: E2={0,1}; Е = E2´E2´...´E2 – прямое произведение n сомножителей; (x ,..,xn)Î E2, | E2| – мощность E2, |E2|=2, тогда |Е |=2n.
Определение 1. Функцией алгебры логики называется закон, осуществляющий отображение Е E2, причем отображение всюду определено и функционально.
Так как множество Е конечно, то задать отображение Е Þ E2, означает задать множество наборов из Е и для каждого набора указать его образ в Е 2.
Пример 1. Пусть n=2, тогда Е ={(0 0),(0 1),(1 0),(1 1)}, отображение Е Þ E2 задано, например, так: (0 0) Þ0 ; (0 1) Þ1; (1 0) Þ1 ; (1 1) Þ1.
Тем самым задана функция, для которой мы будем использовать стандартное обозначение f(x1,x2), записывая эту функцию в виде таблицы:
x1 | x2 | f(x1,x2) |
Здесь x1 и x2 обозначают названия столбцов, а f – символ, обозначающий отображение. Следует обратить внимание, что функции f(x1,x2) и f(y1,y2) задают одно и то же отображение, и их таблицы отличаются только названиями столбцов.
Определение 2.Таблица, задающая функцию f(x1,x2,...,xn), называется таблицей истинности для этой функции.
Рассмотрим функции одной переменной. Их будет всего 4, они задаются следующими таблицами истинности:
x | f0(x) |
функция называется константой 0, записывается f0(x) 0;
x | f1(x) |
функция называется тождественной, записывается f1(x)= x;
x | f2(x) |
функция называется «не x» и записывается f2 (x)= ;
x | f3(x) |
функция записывается f3(x) 1 и называется константой 1. Если стандарт-ным расположением переменной x считать 0 в первой строке и 1 во второй, то функции f0, f1, f2, f3 определяются однозначно наборами значений: f0=(0,0), f1=(0,1), f2=(1,0) и f3=(1,1). Наборы значений функций составляют множество E2´Е2, поэтому количество функций одной переменной равно |E2 E2|=4. Для удобства функции пронумерованы так, что двоичный код номера совпадает с набором значений функции.
Рассмотрим функции двух переменных f(x1,x2). Функции двух переменных определены на множестве Е ={(0 0),(0 1),(1 0),(1 1)}, эти наборы переменных из Е можно тоже рассматривать как двоичные коды чисел 0,1,2,3, именно такой порядок расположения наборов (x1,x2) будем считать стандартным. Тогда функции f(x1,x2) определяются однозначно наборами значений (b1, b2, b3, b4), где каждое biÎE2, поэтому (b1, b2, b3, b4)ÎЕ . Следовательно, число функций двух переменных равно 24=16, занумеруем их числами от 0 до 15 так, чтобы двоичный код номера совпадал с набором значений функции.
x1 x2 | f0 | f1 | f2 | f3 | f4 | f5 | f6 | f7 | f8 | f9 | f10 | f11 | f12 | f13 | f14 | f15 |
0 0 0 1 1 0 1 1 |
Некоторые из этих функций носят специальные названия и играют такую же роль, как элементарные функции в анализе, поэтому называются элементарными функциями алгебры логики. Перечислим их.
1) f1(x1,x2) = (x1&x2), читается «конъюнкция х1 и х2», иногда вместо знака & употребляют знак или вообще его опускают, пишут (х1х2). (х1&х2) совпадает с обычным произведением х1х2 и совпадает с min(x1,x2). Эту операцию называют также логическим умножением.
2) f6(x1,x2) = (x1Åx2) – сложение х1 и х2 по модулю два, иногда пишут (х1+х2)mod2.
3) f7(x1,x2) = (x1Úx2), читается «х1 дизъюнкция х2», она совпадает с max(x1,x2), ее называют логическим сложением.
4) f8(x1,x2) = (x1¯x2), читается «х1 стрелка Пирса х2» и совпадает с отрицанием дизъюнкции, другие названия: функция Вебба, функция Даггера.
5) f9(x1,x2) = (x1~x2), читается «х1 эквивалентно х2».
6) f13(x1,x2)=(x1 x2), читается «х1 импликация х2», иногда обозначается (х1Éх2), т. е. х1 влечет х2 .
7) f14(x1,x2) = (x1|x2), читается «х1 штрих Шеффера х2», эта операция или функция является отрицанием конъюнкции.
Символы ,&,Ú,¯,~,® ,Å,|, участвующие в обозначениях элементарных функций, называются логическими связками или просто связками. Переменные 0 и 1 называются логическими или булевыми переменными, причем 0 соответствует «лжи» , а 1 – «истине», а функции алгебры логики называются еще и булевыми функциями.
Рассмотрим функции f(x1...xn), где (x1...xn)Î Е , тогда число наборов (x1...xn), где функция f(x1...xn) должна быть задана. Число наборов или ситуаций равно |Е |=2n. Обозначим множество всех функций двузначной алгебры логики Р2. Обозначим через Р2(n) число функций, зависящих от n переменных. Очевидно, что Р2(n)=22 n.
С ростом n число Р2(n) быстро растет: P2(1)=4, P2(2)=16, P2(3)=256, P2(4)=65536. При больших n табличный способ задания функций становится неприемлемым, используется формульное задание функций. Но прежде чем ввести понятие формулы, дадим определение существенной переменной.
Определение 3. Функция f(x1,...,xi–1,xi,xi+1,...,xn) существенно зависит от хi, если существуют такие значения a1, ...ai–1, ai+1, ...an переменных x1, ...xi–1, xi+1, ...xn, что f(a1, ...ai–1, 0, ai+1...an)¹f(a1...ai–1, 1, ai+1...an) . Тогда переменная хi называется существенной переменной. В противном случае хi называется фиктивной переменной.
Пример 2.
Рассмотрим несколько функций двух переменных
x1 | x2 | (x1&x2) | f3 | f15 |
Покажем, что (х1&x2) существенно зависит от х1. Рассмотрим наборы (0,1) и (1,1), здесь a2=1, f(0,a2)=0 и не равно f(1,a2)=1. Покажем, что х2 тоже существенная переменная. Рассмотрим наборы (1,0) и (1,1). Здесь a1=1, f(1,0)=0 и не равно f(1,1)=1. Для функции f3(x1,x2) покажем, что х2 – фиктивная переменная, т.е. надо показать, что не существует наборов (a1,0) и (a1,1) таких, что f3(a1,0)¹f3(a1,1). Пусть a1=0, т.е. рассмотрим наборы (0,0) и (0,1), f(0,0)=f(0,1)=0. Пусть a1=1, но f(1,0)=f(1,1)=1.
Для функции f15 и x1 и x2 являются фиктивными переменными. x1 – фиктивная переменная, если не существует наборов (0,a2) и (1,a2), таких, что f(0,a2)¹f(1,a2). Если a2=0, то f(0,0)=f(1,0)=1. Пусть a2=1, тогда f(0,1)=f(1,1)=1.
Пусть хi является фиктивной переменной для функции f(x1, ..., xi, ..., xn). Тогда ее можно удалить из таблицы истинности, вычеркнув все строки вида: (a1, ...ai–1, 1, ai+1, ...an) или, наоборот, все строки вида: (a1, ..., ai–1, 0, ai+1, ...an) и столбец для переменной хi. При этом получим таблицу для некоторой функции g(x1, ..., xi–1, xi+1, ...xn). Будем говорить, что функция g(x1, ...xi–1, xi+1, ...xn) получена из функции f(x1, ..., xi, ...xn) путем удаления фиктивной переменной хi или f получена из g путем введения фиктивной переменной хi.
Определение 4. Функции f1 и f2 называются равными, если f2 можно получить из f1 путем добавления или удаления фиктивной переменной.
Пример 3.
x1 | x2 | f3 |
Вычеркнули строки типа (a,1), т.е. (0,1) и (1,1) и столбец для х2.
Получили f3(x1 x2) = g(x1) = x1.
Пример 4.
x1 | x2 | g |
Пусть функция g(x1 x2) задана таблицей и существенно зависит от обеих переменных. Построим функцию f(x1,x2,x3), которая получается из g(x1,x2) введением фиктивной переменной х3:
x1 | x2 | x3 | f |
К наборам (х1,х2) мы добавим х3=0, получим наборы вида: (a1,a2,0), на этих наборах функцию f положим равной g(a1,a2), затем добавим наборы вида (a1,a2,1), функцию f(a1,a2,1) положим равной g(a1,a2).
Особую роль играют константы 0 и 1, которые не имеют существенных переменных и которые можно рассматривать как функции от пустого множества переменных.
Определение 2. Две формулы N и D из <M> называются равными
N=D или эквивалентными N~D , если функции, реализуемые ими, равны.
Пример 2.Доказать эквивалентность формул:
( &(х2Åx3))~( ) .
x1 | x2 | x3 | x2Åx3 | & | x2® x3 | x3®x2 | & | Úx1 | ® |