Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Примеры и Задание к контрольной работе по дискр....doc
Скачиваний:
30
Добавлен:
17.12.2018
Размер:
2.06 Mб
Скачать
    1. Двойственные функции и совершенные нормальные формы

      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=[f1f2,…, fp] реализует функцию f(x1,x2,…,xn), тогда формула [f1*f2*,…, fp*], полученная из формулы U заменой функций f1f2,…, fp двойственными функциями f1*f2*,…, fp* соответственно, реализует функцию f*(x1,x2,…,xn), двойственную f. Эта формула называется двойственной к формуле U и обозначается U*. Таким образом, U*= [f1*f2*,…, fp*], где S означает структуру формулы. Заметим, что структура формулы, определяемая порядком выполняемых действий, остается неизменной.

На практике наиболее часто принцип двойственности применяется к формулам, сконструированным из таких функций, как константы ноль и единица, тождественной функции, отрицания, конъюнкции и дизъюнкции. В таких случаях для получения двойственной формулы необходимо ноль заменить на единицу, а единицу на ноль везде, где они встречаются, знак «&» заменить знаком «», а знак «» – на «&». При этом следует учесть порядок выполняемых действий в исходной формуле и, если он не был задан явно скобками, а задавался только приоритетом операций, то, возможно, придется расставить скобки в двойственной формуле. Тогда установить их надо на тех же местах, где они неявно присутствовали в исходной формуле. В других случаях, ввиду того же старшинства операций, в двойственной формуле скобки, возможно, и не понадобятся.

Примеры:

  1. U1(x,y) = yU1*(x,y) =  y;

  2. U2(x,y) =   U2*(x,y) = ( y) &;

  3. U3(x,y) = ( y) & ()  U3*(x,y) = y  .