
- •Дискретная математика Методические указания и контрольные задания для студентов I курса заочной формы обучения Оглавление
- •I.Краткие теоретические сведения
- •I.1.Множества и операции над ними
- •I.2.Бинарные отношения
- •1.Отношение эквивалентности
- •2.Отношение упорядоченности
- •3.Функции
- •I.3.Функции и формулы алгебры логики
- •I.4.Двойственные функции и совершенные нормальные формы
- •1.Принцип двойственности
- •2.Построение совершенных нормальных форм
- •I.5.Полнота и замкнутость систем функций алгебры логики
- •1.Полные системы функций алгебры логики
- •2.Важнейшие замкнутые классы
- •II.Задание к контрольной работе по дискретной математике
- •I. Множества и операции над ними.
- •III.Варианты контрольных работ Вариант №1
- •Вариант №2
- •Вариант №3
- •Вариант №4
- •Вариант №5
- •Вариант №6
- •Вариант №7
- •Вариант №8
- •Вариант №9
- •Вариант №10
- •Вариант №11
- •Вариант №12
- •Вариант №13
- •Вариант №14
- •IV.Пример решения контрольной работы
- •V.Список литературы
I.4.Двойственные функции и совершенные нормальные формы
1.Принцип двойственности
Функция
называется двойственной к функции
f(x1,x2,…,xn).
Для обозначения двойственной функции
используется запись: [f(x1,x2,…,xn)]*
или f*(x1,x2,…,xn)
или f*.
Для получения столбца значений двойственной функции, как следует из определения, необходимо инвертировать значения функции f, т.е. заменить все единицы на нули, а нули – на единицы, а затем «перевернуть» полученный столбец, т.е. переписать его, начиная с конца, – что соответствует инвертированию значений переменных.
В таблице 5 процесс получения двойственной функции показан по шагам.
x |
y |
z |
f(x,y,z) |
|
|
|
0 |
0 |
0 |
1 |
0 |
0 |
|
0 |
0 |
1 |
1 |
0 |
1 |
|
0 |
1 |
0 |
0 |
1 |
1 |
|
0 |
1 |
1 |
1 |
0 |
1 |
|
1 |
0 |
0 |
0 |
1 |
0 |
|
1 |
0 |
1 |
0 |
1 |
1 |
|
1 |
1 |
0 |
0 |
1 |
0 |
|
1 |
1 |
1 |
1 |
0 |
0 |
Таблица 5 |
Легко убедиться, что (0)*=1, (1)*=0, (х)*=х, ( )*= , (x&y)*= xy, (xy)*=x&y, (xy)*= , ( )*=yx, (xy)*=xy, (xy)*=xy, (xy)*=xy, (xy)*=xy.
Из определения двойственности следует, что f**=(f*)*=f, т.е. f двойственна f*, – это так называемое свойство взаимности.
Принцип двойственности:
пусть формула U=S [f1, f2,…, fp] реализует функцию f(x1,x2,…,xn), тогда формула S [f1*, f2*,…, fp*], полученная из формулы U заменой функций f1, f2,…, fp двойственными функциями f1*, f2*,…, fp* соответственно, реализует функцию f*(x1,x2,…,xn), двойственную f. Эта формула называется двойственной к формуле U и обозначается U*. Таким образом, U*= S [f1*, f2*,…, fp*], где S означает структуру формулы. Заметим, что структура формулы, определяемая порядком выполняемых действий, остается неизменной.
На практике наиболее часто принцип двойственности применяется к формулам, сконструированным из таких функций, как константы ноль и единица, тождественной функции, отрицания, конъюнкции и дизъюнкции. В таких случаях для получения двойственной формулы необходимо ноль заменить на единицу, а единицу на ноль везде, где они встречаются, знак «&» заменить знаком «», а знак «» – на «&». При этом следует учесть порядок выполняемых действий в исходной формуле и, если он не был задан явно скобками, а задавался только приоритетом операций, то, возможно, придется расставить скобки в двойственной формуле. Тогда установить их надо на тех же местах, где они неявно присутствовали в исходной формуле. В других случаях, ввиду того же старшинства операций, в двойственной формуле скобки, возможно, и не понадобятся.
Примеры:
U1(x,y) = x & y U1*(x,y) = x y;
U2(x,y) = x & y U2*(x,y) = (x y) & ;
U3(x,y) = (x y) & (
) U3*(x,y) = x & y
.